Hans Fugal [Wed, 15 Oct 2014 16:31:52 +0000 (09:31 -0700)]
(wangle) s/State/Core/
Summary:
codemod
`State` is such an overloaded term, and not really the best to describe this backing future/promise object. Yes, it holds the state but it's more than that and it gets in the way of calling the states of the state machines `State`s.
Test Plan: builds and tests pass
Reviewed By: davejwatson@fb.com
Subscribers: trunkagent, net-systems@, fugalh, exa, njormrod
FB internal diff:
D1615707
Andrii Grynenko [Wed, 15 Oct 2014 01:00:43 +0000 (18:00 -0700)]
Bump version to 12:0
Andrii Grynenko [Wed, 8 Oct 2014 01:12:33 +0000 (18:12 -0700)]
Don't re-create singletons
Summary:
This forbids singleton creation/re-creation after destroyInstances() was called.
Only after reset() is called singletons can be created again.
registrationComplete() behavior is also slightly change. We disallow singleton registration after registrationComplete() is called even in Relaxed mode. Strict mode now only controlls whether singletons can be constructed before registation is complete.
Test Plan: unit test
Reviewed By: chip@fb.com
Subscribers: hphp-diffs@, ps, trunkagent, njormrod, mshneer, lins
FB internal diff:
D1605136
Yedidya Feldblum [Fri, 10 Oct 2014 19:44:26 +0000 (12:44 -0700)]
Basic tests for EventHandler.
Summary:
[Folly] Basic tests for EventHandler.
Worthwhile adding some tests just for this class since it's rather fundamental. It is already tested indirectly via any number of things that make use of EventBase under the hood, but it's worth having a place for more direct tests.
Test Plan: Unit tests in `folly/io/async/test/EventHandlerTest.cpp`.
Reviewed By: njormrod@fb.com
Subscribers: njormrod, chalfant, dougw
FB internal diff:
D1606284
Soren Lassen [Fri, 10 Oct 2014 14:12:31 +0000 (07:12 -0700)]
Better estimateSpaceNeeded(double)
Test Plan: fbconfig -r folly/test && fbmake runtests
Reviewed By: mpawlowski@fb.com
Subscribers: njormrod
FB internal diff:
D1604761
Blame Revision:
D1420588
Hans Fugal [Thu, 9 Oct 2014 23:27:12 +0000 (16:27 -0700)]
Go back to a regular mutex
Summary:
D1428504 changed the `detail::State` mutex to be a recursive mutex to get around deadlock in our project, where a promise was being freed within a callback, racing with the mechanics happening while fulfilling the promise in the first place. At least, that's what seemed to be happening. I couldn't easily pull it into gdb because it's a python test.
I made my own test to repro, and it did in fact deadlock:
TEST(Future, DISABLED_promiseDestructedDuringCallback) {
auto p = folly::make_unique<Promise<void>>();
p->getFuture().then([&](Try<void>&&) {
// shouldn't deadlock.
p.reset();
});
p->setValue();
}
However, although this code fixes our project it does not fix this code, which still fails (not with a deadlock, but with a promiseAlreadyFulfilled exception). So whatever our project is doing is a bit more intricate.
I'm not convinced that even allowing this is ok - so I suspect out project is doing something bad. However, I also think it's probably bad to hold the lock while doing the callback so I am presenting this as a fix/compromise.
Test Plan:
unit tests
Reviewed By: hannesr@fb.com
Subscribers: net-systems@, fugalh, exa, njormrod, fsilva, davejwatson
FB internal diff:
D1604829
Blame Revision:
D1428504
Sean Cannella [Thu, 9 Oct 2014 19:40:37 +0000 (12:40 -0700)]
Port compilation fixes (1/3)
Test Plan: existing tests
Reviewed By: meyering@fb.com
Subscribers: trunkagent, bmatheny, ranjeeth, njormrod, subodh
FB internal diff:
D1605942
Tasks:
5183325
Francis Ma [Thu, 9 Oct 2014 15:35:06 +0000 (08:35 -0700)]
Move static global variable randomDevice inside the scope of the function
Test Plan: Tests under folly passed
Reviewed By: seanc@fb.com
Subscribers: trunkagent, seanc, njormrod
FB internal diff:
D1600266
Tasks:
5317470
Nathan Bronson [Thu, 9 Oct 2014 02:44:16 +0000 (19:44 -0700)]
add per node mutex for emulated futex
Summary:
The emulated futex (not used on Linux) has an optimization to defer
notification until after the bucket mutex has been unlocked, to avoid
lock collisions between the waiter and waker. That code will have a
use-after-free problem if the waiter's condition_variable has a spurious
wakeup, which is allowed by the spec. That code also doesn't do
anything about contention between multiple waiters.
This diff adds a mutex to each wait node, relieving the waiters from
having to acquire the bucket lock on wakeup. Rather than trying to
perform a racy late notification, we just make sure to release the node
lock immediately after calling notify_one, which seems to have the
desired effect.
Test Plan:
1) existing unit tests
2) new unit tests
Reviewed By: delong.j@fb.com
Subscribers: boseant, njormrod
FB internal diff:
D1602360
James Sedgwick [Thu, 9 Oct 2014 00:15:17 +0000 (17:15 -0700)]
move TEventBaseManager to folly/io/async/EventBaseManager
Summary:
This class isn't thrift specific anymore, especially now that TEventBase->EventBase.
Specific use case in folly: folly/experimental/wangle/concurrent/IOThreadPoolExecutor
EventBaseManager itself needs some work/cleanup, but that is for a later diff
For instance, we might try to push towards only allowing access to the singleton, and towards
removing overrides. i.e. only getEventBase. But that's pending an audit of how people are using it now.
Note that the ProfiledMutex protecting the event base set has been made a regular std::mutex
Test Plan:
compiled thrift/lib/cpp|cpp2, made a pass at fixing forward declarations elsewhere
will let contbuild help me iterate
Reviewed By: hans@fb.com
Subscribers: trunkagent, nli, fbcode-common-diffs@, davejwatson, hero-diffs@, zeus-diffs@, andrewcox, netego-diffs@, alandau, apollo-diffs@, antonl, laser-diffs@, ads-dsp-eng@, darshan, micha, njormrod, panin, hdoshi, scuba-diffs@, bmatheny
FB internal diff:
D1590827
Tasks:
5247981
Nathan Bronson [Wed, 8 Oct 2014 23:59:27 +0000 (16:59 -0700)]
fix flaky test from uninitialized std::atomic
Summary:
std::atomic<bool> default constructor doesn't initialize it to
false, so the flag to end the LifoSem.multi_try_wait test was sometimes
set too early. This diff fixes that, makes the test more deterministic,
and also fixes a couple of other benign uninitialized values (so that
they won't be used as prototypes for places where it does matter).
Test Plan: unit tests
Reviewed By: mpawlowski@fb.com
Subscribers: njormrod, lovro
FB internal diff:
D1604508
Tasks:
5336837
Hans Fugal [Wed, 8 Oct 2014 19:06:38 +0000 (12:06 -0700)]
Fix via
Summary: Sometimes you just have to take a step back. :-P
Test Plan: All the unit tests including the one that had been disabled, now pass.
Reviewed By: hannesr@fb.com
Subscribers: meisner, trunkagent, net-systems@, fugalh, exa, njormrod, davejwatson
FB internal diff:
D1596368
Tasks:
4920689,
4480567,
5306911
Marcin Pawlowski [Wed, 8 Oct 2014 19:00:18 +0000 (12:00 -0700)]
stop prereserving space in toAppend
Summary:
previous change would cause reserving
as much as needed in toAppend for all arguements.
This had bad consequences for appending in a loop,
described here: https://phabricator.fb.com/
D1420588#22
Not split the interfaces so that user has to decide
Test Plan: unit tests
Reviewed By: soren@fb.com
Subscribers: trunkagent, njormrod
FB internal diff:
D1601614
Tasks:
5303991
Hans Fugal [Tue, 7 Oct 2014 22:50:32 +0000 (15:50 -0700)]
wangle-bench gflags
Summary: Because windtunnel quirkloads needs `--json` which is enabled with gflags
Test Plan:
$ wangle-bench --json
{
"%hundredThens" :
28133155.
113220215,
"no_contention" :
4842268655.11322,
"%fourThens" :
1495655.
1132202148,
"%twoThens" : 882311.
3632202148,
"oneThen" : 581053.
5507202148,
"-" : 0,
"%withThen" : 559830.
8944702148,
"%promiseAndFuture" : 250840.
66009521484,
"%contention" :
8074419655.11322,
"constantFuture" : 239916.
83197021484
}
Reviewed By: meisner@fb.com
Subscribers: robbert, net-systems@, fugalh, exa, njormrod, davejwatson, jsedgwick
FB internal diff:
D1601364
Tasks:
5277907
Hans Fugal [Tue, 7 Oct 2014 23:36:06 +0000 (16:36 -0700)]
serial/parallel benchmark
Summary: This is an attempt to see the effect of lock contention in the less-common case where a promise is fulfilled at the same time the future is still being set up. Although this is expected to be off the beaten path, it will still be a good idea to keep an eye on how we improve or worsen perf, when we play with different locking strategies (which I intend to do a lot of in the near term).
Test Plan:
============================================================================
folly/wangle/test/Benchmark.cpp relative time/iter iters/s
============================================================================
constantFuture 249.31ns 4.01M
promiseAndFuture 100.88% 247.13ns 4.05M
withThen 43.87% 568.30ns 1.76M
----------------------------------------------------------------------------
oneThen 569.62ns 1.76M
twoThens 63.46% 897.60ns 1.11M
fourThens 39.64% 1.44us 695.90K
hundredThens 1.91% 29.75us 33.61K
----------------------------------------------------------------------------
serial 4.97ms 201.21
parallel 60.22% 8.25ms 121.18
============================================================================
Reviewed By: jsedgwick@fb.com
Subscribers: meisner, net-systems@, fugalh, exa, njormrod
FB internal diff:
D1593010
Nathan Bronson [Wed, 1 Oct 2014 22:46:20 +0000 (15:46 -0700)]
add emulation of futex() for non-Linux systems
Summary:
Inside the Linux kernel, futex() works by hashing the source
address to a fixed set of wakeup lists. When using folly on non-Linux
systems we can emulate something similar by using std::mutex and
std::condition_variable.
Emulating futex() using higher-level APIs is less crazy than it sounds,
because the emulated futex still provides the advantages of the real
one: it allows all of the fast-paths of a new synchronization construct
to be inlined; it is space efficient, taking only 1 word and allowing
the caller to encode state into all of the word's bits; and it avoids
system calls unless a thread actually needs to be put to sleep or
woken up. Think of this as a way of boostrapping something with the
same properties as futex() on platforms that don't expose it publically.
(Presumably these platforms have private APIs that do something similar.)
This diff moves all of the Linux-specific futex stuff into Futex.cpp,
where it is gated by #ifdef __linux__. It also adds an emulated
implementation. The emulated futex will be selected by default on
non-Linux platforms, or it can be used on Linux by using an Atom template
type of folly::detail::EmulatedFutexAtomic. This means, for example,
that you can test MPMCQueue on top of the emulated API by instantiating
a MPMCQueue<ElemType, EmulatedFutexAtomic>.
As a bonus, this refactoring provides a small speed boost by removing
an unnecessary evaluation of the errno macro in the success path of
futexWait.
Test Plan:
1. existing unit tests
2. new unit tests (including tests of Futex users)
3. compile Futex.cpp on OS X (some other build failures still occur)
Reviewed By: delong.j@fb.com
Subscribers: trunkagent, njormrod, yiding, boseant, mssarang
FB internal diff:
D1596118
Tasks:
4952724
Francis Ma [Mon, 6 Oct 2014 23:34:06 +0000 (16:34 -0700)]
Move static member inside the scope of the function
Summary: We are seeing crashes which comes from the initialization of the static global variable. This particular variable is used only in a single function that was never invoked. So moving it into the scope of the function will at least solve the problem. The real issue still requires some deep investigation though.
Test Plan: unitest under folly passed
Reviewed By: subodh@fb.com
Subscribers: seanc, njormrod
FB internal diff:
D1598048
Tasks:
5316441
Nathan Bronson [Mon, 6 Oct 2014 04:04:53 +0000 (21:04 -0700)]
detail::MemoryIdler should use Malloc.h's mallctl decl
Summary:
Malloc.h now takes care to declare mallctl properly on platforms
that aren't using weak symbols, so we should just rely on that for
MemoryIdler.cpp. This is one step toward fixing folly build on OS X.
Test Plan: fbmake runtests
Reviewed By: je@fb.com
Subscribers: yiding, njormrod
FB internal diff:
D1596930
Tasks:
4952724
Blame Revision:
Andrii Grynenko [Thu, 2 Oct 2014 03:34:27 +0000 (20:34 -0700)]
Leak folly::SingletonVault
Summary:
This will ensure SingletonVault is always available. It matters for singletons, not managed by folly::Singleton. Singletons in it will actually be destroyed via static SingletonVaultDestructor.
This does the same as
D1591270 (which got reverted), but doesn't change destruction order.
Test Plan:
Run tests which were broken by
D1591270
Reviewed By: chip@fb.com
Subscribers: njormrod
FB internal diff:
D1594898
Andrii Grynenko [Wed, 17 Sep 2014 04:12:10 +0000 (21:12 -0700)]
Fix folly::Singleton to work with objects w/o default constructor
Test Plan:
unit tests
Reviewed By: ostap@fb.com
Subscribers: netego-diffs@, trunkagent, alikhtarov, marccelani, mshneer, zhuohuang, lins, njormrod
FB internal diff:
D1560406
Anton Likhtarov [Thu, 2 Oct 2014 20:23:20 +0000 (13:23 -0700)]
Add extra assertions in ExternalUnixAddr::free()
Summary: Memory corruption investigation
Test Plan: fbconfig folly/test:network_address_test; fbmake runtests
Reviewed By: davejwatson@fb.com
Subscribers: trunkagent, andrii, njormrod
FB internal diff:
D1592539
Tasks:
5230657
Blame Revision:
D1575098
Daniel Sommermann [Thu, 2 Oct 2014 22:19:27 +0000 (15:19 -0700)]
Revert "Leak folly::SingletonVault"
Summary:
This reverts commit
3cf88fb680b4b9c47189d1e12699e2c24c7ac38b. It
was timing out our tests. probably static (de)initialization order fiasco related.
Test Plan: watch contbuild, git bisect
Reviewed By: afrind@fb.com
Subscribers: doug, njormrod
FB internal diff:
D1593016
Andrii Grynenko [Thu, 2 Oct 2014 03:34:27 +0000 (20:34 -0700)]
Leak folly::SingletonVault
Summary: This will ensure SingletonVault is always available. It matters for singletons, not managed by folly::Singleton. Singletons in it will actually be destroyed via static SingletonVaultDestructor.
Test Plan: unit test
Reviewed By: chip@fb.com
Subscribers: njormrod
FB internal diff:
D1591270
Hans Fugal [Thu, 2 Oct 2014 17:39:53 +0000 (10:39 -0700)]
add some benchmarks
Summary: For great speed
Test Plan:
$ fbmake opt && _bin/folly/wangle/wangle-bench
============================================================================
folly/wangle/test/Benchmark.cpp relative time/iter iters/s
============================================================================
constantFuture 235.92ns 4.24M
promiseAndFuture 100.37% 235.04ns 4.25M
withThen 41.97% 562.17ns 1.78M
----------------------------------------------------------------------------
oneThen 539.03ns 1.86M
twoThens 64.01% 842.14ns 1.19M
fourThens 39.27% 1.37us 728.62K
hundredThens 1.82% 29.63us 33.75K
============================================================================
Reviewed By: davejwatson@fb.com
Subscribers: trunkagent, net-systems@, fugalh, exa, njormrod
FB internal diff:
D1587871
James Sedgwick [Thu, 2 Oct 2014 03:49:37 +0000 (20:49 -0700)]
subscriptions
Summary:
I'm not thrilled with this implementation, but it mostly works. The big bummer is enforcing that Observables are held in shared_ptrs, or rather that enforcing that condition is impossible.
The protected constructor / friended dumb make_shared() pattern is clunky, and it'd be really easy for a subclasser to shoot themselves in the foot or even in the face.
It does seem like maybe Observable should be made an interface again, and all these details should live in a subclass (FanoutObservable?) where the restriction are super obvious. For instance, the langtech AudioStream object doesn't need all this crap because it overrides subscribe() without using the observer list, but it subclasses anyways.
I'm noodling another approach that (if it works) will not require the shared_ptr dancing, but will probably have some additional overhead... the observable would have to keep track of the subscriptions itself.
I like the RAII subscriptions, though perhaps subscriptions should be optional as long as it's clear that your subscription will last forever it you opt out of them.
Thoughts?
Test Plan: added unit
Reviewed By: hans@fb.com
Subscribers: rushix, hannesr, trunkagent, fugalh, mwa, jgehring, fuegen, njormrod, bmatheny
FB internal diff:
D1580443
Adam Simpkins [Sun, 28 Sep 2014 01:08:34 +0000 (18:08 -0700)]
add stringVPrintf() and stringVAppendf()
Summary:
This adds versions of stringPrintf() and stringAppendf() that accept
va_list arguments.
This also fixes the existing stringPrintf() functions to properly call
va_end() even when an exception is thrown in stringPrintfImpl().
Test Plan: Included new unit tests for stringVPrintf() and stringVAppendf().
Reviewed By: davejwatson@fb.com
Subscribers: trunkagent, doug, net-systems@, exa, njormrod
FB internal diff:
D1583675
James Sedgwick [Wed, 1 Oct 2014 17:55:34 +0000 (10:55 -0700)]
in thread pools, take factory as shared ptr
Summary: needed for thrift server. if you have some sort of stateful/functional factory and you want to hold on to it, you should be allowed to
Test Plan: compiles with forthcoming thrift diff
Reviewed By: davejwatson@fb.com
Subscribers: trunkagent, fugalh, njormrod
FB internal diff:
D1584587
James Sedgwick [Wed, 1 Oct 2014 17:32:54 +0000 (10:32 -0700)]
expose event base from IOThreadPoolExecutor
Summary:
I'm not 100% sure this is the best way to go about this but I don't hate it either.
I'm going to start seeing how it might fit into tserver - my guess is that some sort Cpp2WorkerFactory which also manages those objects would get plugged in as the thread factory
Haven't fleshed out how this would relate to TEventBaseManager
Test Plan: added unit, starting to play with this in Thrift2 server
Reviewed By: davejwatson@fb.com
Subscribers: alandau, bmatheny, trunkagent, fugalh, njormrod
FB internal diff:
D1574660
Dave Watson [Tue, 30 Sep 2014 23:17:25 +0000 (16:17 -0700)]
Bump version to 11:0
Hans Fugal [Tue, 30 Sep 2014 22:52:52 +0000 (15:52 -0700)]
(Wangle) Make via behave more like gate
Summary:
Could the problem be that via continues the existing chain of futures,
whereas we actually want to start a new chain?
Is there any particular reason this wasn't implemented like this originally?
Test Plan:
Ran all the unit tests. I hope to try to reproduce the thread issue and
see if this improves things.
Reviewed By: davejwatson@fb.com
Subscribers: trunkagent, net-systems@, exa, njormrod, fugalh
FB internal diff:
D1500225
Tasks:
4920689
Andrii Grynenko [Wed, 24 Sep 2014 00:50:05 +0000 (17:50 -0700)]
remove get_weak from singleton
Summary:
Test Plan: fbmake runtests, OBC no longer segfaults
Reviewed By: mshneer@fb.com
Subscribers: fbcode-common-diffs@, trunkagent, mcduff, marccelani, hitesh, mshneer, njormrod, lins
FB internal diff:
D1573880
Alan Frindell [Mon, 29 Sep 2014 20:01:49 +0000 (13:01 -0700)]
Fix compiler warning in Subprocess
Summary: I'm going to have hhvm depend on Subprocess, found this build error in open source. I figured the intent was to set r to the return code. I could also delete the whole thing since it's unused.
Test Plan: Unit tests
Reviewed By: tudorb@fb.com
Subscribers: trunkagent, mwilliams, doug, njormrod
FB internal diff:
D1583626
Haijun Zhu [Mon, 29 Sep 2014 17:09:38 +0000 (10:09 -0700)]
Fix bug and unit test failure in HHWheelTimer
Summary: Some minor bug and a failed test caused by
D1578466
Test Plan:
fbconfig thrift/lib/cpp/test:HHWheelTimerTest && fbmake
runtests
Reviewed By: davejwatson@fb.com
Subscribers: trunkagent, alandau, bmatheny, njormrod
FB internal diff:
D1581949
Andrii Grynenko [Fri, 26 Sep 2014 02:02:37 +0000 (19:02 -0700)]
Use RWSpinLock for Singleton mutex
Summary: We only need exclusive lock when we add items to singletons_. Each SingletonEntry has its own mutex, so it's safe to rely on it for any modifications within individual entries.
Test Plan: Applied
D1573880 and ran fbconfig -r servicerouter/client/cpp2 && fbmake runtests
Reviewed By: chip@fb.com
Subscribers: trunkagent, njormrod, hitesh, mshneer
FB internal diff:
D1579877
Nicholas Ormrod [Fri, 26 Sep 2014 22:19:51 +0000 (15:19 -0700)]
Malloc cannot include ScopeGuard
Summary:
Because we put FBString and Malloc into libgcc, we have to be
careful which dependencies they each have. We cannot include ScopeGuard.
Reorganize the code a bit to avoid the ScopeGuard.
Test Plan: fbconfig -r folly && fbmake runtests
Reviewed By: je@fb.com
Subscribers: trunkagent, sdwilsh, njormrod
FB internal diff:
D1580957
Nicholas Ormrod [Fri, 26 Sep 2014 22:17:04 +0000 (15:17 -0700)]
Rare bug fix
Summary:
By the birthday paradox, this will fail about once every 8,100
runs. Dropping to 100 with cut that to 1 in 860,000.
Test Plan: fbconfig -r folly && fbmake runtests
Reviewed By: sdoroshenko@fb.com
Subscribers: sdwilsh, njormrod
FB internal diff:
D1581238
Anton Likhtarov [Fri, 26 Sep 2014 22:29:05 +0000 (15:29 -0700)]
Bump version to 10:0
James Sedgwick [Fri, 26 Sep 2014 19:17:01 +0000 (12:17 -0700)]
fix future executor test
Summary: This should be the last test abusing sleeps.
Test Plan: ran
Reviewed By: hannesr@fb.com
Subscribers: fugalh, njormrod
FB internal diff:
D1580830
Tasks:
5225808
Jim Meyering [Thu, 25 Sep 2014 22:25:36 +0000 (15:25 -0700)]
folly/GroupVarint: fix a clang-caught heap-buffer-overrun
Summary:
Avoid a clang-caught heap-buffer-overrun
and document that the ssse3 decoder requires at least 17 bytes
of readable memory starting at the source pointer.
* folly/GroupVarint.h (decode_simple): Comment out dead code.
(decode)[__SSSE3__]: Add a comment describing this limitation.
* folly/test/GroupVarintTest.cpp (testGroupVarint32):
Include <algorithm> for use of std::max.
Ensure that the buffer we use has length at least 17.
Test Plan:
Now, all tests succeed with clang/asan
Reviewed By: simpkins@fb.com
Subscribers: trunkagent, mathieubaudet, njormrod
FB internal diff:
D1579109
Tasks:
5241437
James Sedgwick [Fri, 26 Sep 2014 15:56:56 +0000 (08:56 -0700)]
RFC: future executor
Summary:
not necessarily for commit but i was playing around a bit with this today to see what it might look like, so i figured i'd put it up
i assume this shenanigan isn't remotely safe (threadwise) without some extra magic... @fugalh we chatted about this last time i was in mpk a bit.
maybe addFuture could take an executor to make sure the promise is fulfilled on the correct thread, or something.
you'd have to reimplement timeouts via this executor or via futures if you wanted to get them via the futures channel, which makes sense anyway as this could be used with any Executor and not just ThreadPoolExecutor which owns that implementation
also specialized makeFutureTry to take functions that return futures but treat them like they return the contained types, so fulfil() can be used liked then()
this specialization could just as easily be done on fulfil() itself if we wanted.
Test Plan: unit
Reviewed By: davejwatson@fb.com
Subscribers: hannesr, trunkagent, craffert, njormrod, fugalh, bmatheny
FB internal diff:
D1566369
James Sedgwick [Fri, 26 Sep 2014 15:48:09 +0000 (08:48 -0700)]
fix more flakey tests
Summary: fixed the one brought up in the task, and tweaked another that could theoretically cause problems
Test Plan: ran, though I have not been able to repro the
Reviewed By: njormrod@fb.com
Subscribers: fugalh, njormrod
FB internal diff:
D1575632
Tasks:
5225808
Simon Jenkins [Thu, 25 Sep 2014 21:25:47 +0000 (14:25 -0700)]
Set DEFAULT_CATCHUP_EVERY_N to 10 to get more accurate task expiration when busy event base
Summary:
when event base is busy we're timing out tasks too early.
BIG SCARY NOTE: I don't have the thrift knowledge to know if there's sideeffects of this, please let
me know if this change is harmful.
Test Plan:
tested internally
Reviewed By: davejwatson@fb.com
Subscribers: njormrod
FB internal diff:
D1578466
Tasks:
4752162
Dave Watson [Wed, 24 Sep 2014 18:28:48 +0000 (11:28 -0700)]
Fix SocketAddress AF_UNIX support
Summary: check external_ vs. AF_UNIX. Also fix reset() to reset storage_.addr
Test Plan: fbconfig folly/test:network_address_test; fbmake runtests
Reviewed By: soren@fb.com
Subscribers: tudorb, trunkagent, doug, njormrod
FB internal diff:
D1575098
Andrew Gallagher [Thu, 25 Sep 2014 01:36:16 +0000 (18:36 -0700)]
Add and fix BUCK files for folly
Summary:
This gets almost all of folly building with buck. There are a few
cases we don't support yet (custom test wrappers for spooky test
binaries, dlopen-enabled exception tracer binary, etc), but the
vast majority is covered.
Test Plan: built all build targets and ran all tests buck
Reviewed By: sdwilsh@fb.com
Subscribers: tjackson, sdwilsh, fugalh, njormrod
FB internal diff:
D1577256
Tasks:
5055879
Marc Horowitz [Fri, 5 Sep 2014 23:45:24 +0000 (16:45 -0700)]
expose the class_name in an efficient way
Summary:
Add a class_name method, which doesn't need to throw/catch
regardless how the exception is captured.
Test Plan: exception_wrapper_test
Reviewed By: mshneer@fb.com
Subscribers: njormrod
FB internal diff:
D1543596
Tasks:
5025089
Blame Revision:
Nicholas Ormrod [Thu, 25 Sep 2014 00:02:47 +0000 (17:02 -0700)]
Disable failing wangle test
Summary:
Under moderate load, this part of the test would fail. When
there is resource contention, it is quite possible that the timeout will
be exceeded. A further reduction of the time spread will render this
test next to useless.
Moderate load can be as little as running all of folly's tests at once,
which is something that our testing infrastructure does quite
frequently.
fbconfig -r folly
fbmake runtests
Test Plan:
fbconfig -r folly && fbmake runtests
Reviewed By: hannesr@fb.com
Subscribers: sdwilsh, fugalh, njormrod
FB internal diff:
D1576570
Tasks:
5225808
Soren Lassen [Wed, 24 Sep 2014 20:34:17 +0000 (13:34 -0700)]
Fix some folly memory leaks found with clang:dev + asan
Summary:
Reverts the revert of the small_vector and test parts of
D1569246.
I'm saving the SocketAddress fix for later, because it caused problems
and needs more research.
Test Plan:
unit tests with clang:dev/asan
Reviewed By: njormrod@fb.com
Subscribers: mathieubaudet, philipp, meyering, njormrod
FB internal diff:
D1575574
Blame Revision:
D1575190
Dave Watson [Wed, 24 Sep 2014 17:52:50 +0000 (10:52 -0700)]
update thrift to use managed connection
Summary:
Use the new managed connection code in folly. Cleans things up a fair bit
The only catch was the current ConnectionManager code uses raw pointers, thrift expects shared_ptr so the request object can keep the channel around until the requests are finished
Test Plan: fbconfig -r thrift/lib/cpp2; fbmake runtests
Reviewed By: afrind@fb.com
Subscribers: trunkagent, njormrod, doug, fugalh, alandau, bmatheny, dcsommer, afrind
FB internal diff:
D1519923
Tasks:
5002343
Danny Guo [Wed, 24 Sep 2014 18:48:36 +0000 (11:48 -0700)]
Revert "Fix folly memory leaks found with clang:dev + asan."
Summary: This reverts commit
2c726dcf86bb176fb3695739a3d8bca2f95c41e6.
Test Plan: build it
Reviewed By: soren@fb.com
Subscribers: woo, mathieubaudet, njormrod
FB internal diff:
D1575190
James Sedgwick [Wed, 24 Sep 2014 17:30:21 +0000 (10:30 -0700)]
de-flake tests
Summary: make these more serialized / event based so they don't get flakey under high load
Test Plan:
ran under load - caveat: i was not able to repro the flakiness @njormrod reported
but by inspection these should be fine
Reviewed By: njormrod@fb.com
Subscribers: fugalh, njormrod
FB internal diff:
D1574640
Tasks:
5225808
Soren Lassen [Tue, 23 Sep 2014 19:42:33 +0000 (12:42 -0700)]
Fix folly memory leaks found with clang:dev + asan.
Summary: I tried running folly/test with clang:dev and asan and found these leaks.
Test Plan:
unit tests with clang:dev/asan
Reviewed By: davejwatson@fb.com
Subscribers: davejwatson, trunkagent, mathieubaudet, njormrod, meyering, philipp
FB internal diff:
D1569246
James Sedgwick [Tue, 23 Sep 2014 18:17:03 +0000 (11:17 -0700)]
user-defined expirations
Summary:
Couple of notes:
1. is it a bummer not to have per-task callbacks of some kind? the interfaces set up here only tell you that some task expired, not which one expired. TM calls back with the Runnable object. is that useful?
2. std::chrono::* business is frustratingly verbose, but the safety/explicitness is nice. Not sure how I feel overall.
3. perhaps expirations should be given in microseconds even if we don't think we can accurately accomplish that
Test Plan: added unit
Reviewed By: hans@fb.com
Subscribers: fugalh, njormrod, bmatheny
FB internal diff:
D1563520
Pavlo Kushnir [Tue, 23 Sep 2014 18:10:55 +0000 (11:10 -0700)]
Fix fbthrift build
Summary: Mcrouter open source build is failing because Codel is missing in fbthrift.
Test Plan: visual
Reviewed By: davejwatson@fb.com
Subscribers: fugalh, njormrod
FB internal diff:
D1572122
Blame Revision:
D1566128
Dave Watson [Mon, 22 Sep 2014 22:18:51 +0000 (15:18 -0700)]
fix unittest
Summary: Looks like the test explicitly looks for InvalidAddressFamilyException. I don't think any users are depending on this particular error type either way, I just switched it to InvalidAddressFamilyException
Test Plan:
unit tests
Reviewed By: ldbrandy@fb.com
Subscribers: doug, njormrod
FB internal diff:
D1570363
Tasks:
5153819
James Sedgwick [Tue, 23 Sep 2014 13:12:18 +0000 (06:12 -0700)]
thread safety for Observable::observers_
Summary: this way we can subscribe to an observable and blast data through it simultaneously from different threads
Test Plan: not much... the one client of rx compiles
Reviewed By: davejwatson@fb.com
Subscribers: fugalh, njormrod, bmatheny
FB internal diff:
D1560647
James Sedgwick [Tue, 23 Sep 2014 13:08:00 +0000 (06:08 -0700)]
stats for ThreadPoolExecutor
Summary:
pool-wide stats via a call on the pool, and per-task stats (e.g. to be funneled into a histogram) via an rx subscription
rx needs a little work before this diff is safe - e.g. synchronization around the subscriber list, and perhaps exposing whether there are any subscribers so we can skip stat tracking if no one is listening
won't commit this without moving rx into folly/experimental of course
the idea is that timeout/expiration notifications can also go through the same subscription channel
haven't run the benchmarks yet and have to leave for the evening but tmrw i'll commit changes to the benchmark and get this stuff into windtunnel so i don't have to do so much manual output inspection on future diffs
Test Plan: added unit
Reviewed By: davejwatson@fb.com
Subscribers: fugalh, njormrod, bmatheny
FB internal diff:
D1558424
Tasks:
5002392,
5002425
James Sedgwick [Tue, 23 Sep 2014 12:48:08 +0000 (05:48 -0700)]
move rx to folly/experimental
Summary: As above. I want to use this for the thread pools and it probably belongs in folly long-term anywya (if we stick with it)
Test Plan: compiled the one user
Reviewed By: hans@fb.com
Subscribers: fugalh, mwa, jgehring, fuegen, njormrod
FB internal diff:
D1560578
James Sedgwick [Tue, 23 Sep 2014 12:46:37 +0000 (05:46 -0700)]
move Codel to wangle
Summary: under folly::wangle::
Test Plan: ran unit for experimental/wangle, thrift/lib/cpp/concurrency, and a user of FbThreadManager
Reviewed By: hans@fb.com
Subscribers: trunkagent, fbcode-common-diffs@, fugalh, alandau, bmatheny, everstore-dev@, njormrod
FB internal diff:
D1566128
Nicholas Ormrod [Mon, 22 Sep 2014 21:13:14 +0000 (14:13 -0700)]
Fix lint errors
Summary: Pass const StringPieces by value instead of reference.
Test Plan:
fbconfig -r folly && fbmake runtests
Reviewed By: robbert@fb.com
Subscribers: trunkagent, sdwilsh, njormrod
FB internal diff:
D1569488
Ranjeeth Dasineni [Wed, 20 Aug 2014 19:38:57 +0000 (12:38 -0700)]
rfc : -Wshorten-64-to-32 warnings in folly liger dependencies
Summary:
This is not a fix but me seeking advice here. The context here is that in liger (our common network
stack for mobile platforms), we saw bugs due to truncation and want to enable these warnings. To find those in our code,
I had to first resolve the folly ones. I just got around by making the truncation explicit so that I can get to real errors.
Ideally I would like owners to examine each case and fix the original/accept the explicit truncate if its intended. Let me
know what you think. The last (least preferred) is for us to keep this as a liger only change. We have a couple of ways to
do that but it would be nice to fix.
N.B : this covers only liger dependencies
Test Plan: errors resolved after these changes.
Reviewed By: njormrod@fb.com
Subscribers: trunkagent, doug, shilin, njormrod, seanc, pgriess
FB internal diff:
D1509355
Nathan Bronson [Mon, 22 Sep 2014 18:33:28 +0000 (11:33 -0700)]
fix leak in MPMCQueueTest's use of boost::intrusive_ptr
Summary:
MPMCQueueTest's intrusive reference count test implementation was
incorrect, so it simultaneously didn't test what it should and had a leak.
Test Plan: tests, plus new __thread to track lifetimes
Reviewed By: meyering@fb.com
Subscribers: njormrod, soren, meyering
FB internal diff:
D1569448
Nicholas Ormrod [Mon, 22 Sep 2014 18:27:18 +0000 (11:27 -0700)]
Fix lint errors
Summary: Lines exceeding 80 characters have been restructured.
Test Plan:
fbconfig -r folly && fbmake runtests
Reviewed By: robbert@fb.com
Subscribers: trunkagent, sdwilsh, fugalh, njormrod
FB internal diff:
D1568086
Nicholas Ormrod [Mon, 22 Sep 2014 18:20:47 +0000 (11:20 -0700)]
Increase wangle test timers
Summary:
When running all folly tests at once, as with
fbconfig -r folly && fbmake runtests
the wangle tests sometimes fail. Enough tests are running that the
1-millisecond timer is too small, and is sometimes missed. Bumping
it to 10 milliseconds.
Test Plan:
fbconfig -r folly && fbmake runtests
Reviewed By: hans@fb.com
Subscribers: sdwilsh, fugalh, njormrod
FB internal diff:
D1568124
Tasks:
5180879
Pavlo Kushnir [Sat, 20 Sep 2014 00:02:35 +0000 (17:02 -0700)]
Faster accessors for dynamic values
Summary:
Sometimes it is useful to have a fast accessor to a value stored in dynamic, without any type conversion. These still do the type check, but compiler has more room for optimization.
Test Plan: build folly, will add unit tests/benchmarks if this makes sense at all.
Reviewed By: njormrod@fb.com
Subscribers: jdelong, njormrod
FB internal diff:
D1564867
Guohui Wang [Fri, 29 Aug 2014 01:32:59 +0000 (18:32 -0700)]
add function to push data from another cursor
Summary:
Add a function to Writable to push data from another cursor. Data in the input
cursor could be in a buffer chain.
Added test in IOBufCurosTest.cpp to test the new function.
Test Plan: fbmake runtests;
Reviewed By: simpkins@fb.com
Subscribers: njormrod, net-systems@
FB internal diff:
D1563209
Tasks:
4886058
Blame Revision:
dcsommer [Fri, 19 Sep 2014 22:31:17 +0000 (15:31 -0700)]
Bump version to 9:0
Tudor Bosman [Fri, 19 Sep 2014 19:58:10 +0000 (12:58 -0700)]
Do not barf on invalid ELF files
Summary: The Haskell runtime does magic, and loads an ET_REL file directly.
Test Plan: ran it
Reviewed By: jon.coens@fb.com
Subscribers: njormrod, rkroll
FB internal diff:
D1566853
Tasks:
4401996
@override-unit-failures
Dave Watson [Fri, 12 Sep 2014 18:30:59 +0000 (11:30 -0700)]
move socketaddress to folly
Summary:
Goes with IPAddress and MACAddress already in folly.
* change namespace, add typedef in thrift. Had to update forward decls to folly namespace.
* change exception types to std:: types instead of TTransportException. I fbgs'd for everywhere I could find trying to catch these and updated the type, there looked like there were only ~9 files or so.
Test Plan: contbuild.
@override-unit-failures
Tests already passed in last run
Reviewed By: simpkins@fb.com
Subscribers: doug, ps, alandau, everstore-dev@, njormrod, fugalh, alikhtarov, bmatheny, jsedgwick
FB internal diff:
D1556916
James Sedgwick [Fri, 19 Sep 2014 10:19:17 +0000 (03:19 -0700)]
fix occasional crash in cpu pool
Summary: need to initialize threadsToStop_ and make it signed so it doesn't underflow in rare races
Test Plan: cpu pool unit tests no longer crash if run a ton of times
Reviewed By: davejwatson@fb.com
Subscribers: fugalh, njormrod
FB internal diff:
D1563524
Dave Watson [Thu, 18 Sep 2014 19:12:33 +0000 (12:12 -0700)]
install connectionmanager headers
Summary: Install headers / compile files
Test Plan: watch jenkins build
Reviewed By: dcsommer@fb.com
Subscribers: doug, fugalh, njormrod
FB internal diff:
D1564098
Dave Watson [Thu, 18 Sep 2014 16:45:05 +0000 (09:45 -0700)]
Bump version to 8:0
dungcoi [Thu, 18 Sep 2014 16:19:57 +0000 (09:19 -0700)]
merge https://github.com/facebook/folly/pull/88
Summary:
merge https://github.com/facebook/folly/pull/88, missing install header
Looks like fbthrift build needs this
Test Plan: watch jenkins build still works
Reviewed By: ckwalsh@fb.com
Subscribers: doug, njormrod
FB internal diff:
D1563651
Sean Cannella [Thu, 18 Sep 2014 14:20:04 +0000 (07:20 -0700)]
Remove dependency on std::to_string
Summary:
Mobile platform clang doesn't currently support std::to_string
so remove folly's dependency on it.
Test Plan: existing tests
Reviewed By: mpawlowski@fb.com
Subscribers: kmdent, fma, benyluo, shikong, ranjeeth, subodh, pgriess, njormrod
FB internal diff:
D1562179
Tasks:
5183325
Matt Dordal [Wed, 17 Sep 2014 23:52:03 +0000 (16:52 -0700)]
fix race in Future::waitWithSemaphore
Summary:
There's a race condition in waitWithSemaphore, specifically because we're
returning a new future that's completed by the input future. As a result,
that future may not be completed by the time waitWithSemaphore returns,
although completion should be imminent.
Test Plan:
`var=0; while true ; do echo $((var++)); _bin/folly/wangle/wangle-test --gtest_filter='Future*' || break ; done`
Before change two runs yielded 303 and 371.
After change I killed the test at 11000.
Reviewed By: njormrod@fb.com
Subscribers: fugalh, njormrod
FB internal diff:
D1561281
Tasks:
5180879
Nicholas Ormrod [Wed, 17 Sep 2014 20:21:40 +0000 (13:21 -0700)]
remove eof whitespace lines
Summary:
Remove lint errors from folly: trailing newlines
find folly | xargs arc lint | grep -B3 EOF | grep ">>>" | egrep -o "folly[^:]*" | xargs -n1 sed -i '$d'
folly/experimental/io/test/AsyncIOTest.cpp had two trailing newlines,
the second was removed by hand
@override-unit-failures
Test Plan:
fbconfig -r folly && fbmake runtests
Pretty overkill for a whitespace diff, but why not.
Reviewed By: robbert@fb.com
Subscribers: sdwilsh, fugalh, njormrod
FB internal diff:
D1561213
Dave Watson [Wed, 17 Sep 2014 18:23:54 +0000 (11:23 -0700)]
Bump version to 7:0
Dave Watson [Wed, 17 Sep 2014 17:20:31 +0000 (10:20 -0700)]
move connectionmanager/managed connection to wangle
Summary: Moar code sharing between proxygen/thrift. Code must be moved to a common library: The only one we currently have is folly, but if someone wants to argue for a separate lib, that's cool too
Test Plan: fbconfig -r proxygen; fbmake dev
Reviewed By: dcsommer@fb.com
Subscribers: doug, fugalh, bmatheny, njormrod
FB internal diff:
D1519919
Tasks:
5002343
James Sedgwick [Wed, 17 Sep 2014 09:58:06 +0000 (02:58 -0700)]
ThreadPoolExecutor and its children CPUThreadPoolExecutor and IOThreadPoolExecutor
Summary:
Spun off from https://phabricator.fb.com/
D1534506 as this seemed different enough for a new diff
Similar to previous diff but attempts to reuse a common thread management process between cpu and io bound thread pools. Also sets the stage for other common functionality, e.g. stats, monitoring, timeouts, and so on
Here is some output from the queue benchmark in common/concurrent with both of these pools added (changes to BM not in this diff): https://phabricator.fb.com/P16308560
Test Plan: added a unit test, ran benchmark
Reviewed By: davejwatson@fb.com
Subscribers: fugalh, njormrod, bmatheny
FB internal diff:
D1555443
Tasks:
5002392,
5002425
Sean Cannella [Wed, 17 Sep 2014 00:08:52 +0000 (17:08 -0700)]
Fix folly signed/unsigned comparisons
Summary:
Fix a few sign comparison issues in folly::IPAddress
@override-unit-failures
Test Plan: existing tests, compiled with clang
Reviewed By: meyering@fb.com, davejwatson@fb.com
Subscribers: njormrod, bmatheny, subodh, ranjeeth, pgriess
FB internal diff:
D1559152
Marc Horowitz [Thu, 11 Sep 2014 00:39:19 +0000 (17:39 -0700)]
make with_exception() const work in all cases
Summary:
Abstract the with_exception() logic into a static template
function which will work with a const or non-const object.
Test Plan: exception_wrapper_test
Reviewed By: vloh@fb.com
Subscribers: njormrod
FB internal diff:
D1549175
Tasks:
5127267
Shao-Chuan Wang [Tue, 16 Sep 2014 05:56:18 +0000 (22:56 -0700)]
Adding IO stats in AsyncIO.
Summary:
It would be great if we have IO stats tracking built within AsyncIO.
It would enable upper layer application to better track the number of I/O
that was submitted and completed
Test Plan:
$ fbmake runtests
Test Results Summary:
Passed: 1734
100% successful
Reviewed By: philipp@fb.com
Subscribers: njormrod, schen, stanislav
FB internal diff:
D1557472
Tasks:
5008299
Dave Watson [Mon, 15 Sep 2014 21:30:23 +0000 (14:30 -0700)]
Bump version to 6:0
Chip Turner [Fri, 12 Sep 2014 00:36:50 +0000 (17:36 -0700)]
Add non-strict mode to folly::Singleton
Summary:
It is difficult to guarantee every binary can call
registrationComplete; for now, support a mode where we don't enforce the
strict registration lifecycle. In the fullness of time, we can make
strictness the default.
Test Plan: runtests
Reviewed By: lins@fb.com
Subscribers: lins, anca, njormrod
FB internal diff:
D1551688
Victor Loh [Fri, 12 Sep 2014 22:03:39 +0000 (15:03 -0700)]
equality for exception_wrapper
Summary:
std::exception_ptr expose methods to compare equality and it
will be great to do so for folly::exception_wrapper (it helps in gmock
testing).
Test Plan: added some unit tests to test this new functionality
Reviewed By: mhorowitz@fb.com
Subscribers: njormrod
FB internal diff:
D1546597
Dave Watson [Wed, 3 Sep 2014 21:41:47 +0000 (14:41 -0700)]
Make TSocketAddress use folly::IPAddress
Summary:
Step 1 of moving TAsyncSocket and friends to folly.
folly::IPAddress changes (can split these off if requested):
* isLoopback looks for a single address, as opposed to subnet
* For V6, isPrivate & isLoopback don't seem to check mapped addresses
TSocketAddress changes:
* Make union use folly::IPAddress instead of sockaddr struct. external_ bool to tell if using AF_UNIX instead.
* manage the port and scope/zone info ourselves
@override-unit-failures
Overriding failures, can't get contbuild to finish all builds after several tries. None of the failures look related
Test Plan:
fbconfig -r thrift
fbmake runtests
fbconfig folly/test:network_address_test
fbmake runtests
Reviewed By: simpkins@fb.com
Subscribers: snaptu-diffs@, trunkagent, hphp-diffs@, njormrod, fbcode-common-diffs@, doug, ruibalp, ps, alandau, bmatheny
FB internal diff:
D1479365
Tasks:
3658665
Jim Meyering [Thu, 11 Sep 2014 22:23:17 +0000 (15:23 -0700)]
folly: avoid used-uninitialized bug in a test
Summary:
Clang complained about this.
* folly/gen/test/FileBenchmark.cpp (BENCHMARK): Initialize "rfd" to -1
and verify that it is set to something nonnegative in the first
BENCHMARK_SUSPEND block.
Test Plan:
Run this:
fbconfig -r --clang --with-project-version clang:dev folly/gen && fbmake runtests
and observe that compilation now succeeds. (and test results remain unchanged)
Reviewed By: tudorb@fb.com
Subscribers: njormrod
FB internal diff:
D1551180
Tasks:
4090011
Sara Golemon [Wed, 10 Sep 2014 23:59:58 +0000 (16:59 -0700)]
Bump version to 5:0
Daniel Sommermann [Wed, 10 Sep 2014 23:38:04 +0000 (16:38 -0700)]
Install EvictingCacheMap as part of OSS build
Summary: This may have just been forgotten when imported to folly
Test Plan: live. verified file name
Reviewed By: ranjeeth@fb.com
Subscribers: doug, njormrod
FB internal diff:
D1548804
Sara Golemon [Wed, 10 Sep 2014 18:35:44 +0000 (11:35 -0700)]
Fix folly compilation on MacOSX
Summary:
We don't always have features.h
and our glibc doesn't have __GLIBC_PREREQ()
@override-unit-failures
Test Plan: Builds on MacOSX
Reviewed By: pt@fb.com
Subscribers: njormrod
FB internal diff:
D1546679
Dave Watson [Tue, 9 Sep 2014 18:35:27 +0000 (11:35 -0700)]
Remove broken test
Summary: Broken on other platforms, because demangle(typeid()) seems to return different results? not entirely sure, but would like the builds to be green again
Test Plan: watch contbuild for 'fbthrift jenkins build' to pass
Reviewed By: mhorowitz@fb.com
Subscribers: doug, njormrod
FB internal diff:
D1544919
Blame Revision:
D1535681
Sara Golemon [Tue, 9 Sep 2014 21:22:35 +0000 (14:22 -0700)]
Bump version to 4:0
Dave Watson [Tue, 26 Aug 2014 17:24:34 +0000 (10:24 -0700)]
Move HHWheelTimer to folly
Summary:
Move wheel timer to folly. Needed for abstracting some code out of proxygen/thrift
The only code change was removing usage of thrift's Util::currentTime() in favor of std::chrono::steady_clock::now()
Test Plan: fbconfig thrift/lib/cpp/test:HHWheelTimerTest; fbmake runtests
Reviewed By: alandau@fb.com
Subscribers: doug, alandau, bmatheny, njormrod
FB internal diff:
D1519909
Jason Evans [Wed, 3 Sep 2014 23:08:22 +0000 (16:08 -0700)]
Convert from jemalloc's obsolete *allocm() to *allocx().
Summary:
Convert from jemalloc's obsolete *allocm() to *allocx().
Strengthen goodMallocSize() to always return a jemalloc size class, so
that xallocx() success/failure detection is simple.
@override-unit-failures
Test Plan: Folly, unicorn, and HHVM tests.
Reviewed By: andrei.alexandrescu@fb.com
Subscribers: trunkagent, hphp-diffs@, ps, chaoyc, search-fbcode-diffs@, unicorn-diffs@, ptc, njormrod
FB internal diff:
D1535841
Tasks:
4996808
Marc Horowitz [Thu, 4 Sep 2014 02:32:36 +0000 (19:32 -0700)]
fix exceptionStr to work for derived classes of std::exception
Summary:
templates and overloads are hard. This uses SFINAE to get
the desired behavior, and includes a test.
This also removes a hack in ExceptionWrapper which isn't needed with this fix.
Test Plan: string_test, exception_wrapper_test
Reviewed By: andrei.alexandrescu@fb.com
Subscribers: dreiss, dancol, njormrod
FB internal diff:
D1535681
Blame Revision:
D1517701
Pavlo Kushnir [Mon, 8 Sep 2014 17:32:04 +0000 (10:32 -0700)]
Fix bug in stripComments
Summary: the bug is in InString state when we escape only '"' character. We should escape at least '\\' and '"'. This diffs simply escapes any character after '\\'.
Test Plan: folly unit tests, mcrouter unit tests
Reviewed By: stepan@fb.com
Subscribers: njormrod
FB internal diff:
D1540836
Chip Turner [Wed, 3 Sep 2014 19:22:45 +0000 (12:22 -0700)]
Fix bug in circular singleton creation detection
Summary:
We considered it circular if we tried to create a singleton
while the singleton was being created. In a single threaded world, this
is correct, but under concurrency, two threads can be in the singleton
creation codepath and become confused about the state of the singleton.
This change uses a condition variable to notify when creation completes
so that other threads can wait on the creation to complete. Circular
creation is detected via thread id.
Test Plan:
runtests (new test case; failed without the fix, passes with
it)
Reviewed By: hans@fb.com
Subscribers: lins, anca, njormrod, rkroll
FB internal diff:
D1534081
Hannes Roth [Thu, 4 Sep 2014 16:17:56 +0000 (09:17 -0700)]
(Folly/Wangle) Later.then, Later.whenAllLater
Summary:
Adding some basic functionality to `Later` to make it easier to chain
things.
Test Plan:
Added tests.
`fbconfig -r folly/wangle && fbmake runtests_{dbg,dbgo,opt}`
`fbconfig --clang -r folly/wangle && fbmake runtests_{dbg,dbgo,opt}`
Reviewed By: hans@fb.com
Subscribers: fugalh, njormrod
FB internal diff:
D1527826
Tasks:
4993420
Matt Dordal [Wed, 3 Sep 2014 23:47:14 +0000 (16:47 -0700)]
Rename shadowing local variables in various stats objects
Summary:
The GCC shadow variable detector is quite zealous in warning about
shadowed members. Here, we have local variables that share the name
of member functions. Rename them so that -Wshadow doesn't complain.
Test Plan:
It didn't build, and now it does.
`fbconfig -r folly && fbmake runtests`
Reviewed By: njormrod@fb.com
Subscribers: fbcode-common-diffs@, njormrod
FB internal diff:
D1534033
Chip Turner [Wed, 30 Jul 2014 22:38:28 +0000 (15:38 -0700)]
Make using folly::Singleton easier: names and direct referencing
Summary:
There are times when you want multiple singletons of the same
underlying type -- for instance, a fast and slow request handling
singleton. This diff allows for that with an optional name that
disambiguates multiple singletons of the same type.
In addition, we now also allow direct dereferencing of the
Singleton<Foo> object to get to the underlying singleton. This is most
useful in cases where a singleton is used inside of the same cpp file it
is defined.
Finally, make get() faster by caching the underlying pointer rather than
accessing the shared pointer. If you're using it, you already have a
race condition and hopefully your singleton lifecycle is sane and safe
from problems this may cause.
Test Plan: runtests
Reviewed By: hans@fb.com
Subscribers: njormrod, lins, anca
FB internal diff:
D1485887
Philip Pronin [Thu, 28 Aug 2014 11:05:45 +0000 (04:05 -0700)]
use folly::Baton in waitWithSemaphore
Test Plan:
fbconfig -r folly/wangle && fbmake runtests -j32
Reviewed By: lucian@fb.com
Subscribers: sdoroshenko, fugalh, njormrod
FB internal diff:
D1525044
Tasks:
2680246
Blame Revision:
D1358230