James Sedgwick [Thu, 19 Oct 2017 14:45:51 +0000 (07:45 -0700)]
move ApplyTuple to functional/
Summary: as above
Reviewed By: yfeldblum
Differential Revision:
D6086563
fbshipit-source-id:
ab7f50ba46ebd1dbef6438f956258b2fbb13cb5c
Peter Alexander [Thu, 19 Oct 2017 09:46:56 +0000 (02:46 -0700)]
Add ProducerConsumerQueue::capacity()
Summary: Simple addition. Easy to track externally, but might as well provide it in the class if it is readily available.
Reviewed By: yfeldblum
Differential Revision:
D6093826
fbshipit-source-id:
9d8c02891b2cea9ce0d3f6ea78e1e0055b536eb8
Yedidya Feldblum [Thu, 19 Oct 2017 09:30:31 +0000 (02:30 -0700)]
Revert
D6050464: [Folly] Move folly/Hash.h to folly/hash/
Summary:
This reverts commit
64eb65aac8e3e7cd0126e65ca3998bfe167e2d73
bypass-lint
Differential Revision:
D6050464
fbshipit-source-id:
1ed63f30837dc11ae57b316f1f7cb233a210894a
Walker Mills [Thu, 19 Oct 2017 07:57:03 +0000 (00:57 -0700)]
Add window overload that takes an executor to prevent stack overflow
Summary:
AIUI, if there is no executor available, then callbacks are executed inline. `folly::window` uses a recursive helper function (`spawn`) to handle chaining callbacks. So if `window` is used on a large enough collection of `Future`s without executors (e.g., created by `makeFuture`, or have otherwise already completed), you get a stack overflow. A minimal repro looks like:
```
int main(int argc, char** argv) {
std::vector<int> v(100000);
for(int i=0; i < v.size(); i++) {
v[i] = i;
}
std::vector<folly::Future<folly::Unit>> f =
folly::window(
std::move(v),
[](int /* unused */) { return folly::makeFuture(); },
1);
folly::collectAll(f).get();
}
```
This diff resolves the issue by adding an overload of `folly::window` which takes an executor as its first parameter. The executor-less `window` overload calls through to the new function using an `InlineExecutor` as the default executor.
Reviewed By: yfeldblum
Differential Revision:
D6038733
fbshipit-source-id:
5dcab575592650efa2e106f12632ec06817a0009
Yedidya Feldblum [Thu, 19 Oct 2017 07:37:48 +0000 (00:37 -0700)]
Move folly/Hash.h to folly/hash/
Summary: [Folly] Move `folly/Hash.h` to `folly/hash/`.
Reviewed By: jsedgwick
Differential Revision:
D6050464
fbshipit-source-id:
64eb65aac8e3e7cd0126e65ca3998bfe167e2d73
Arkady Shapkin [Thu, 19 Oct 2017 02:35:00 +0000 (19:35 -0700)]
Enable bug workaround also for MSVC 2017.4
Summary:
Workaround a bug in template instantiation in MSVC 2017 U3/4 with /permissive-
https://developercommunity.visualstudio.com/content/problem/81223/incorrect-error-c5037-with-permissive.html
/cc Orvid
Closes https://github.com/facebook/folly/pull/691
Reviewed By: yfeldblum
Differential Revision:
D6085652
Pulled By: Orvid
fbshipit-source-id:
f068dc3f8e474163815fc497b05410fe76834a52
Boliu Xu [Thu, 19 Oct 2017 02:08:13 +0000 (19:08 -0700)]
Fix incorrect example usage in stop_watch
Summary: As titled.
Reviewed By: yfeldblum
Differential Revision:
D6087099
fbshipit-source-id:
1c346fa6f65b5ea58e728759905560ae5ad9cc9d
Richard Fillman [Thu, 19 Oct 2017 00:19:59 +0000 (17:19 -0700)]
Move small fields to avoid padding in AsyncSocket.h and AsyncSSLSocket.h
Summary: Compiled mcrouter with the 'Wpadded' flag to try to find any wasted space. Mcrouter itself did not have anything, but there was a lot in AsyncSocket.h and AsyncSSLSocket.h so looked into those and removed a bit of wasted space
Reviewed By: yfeldblum, brianwatling
Differential Revision:
D6033977
fbshipit-source-id:
2dc127208e09980be6a5db576b45d30ac6e044ff
James Sedgwick [Wed, 18 Oct 2017 23:32:35 +0000 (16:32 -0700)]
move futures/QueuedImmediateExecutor to executors/QueuedImmediateExecutor
Summary: as above
Reviewed By: yfeldblum
Differential Revision:
D6076779
fbshipit-source-id:
4c223ab9fce3be8544f6f807781c3d0a99b61dad
Andrew Krieger [Wed, 18 Oct 2017 22:44:01 +0000 (15:44 -0700)]
Workaround MSVC bug with referencing template constructors before definition
Summary:
MSVC has a bug where it is unable to match an out-of-line constructor (and
possibly other kind of member) to the definition if it is implicitly referenced
before the definition is processed. The guilty method is
SemiFuture<Unit> makeSemiFuture(). Moving it after the constructor definitions
resolves the issue.
Reviewed By: yfeldblum
Differential Revision:
D6042277
fbshipit-source-id:
97fe97c0edf3df3d9e3b808968b450c73959b600
James Sedgwick [Wed, 18 Oct 2017 22:01:33 +0000 (15:01 -0700)]
move futures/ScheduledExecutor to executors/ScheduledExecutor
Summary: see title
Reviewed By: yfeldblum
Differential Revision:
D6062601
fbshipit-source-id:
edd9a5e85f4ebecd1a6f1004a4d3b8b43b935c2b
Yedidya Feldblum [Wed, 18 Oct 2017 21:18:47 +0000 (14:18 -0700)]
Move folly/MallctlHelper.h to folly/memory/
Summary: [Folly] Move `folly/MallctlHelper.h` to `folly/memory/`.
Reviewed By: aary
Differential Revision:
D6087216
fbshipit-source-id:
4e0fa4aea976e2578127d3c340e0e9b559a224ca
James Sedgwick [Wed, 18 Oct 2017 18:49:02 +0000 (11:49 -0700)]
move Partial to functional/
Summary: as above
Reviewed By: ngoyal
Differential Revision:
D6087941
fbshipit-source-id:
948ff4f2faa87dd34f87d14ea01c83335f850a27
Christopher Dykes [Wed, 18 Oct 2017 16:49:45 +0000 (09:49 -0700)]
Use nullptr rather than 0 when initializing pointers
Summary:
Because we do this in a few places, and `nullptr` makes it far clearer what the intention is.
Note that with `-Wzero-as-null-pointer-constant` under GCC, doing `std::function<void()> f = {}` initializes `f` with a `0` rather than `nullptr`, triggering the warning, so I've enabled it there as well.
It is not currently possible to actually enable `-Wzero-as-null-pointer-constant`, because GCC 5 reports conversions resulting from a default value as occuring at the call-site rather than at the location where the parameter is defined, and the default allocator in libstdc++ is not clean for this particular warning -_-...
Reviewed By: yfeldblum
Differential Revision:
D6046746
fbshipit-source-id:
6135bb20a503c861838575cf973324d74d75ca69
James Sedgwick [Wed, 18 Oct 2017 16:44:09 +0000 (09:44 -0700)]
move futures/DrivableExecutor to executors/DrivableExecutor
Summary: as title
Reviewed By: yfeldblum
Differential Revision:
D6062437
fbshipit-source-id:
4f99e779e280fdb0b1f035013caff18764e86ab5
Yedidya Feldblum [Wed, 18 Oct 2017 06:36:06 +0000 (23:36 -0700)]
Lift the invoke helper in Function.h
Summary: [Folly] Lift the `invoke` helper in `Function.h`.
Reviewed By: aary
Differential Revision:
D6050569
fbshipit-source-id:
da07901b8d058b0199d23db675c0fb9082fdf67d
James Sedgwick [Wed, 18 Oct 2017 03:21:36 +0000 (20:21 -0700)]
move python/NotificationQueueExecutor to futures/
Summary: as above
Reviewed By: yfeldblum
Differential Revision:
D6076757
fbshipit-source-id:
afe144129e8a0242ba6baee96a84a9084e6e2571
Yedidya Feldblum [Wed, 18 Oct 2017 02:28:49 +0000 (19:28 -0700)]
Simplify impl of setThreadName
Summary: [Folly] Simplify impl of `setThreadName`.
Reviewed By: Orvid, ot
Differential Revision:
D6075179
fbshipit-source-id:
720f29cc688f97b936813898238b8eb26b8a6141
Dan Melnic [Tue, 17 Oct 2017 23:27:56 +0000 (16:27 -0700)]
Do not set WriteFlags::WRITE_MSG_ZEROCOPY if the buffer ! isManaged()
Summary: Do not set WriteFlags::WRITE_MSG_ZEROCOPY if the buffer isShared()
Reviewed By: yfeldblum
Differential Revision:
D6068711
fbshipit-source-id:
fff14dcd4fcb20c9dbb60794420845042518922c
Yedidya Feldblum [Tue, 17 Oct 2017 23:12:20 +0000 (16:12 -0700)]
Un-templatize Range::str
Summary: [Folly] Un-templatize `Range::str`.
Reviewed By: ot
Differential Revision:
D6075642
fbshipit-source-id:
08fc399c43750d34463de7634be4fe386b5db97c
Yedidya Feldblum [Tue, 17 Oct 2017 23:09:36 +0000 (16:09 -0700)]
Refactor ShutdownSocketSet atomic state machine
Summary:
[Folly] Refactor `ShutdownSocketSet` atomic state machine.
* Format.
* Use `while` over `goto`.
* Avoid `memory_order_acq_rel` as the single-argument memory order; some platforms fail to build that.
* Use `memory_order_relaxed` for all atomic operations because stronger memory orders are not actually required: the atomic state never serves as a barrier for synchronizing loads and stores of associated data because there is no associated data.
Reviewed By: davidtgoldblatt
Differential Revision:
D6058292
fbshipit-source-id:
d45d7fcfa472e6e393a5f980e75ad9ea3358bab3
Yedidya Feldblum [Tue, 17 Oct 2017 20:09:48 +0000 (13:09 -0700)]
An InlineExecutor singleton
Summary:
[Folly] An `InlineExecutor` singleton.
Using the Leaky Meyers Singleton pattern, so that it is always available whenever required.
Differential Revision:
D6074534
fbshipit-source-id:
bd4c9cd6a1e60c80de5d2eef1cb6a1e7f16b4e50
Andrew Krieger [Tue, 17 Oct 2017 16:17:30 +0000 (09:17 -0700)]
Don't make copies of std::string or fbstring when converting.
Summary:
This overload of estimateSpaceNeeded was taking a Src by
value, but Src is constrained by IsSomeString which only returns
true for std::string or fbstring, so this was inducing a copy
in any situation where folly::to<> is used with varargs which
contain fb/string arguments.
Reviewed By: yfeldblum
Differential Revision:
D6059517
fbshipit-source-id:
adc239f9049e161fc4b750bae0e3de5dbdcd1bfc
Yedidya Feldblum [Tue, 17 Oct 2017 03:10:35 +0000 (20:10 -0700)]
Make Range.h and FBString.h mutually independent
Summary:
[Folly] Make `Range.h` and `FBString.h` mutually independent.
This means that `Range` cannot directly know about `fbstring`, so any interactions between the two types must be indirected through templates.
Motivation: `FBString.h` is a relatively heaviweight `#include` for things that need `Range.h` but which do not use `fbstring`.
Reviewed By: ericniebler
Differential Revision:
D6062434
fbshipit-source-id:
e2f21c33f482eadffd0a8679eff4ece59bab53e9
Yedidya Feldblum [Tue, 17 Oct 2017 02:25:47 +0000 (19:25 -0700)]
Shrink integral hasher specialization implementations
Summary:
[Folly] Shrink integral `hasher` specialization implementations.
Instead of giving them bodies, just use inheritance.
Reviewed By: luciang
Differential Revision:
D6067757
fbshipit-source-id:
f71bd36132e1b66002493474825894b03754b34f
Chad Austin [Mon, 16 Oct 2017 23:22:25 +0000 (16:22 -0700)]
fix typo in invalid log level error message
Reviewed By: simpkins
Differential Revision:
D6068742
fbshipit-source-id:
a3b3b7fe4a6da8f250e5b9593f66b9f8a9345136
qiao hai-jun [Mon, 16 Oct 2017 18:18:55 +0000 (11:18 -0700)]
fix typo
Summary: Closes https://github.com/facebook/folly/pull/692
Differential Revision:
D6066294
Pulled By: yfeldblum
fbshipit-source-id:
a533527058b8b5bc71fb6f40bad31a50e8c3f585
Yedidya Feldblum [Mon, 16 Oct 2017 17:56:48 +0000 (10:56 -0700)]
4-way overloads for SemiFuture::value
Summary:
[Folly] 4-way overloads for `SemiFuture::value`.
Overload on the receiver reference category and `const`-qualification, deriving the return type reference category and `const`-qualification. Like `Optional`, `Try`, etc.
Differential Revision:
D6062006
fbshipit-source-id:
d7396cd4d4bb62e99445d5f61cb360898fa1c3f3
Ognjen Dragoljevic [Mon, 16 Oct 2017 14:24:15 +0000 (07:24 -0700)]
Fix hash overloads for integral types
Summary:
`folly/Hash.h:379:12: error: implicit instantiation of undefined template 'folly::hasher<unsigned long, void>'`
So, folly is unable to hash the very type it returns: `size_t`. Namely, folly has overloads for `uint32_t` and `uint64_t` which on my Mac map to `int` and `long long` respectively. `size_t` on the other hand maps to `long` which is neither.
Rather than overloading library types (which are just typedefs), we should overload all the built-in types: `char`, `short`, `int`, `long`, `long long`, `signed` and `unsigned` variants (with special treatment of `char`).
Reviewed By: yfeldblum, luciang
Differential Revision:
D6051600
fbshipit-source-id:
d59569dab963cbe0329aa589ff321cfb22308193
Andrew Krieger [Mon, 16 Oct 2017 04:30:56 +0000 (21:30 -0700)]
constexpr estimateSpaceNeeded for string literals.
Summary:
Partially inspired by WillerZ's investigation into faster compiling
StringPiece work, I thought this would be an easy drop in that short
circuits some compilation logic (or possibly is strictly better, since the
StringPiece conversion method isn't constexpr).
Reviewed By: yfeldblum
Differential Revision:
D6059537
fbshipit-source-id:
072f56e58aa47db10b54825cac8a05dc035b295c
Marc Celani [Sun, 15 Oct 2017 21:24:44 +0000 (14:24 -0700)]
Move retrying method to separate header in folly/futures
Summary: folly/futures depends on folly/Random.h, which in turn depends on <random>, which is a fairly large header. Most users of folly::futures do not use retrying, so separate it into a separate header.
Reviewed By: yfeldblum
Differential Revision:
D6028468
fbshipit-source-id:
d8155fe2ddff1a65c265a18f040ee6f1be3f3f0a
Yedidya Feldblum [Fri, 13 Oct 2017 23:14:37 +0000 (16:14 -0700)]
Style fixes for folly/experimental/gdb/README.md
Summary:
[Folly] Style fixes for `folly/experimental/gdb/README.md`.
Should have no effect on Github rendering, but should affect PHabricator rendering.
Reviewed By: Orvid, kennyyu
Differential Revision:
D6055017
fbshipit-source-id:
54204a2b77beeb884cdc486207809f78ac80afe2
Neel Goyal [Fri, 13 Oct 2017 19:22:08 +0000 (12:22 -0700)]
Add AsyncSocketException.cpp to build sources
Summary: Add AsyncSocketException.cpp to the list of files to build in Makefile.am
Reviewed By: knekritz
Differential Revision:
D6051989
fbshipit-source-id:
72083a609fc994770eca078bfef5a0ed04322bfc
Vitaly Berov [Fri, 13 Oct 2017 16:30:02 +0000 (09:30 -0700)]
Replace ShutdownSocketSet to singleton
Summary:
We recently found out that ShutdownSocketSet consumes 150+MB for our service, which uses duplex channels. The problem is that we create ~1000 of ThriftServers, and each of the creates its own ShutdownSocketSet.
In reality, ShutdownSocketSet is only needed to kill all socket's FD in emergency before crash dump is taken, so they don't hand around waiting for crash dump to complete. There is no need to keep a SSS per ThriftServer, singleton should work just fine.
There is a problem here, though. Currently a ThriftServer has 'immediateShutdown' method, which kills all sockets from SSS. So, if SSS becomes a singleton, and we have more than one ThriftServer, calling 'immediateShutdown' on one will kill sockets from the other one. First, it's a quite surprising behavior, and second, it complicates unit tests, which emulate thrift servers running in different processes.
As a result,
1. ShutdownSocketSet is created as a singleton, but each ThriftServer still keeps weak ptr to it (mostly for unit tests support).
2. replaceShutdownSocketSet method is added to ThriftServer.h, so unit tests could set different SSS for different ThriftServers.
3. method immediateShutdown is removed from ThriftServer, because its behavior would be 'surprising'.
There still may be unexpected consequences of this change for the tests because of Singleton, but let's see.
Reviewed By: yfeldblum
Differential Revision:
D6015576
fbshipit-source-id:
dab70dbf82d01bcc71bbe063f983e862911ceb24
Lucian Grijincu [Fri, 13 Oct 2017 08:58:11 +0000 (01:58 -0700)]
folly: AsyncSocketException: move implementation to .cpp, refactor
Reviewed By: yfeldblum
Differential Revision:
D6042832
fbshipit-source-id:
c716ee672c4acfa39cab9f10f3b3f88ca770cd20
Yedidya Feldblum [Fri, 13 Oct 2017 04:21:17 +0000 (21:21 -0700)]
Move folly/Checksum.h into folly/hash/
Summary: [Folly] Move `folly/Checksum.h` into `folly/hash/`.
Reviewed By: Orvid
Differential Revision:
D6045825
fbshipit-source-id:
02d3e6a49e2c0fc115cfee09e1186be7a13525ba
Miroslav Crnic [Wed, 11 Oct 2017 08:43:41 +0000 (01:43 -0700)]
Add support for clang intrinsic constexpr
Summary: Newer versions of clang >=3.4 support intrinsic constexpr
Reviewed By: Orvid
Differential Revision:
D6008856
fbshipit-source-id:
4e40a7032464216d181d76a854cafb2ab4be1be0
Cameron Pickett [Tue, 10 Oct 2017 09:39:20 +0000 (02:39 -0700)]
Handle nullptr from getTimekeeperSingleton
Summary:
According to folly::Singleton::try_get(), https://fburl.com/23wqby9i, the caller is responsible for handling a nullptr return. In this case, we handle it poorly, via a crash both in production and debug code.
This diff opts for handling the nullptr more gracefully, via a future loaded with an exception.
Reviewed By: yfeldblum
Differential Revision:
D6006864
fbshipit-source-id:
e8fde57ed161b33fa1f157ce663ed85e69640c25
Dan Melnic [Mon, 9 Oct 2017 01:27:54 +0000 (18:27 -0700)]
Add SO_ZEROCOPY support
Summary: Add SO_ZEROCOPY support
Reviewed By: djwatson
Differential Revision:
D5851637
fbshipit-source-id:
5378b7e44ce9d888ae08527506218998974d4309
Yedidya Feldblum [Sat, 7 Oct 2017 01:04:56 +0000 (18:04 -0700)]
Let EventBase::runInEventBaseThreadAndWait consume its argument
Summary:
[Folly] Let `EventBase::runInEventBaseThreadAndWait` consume its argument.
Likewise `EventBase::runImmediatelyOrRunInEventBaseThreadAndWait`.
And enforce that the function is destructed before returning, so that, in the case of a wrapped lambda, all captured objects' destructors run before returning from the function.
Reviewed By: elsteveogrande
Differential Revision:
D5994106
fbshipit-source-id:
816c9431a85a3d41e4fda321065614f4c18f0697
Stiopa Koltsov [Fri, 6 Oct 2017 20:07:02 +0000 (13:07 -0700)]
future.then() is identical to future.unit()
Summary:
Document that `future.then()` is identical to `future.unit()`.
Put functions next to each other to make it clear, and use identical
wording.
Reviewed By: yfeldblum
Differential Revision:
D5955451
fbshipit-source-id:
1b55d5785dc0995d4d9364f48241e98ad01b31f4
Yedidya Feldblum [Fri, 6 Oct 2017 18:45:18 +0000 (11:45 -0700)]
Remove Executor::addPtr
Summary:
[Folly] Remove `Executor::addPtr`.
It was there to support passing non-copyable callable objects wrapped as `std::shared_ptr`. It is no longer useful since we have `Function`, which is a non-copyable version of `std::function` which can support capturing non-copyable objects, and it is generally unused.
Reviewed By: spacedentist
Differential Revision:
D5983801
fbshipit-source-id:
b49a86f8dd7e5250a097b0e714a1bdf9ac362916
Jun Qu [Fri, 6 Oct 2017 16:54:59 +0000 (09:54 -0700)]
Workaround for a gcc crash
Summary: I recently got a gcc crash when using `ConcurrentHashMap`
Reviewed By: djwatson
Differential Revision:
D5994587
fbshipit-source-id:
412d48aa6da12c428bb9ab5ed7a317d89c9580b9
Valeriy Khromov [Fri, 6 Oct 2017 11:38:06 +0000 (04:38 -0700)]
add static makeFromPath to construct SocketAddress from a unix domain socket path
Summary:
Add `SocketAddress::makeFromPath(StringPiece)` static member function to
constructor `SocketAddress` from a path to Unix domain socket.
Reviewed By: yfeldblum
Differential Revision:
D5974523
fbshipit-source-id:
b5c1537e67d07d1ef401fea75e35753392eeaf6b
Yedidya Feldblum [Fri, 6 Oct 2017 00:02:00 +0000 (17:02 -0700)]
Use fewer keep-alives in VirtualEventBase::keepAliveRelease
Summary:
[Folly] Use fewer keep-alives in `VirtualEventBase::keepAliveRelease`.
{
D5982132} mistakenly used `VirtualEventBase::add`, which holds a keep-alive on the master `EventBase`, instead of calling `EventBase::add` directly.
(Note: this ignores all push blocking failures!)
Reviewed By: andriigrynenko
Differential Revision:
D5992403
fbshipit-source-id:
f427025c06f01e6a93d6eae8a051c3553f58be20
Yedidya Feldblum [Thu, 5 Oct 2017 22:52:28 +0000 (15:52 -0700)]
Make keepAliveRelease consistent between EventBase and VirtualEventBase
Summary: [Folly] Make `keepAliveRelease` consistent between `EventBase` and `VirtualEventBase`.
Reviewed By: elsteveogrande
Differential Revision:
D5982132
fbshipit-source-id:
536d48e5672567e78786691bfb283c34d1f31960
Yedidya Feldblum [Thu, 5 Oct 2017 22:40:50 +0000 (15:40 -0700)]
Move GlobalThreadPoolList.h into folly/concurrency/
Summary:
[Folly] Move `GlobalThreadPoolList.h` into `folly/concurrency/`.
This seems like a better place than the top-level. It seems reasonable because this has *something* to do with concurrency. This is used by executors, but is not itself an executor, so it was not clear that it should go to `folly/executors/`, although that also seems like quite the reasonable choice.
Reviewed By: Orvid
Differential Revision:
D5985142
fbshipit-source-id:
6117d133757af74023d6cffb838741da83d173bd
Andre Pinto [Thu, 5 Oct 2017 15:34:49 +0000 (08:34 -0700)]
Add an overload to use backlashify with StringPiece
Summary: Allows calling backlashify on a StringPiece.
Reviewed By: yfeldblum
Differential Revision:
D5930015
fbshipit-source-id:
ca14c78d9a90c45781da7229eb5d2f437792b2d1
Lee Howes [Thu, 5 Oct 2017 02:59:14 +0000 (19:59 -0700)]
Add SemiFuture class.
Summary:
Offer a clean separation between future as a vocabulary type for crossing
library interfaces, and future as a type to manage continuations.
The principle is that if we want an API with clean separation of execution it
should both return and receive SemiFutures. The returned SemiFuture would
only be awaitable, but not continuable. If the caller wants to enqueue a
continuation then it is efficiently convertable into a folly::Future by
calling .via.
This means that an API a) Does not have to take an executor to ensure it
returns a valid future. That can be deferred to the caller or the caller's
caller/target for true separation. b) The API can ensure that its own executor
is not exposed to the caller, while still having a clean API.
Obviously if some API wants to allow returning of a continuable future, then it
can also provide an executor-taking API.
Reviewed By: yfeldblum
Differential Revision:
D5769284
fbshipit-source-id:
46241d1274bf7b1698a7d28a47cff2a65a983740
Eric Niebler [Wed, 4 Oct 2017 21:56:25 +0000 (14:56 -0700)]
give folly future's exceptions default visibility
Summary: Exception types should have default visibility, otherwise RTTI doesn't work right.
Reviewed By: elsteveogrande
Differential Revision:
D5976415
fbshipit-source-id:
45dcfe3476b513aa49a6f78352318f31d381ada7
Yedidya Feldblum [Wed, 4 Oct 2017 18:56:32 +0000 (11:56 -0700)]
Move keepalive-acquire code into Executor::keepAliveAcquire overrides
Summary:
[Folly] Move keepalive-acquire code into `Executor::keepAliveAcquire` overrides.
This makes the API more symmetric and allows for more flexibility. Also serves as preparation for generalizing the keepalive-token interface.
Reviewed By: andriigrynenko
Differential Revision:
D5974080
fbshipit-source-id:
26209e49a0f5834ba229d4bbfc9272c2e4ffb3fd
Tom Jackson [Wed, 4 Oct 2017 17:31:05 +0000 (10:31 -0700)]
Benchmark comparison
Summary:
I couldn't find anything that consumes `--json` output, so I made this. It prints out benchmark results from two runs, comparing each benchmark to its corresponding baseline. This should help with benchmarking changes across revisions.
Along the way:
- Two small transparent `struct`s replaces the use of `tuple`s everywhere.
- New output JSON format (additive), formatted as array of arrays so order is preserved.
- New comparison binary in `folly/tools/benchmark_compare`
Sample output:
{P58307694}
Reviewed By: yfeldblum
Differential Revision:
D5908017
fbshipit-source-id:
d7411e22b459db16bd897f656e48ea4e896cb1bf
Yedidya Feldblum [Wed, 4 Oct 2017 06:50:27 +0000 (23:50 -0700)]
Let keep-alive tokens from VirtualEventBase be destroyed from any thread
Summary:
[Folly] Let keep-alive tokens from `VirtualEventBase` be destroyed from any thread.
This case was missed in {
D5951397} (facebook/folly@
6f3b7616f3402355441c62ca60a36159435aa818).
Reviewed By: andriigrynenko
Differential Revision:
D5970670
fbshipit-source-id:
19e2b00134516e68113234acd6111e21c3e23e8d
Maged Michael [Tue, 3 Oct 2017 19:19:29 +0000 (12:19 -0700)]
Dynamic MPMCQueue: Backout of last change as it may deadlock
Summary: The previous change can lead to deadlock. Backing out.
Reviewed By: djwatson
Differential Revision:
D5957084
fbshipit-source-id:
72ea1cb6236367912b4b087da7e4d57f8a2daed0
Maged Michael [Tue, 3 Oct 2017 14:56:57 +0000 (07:56 -0700)]
Fixes: prevent compiler reporting UB, hazptr_array move operator, empty array test
Summary:
Three fixes:
(1) The compiler reports UB in line 432 for the case M > HAZPTR_TC_SIZE even though it is executed only if M <= HAZPTR_TC_SIZE. Added a condition M <= HAZPTR_TC_SIZE to help the compiler determine that line 432 is not executed in that case.
(2) Added missing management of empty state in hazptr_array move operator
(3) Added nullptr argument to empty hazptr_array in Array test
Reviewed By: djwatson
Differential Revision:
D5951283
fbshipit-source-id:
cb8e61421ab06c7733f67bf2d2274d3311260ac4
Yedidya Feldblum [Tue, 3 Oct 2017 02:45:55 +0000 (19:45 -0700)]
Let keep-alive tokens be destroyed from any thread
Summary: [Folly] Let keep-alive tokens be destroyed from any thread.
Reviewed By: andriigrynenko
Differential Revision:
D5951397
fbshipit-source-id:
91e72588de4ef33a730ebef5770e77635d4e93ba
Igor Sugak [Mon, 2 Oct 2017 20:42:09 +0000 (13:42 -0700)]
fix -Wvexing-parse
Summary:
```lang=cpp
folly/test/stl_tests/StlVectorTest.cpp:1975:11: error: parentheses were disambiguated as redundant parentheses around declaration of variable named 'm' [-Werror,-Wvexing-parse]
Vector(m);
^~~
folly/test/stl_tests/StlVectorTest.cpp:1975:11: note: add a variable name to declare a 'Vector' initialized with 'm'
Vector(m);
^
varname
folly/test/stl_tests/StlVectorTest.cpp:1975:5: note: add enclosing parentheses to perform a function-style cast
Vector(m);
^
( )
folly/test/stl_tests/StlVectorTest.cpp:1975:11: note: remove parentheses to silence this warning
Vector(m);
^ ~
1 error generated.
```
Reviewed By: Gownta
Differential Revision:
D5955613
fbshipit-source-id:
3015570ce111603b3561914d07b55365a221c686
Yedidya Feldblum [Mon, 2 Oct 2017 05:11:27 +0000 (22:11 -0700)]
Move Merge.h into folly/algorithm/
Summary: [Folly] Move `Merge.h` into `folly/algorithm/`.
Reviewed By: Orvid
Differential Revision:
D5951346
fbshipit-source-id:
487203e55e2a44888e599ca22849798154e5b386
Maged Michael [Sun, 1 Oct 2017 01:11:41 +0000 (18:11 -0700)]
Optimize local and bulk management of hazptr_holder-s
Summary:
Changes:
- Added hazptr_local<M> for optimized management of local hazptr_holder-s.
- Added hazptr_array<M> for optimized management of hazptr_holder-s
- Added benchmarks for hazptr_local and hazptr_array
- Added tests for hazptr_local and hazptr_array
- Changed SWMRList example to use hazptr_local<2> instead of two hazptr_holder-s.
- Updated benchmark performance results.
Reviewed By: davidtgoldblatt
Differential Revision:
D5833721
fbshipit-source-id:
154811f67c38abac7342cecb71f829778ccf76b2
Felix Handte [Fri, 29 Sep 2017 19:41:24 +0000 (12:41 -0700)]
Short-Circuit within() When Future Is Already Complete
Summary:
As title. No sense adding a timeout to the timeout manager when the future is
already complete.
Reviewed By: yfeldblum
Differential Revision:
D5933144
fbshipit-source-id:
4d1bbd866c47ccee6bd0518cbe063afc1d34cbca
Igor Sugak [Fri, 29 Sep 2017 06:35:24 +0000 (23:35 -0700)]
delete deprecated SSLContext::setSSLLockTypes
Summary: This is deprecated and not used.
Reviewed By: yfeldblum
Differential Revision:
D5936286
fbshipit-source-id:
68f757be06ebe375e14db008d0e5828fad0c3aa5
Kyle Nekritz [Wed, 27 Sep 2017 20:11:31 +0000 (13:11 -0700)]
Add AsyncSocketExceptionType for early data rejection.
Summary: To be used to signal that data that was sent as TLS 1.3 early data was lost. This needs its own exception type as it requires special handling (ie it should usually be retried immediately).
Reviewed By: siyengar
Differential Revision:
D5869914
fbshipit-source-id:
ca0d8ef19cb991e9d6ffe0f8c99abfb03b748ce6
Mohamed Amin JABRI [Wed, 27 Sep 2017 17:38:18 +0000 (10:38 -0700)]
Fix unittest compile error on futures/test/RetryingTest.cpp.
Summary:
On MacOS compiling unittests with "make chek" shows the following compile
error:
```
../futures/test/RetryingTest.cpp:168:26: error: no matching function for call to 'min'
newMemLimit.rlim_cur = std::min(1UL << 30, oldMemLimit.rlim_max);
```
Closes https://github.com/facebook/folly/pull/680
Reviewed By: elsteveogrande
Differential Revision:
D5921433
Pulled By: yfeldblum
fbshipit-source-id:
236d8336f852750a983c2e268db8811d1a4ed9ee
Michael Lee [Tue, 26 Sep 2017 15:35:09 +0000 (08:35 -0700)]
Delete conversion from Objective-C block to folly::Function
Summary: Objective-C blocks are stack allocated, and unless there is a proper assignment it isn't retained and the memory is freed. Because folly::Function used to move, it would hold a reference, but after switch to a constructor by-value, it no longer does this and we see a use-after-free.
Reviewed By: yfeldblum, ericniebler
Differential Revision:
D5888606
fbshipit-source-id:
fe4cabb2f2ae289cce0e7429e0af3935ba314720
Yedidya Feldblum [Sun, 24 Sep 2017 06:12:57 +0000 (23:12 -0700)]
Let ProcessReturnCode be publicly constructible
Summary:
[Folly] Let `ProcessReturnCode` be publicly constructible.
Via provided constructor functions, which limit how it may be constructed so that it is only constructible into a valid state.
Differential Revision:
D5898739
fbshipit-source-id:
7490018adfc39408b4290248ef1220e8fd0238cb
Yedidya Feldblum [Sat, 23 Sep 2017 04:19:34 +0000 (21:19 -0700)]
Avoid tautological compare in folly/experimental/symbolizer/
Summary:
[Folly] Avoid tautological compare in `folly/experimental/symbolizer/`.
`x < 0` when `x` is unsigned is tautological and there are warnings against such comparisons. The underlying type of an unscoped enumerations without a fixed underlying type is not specified, and whether it is signed is also not specified; it could be unsigned, and is unsigned in practice in common cases.
Reviewed By: Orvid, eduardo-elizondo
Differential Revision:
D5897792
fbshipit-source-id:
24d84f9bf2c61c907585e1b675c2bbf11ef1720b
Matthew Tolton [Sat, 23 Sep 2017 00:32:21 +0000 (17:32 -0700)]
Fix deadlock in TimedMutex
Summary:
If a lock is stolen from fiber f1, and then fiber f2 is notified before f1 one
wakes up and discovers the crime, then f1 will clear notifiedFiber_ so that f2
thinks the lock was stolen from it as well and hence recurses back into lock().
Reviewed By: andriigrynenko
Differential Revision:
D5896323
fbshipit-source-id:
528ec1ed983175d3e08f3dc07b69bbc783a86cfb
Nathan Bronson [Fri, 22 Sep 2017 19:01:30 +0000 (12:01 -0700)]
fix ASAN stl_tests:stl_vector_test
Summary:
folly/test/stl_tests/StlVectorTest.cpp was too slow under
mode/dev-asan, resulting in timeouts, and the relinquish test allocated
with malloc and freed with operator delete. This diff reduces the vector
size for testing under ASAN, and fixes the allocation mismatch.
Reviewed By: Orvid
Differential Revision:
D5890969
fbshipit-source-id:
49a9498f6c0c4b3c7165906efd1262e518fea810
Kyle Nekritz [Thu, 21 Sep 2017 20:28:03 +0000 (13:28 -0700)]
Use unique_ptr rather than shared_ptr in MockReadCallback.
Summary: This is more convenient to use (for example with an IOBufEqual matcher).
Reviewed By: yfeldblum
Differential Revision:
D5882029
fbshipit-source-id:
6aa12f80479f40bcc2af64dc270fb0a9382983b5
Kenny Yu [Wed, 20 Sep 2017 03:31:08 +0000 (20:31 -0700)]
Add gdb deadlock detector script to new folly/experimental/gdb directory
Summary:
This adds a gdb deadlock detector script into a new directory in folly. I
chose to put it under the `experimental` directory and not the top-level
directory as we have only tested these scripts on x86_64 Linux and not other
types of platforms.
This diff includes:
- a README on the contents of this directory and how to use the scripts
- a script to detect deadlocks
gdb directory
---------------
This new directory will contain a collection of gdb scripts that we have
found helpful. These scripts use the [gdb extension Python API](https://sourceware.org/gdb/current/onlinedocs/gdb/Python.html#Python).
To run the scripts, fire up gdb and load a script with `source -v`. Example:
```
$ gdb -p 123456
(gdb) source -v ./folly/experimental/gdb/deadlock.py
Type "deadlock" to detect deadlocks.
(gdb) deadlock
Found deadlock!
...
```
deadlock detector script
----------------------------
Consider the following program that always deadlocks:
```
void deadlock3() {
std::mutex m1, m2, m3;
folly::Baton<> b1, b2, b3;
auto t1 = std::thread([&m1, &m2, &b1, &b2] {
std::lock_guard<std::mutex> g1(m1);
b1.post();
b2.wait();
std::lock_guard<std::mutex> g2(m2);
});
auto t2 = std::thread([&m3, &m2, &b3, &b2] {
std::lock_guard<std::mutex> g2(m2);
b2.post();
b3.wait();
std::lock_guard<std::mutex> g3(m3);
});
auto t3 = std::thread([&m3, &m1, &b3, &b1] {
std::lock_guard<std::mutex> g3(m3);
b3.post();
b1.wait();
std::lock_guard<std::mutex> g1(m1);
});
t1.join();
t2.join();
t3.join();
}
```
Once the process has deadlocked, we can use gdb to find the threads and mutexes involved in the deadlock:
```
$ gdb -p
2174496
(gdb) source -v ./folly/experimental/gdb/deadlock.py
Type "deadlock" to detect deadlocks.
(gdb) deadlock
Found deadlock!
Thread 2 (LWP
2174497) is waiting on mutex (0x00007ffcff42a4c0) held by Thread 3 (LWP
2174498)
Thread 3 (LWP
2174498) is waiting on mutex (0x00007ffcff42a4f0) held by Thread 4 (LWP
2174499)
Thread 4 (LWP
2174499) is waiting on mutex (0x00007ffcff42a490) held by Thread 2 (LWP
2174497)
```
Reviewed By: yfeldblum
Differential Revision:
D5860868
fbshipit-source-id:
020a32327a79bb066269fe08113695803ce06c7d
Phil Willoughby [Tue, 19 Sep 2017 20:57:36 +0000 (13:57 -0700)]
Benchmark a realistic common use
Summary:
We didn't previously benchmark the performance of `get()`, which was a strange
omission.
Reviewed By: akrieger
Differential Revision:
D5863567
fbshipit-source-id:
468b249da9120fcb84f3303ac5e2157761b6369d
Christopher Dykes [Tue, 19 Sep 2017 05:54:48 +0000 (22:54 -0700)]
Enable -Wunused-variables
Summary:
Only for clang for the moment, as more work is needed for GCC.
MSVC builds have always had unused variable warnings enabled, I just hadn't gotten around to cleaning up all of the tests for it to be able to enable it.
Reviewed By: yfeldblum
Differential Revision:
D5827840
fbshipit-source-id:
ab503b5791fcc58d685b8327179b810880c5dea7
Christopher Dykes [Tue, 19 Sep 2017 02:03:12 +0000 (19:03 -0700)]
Fix hardware crc32 under MSVC
Summary: It was horribly broken in multiple ways. It didn't support input > 4gb on Windows, was truncating the entire table to chars, and simply couldn't be compiled because it was exceeding MSVC's max macro instantion depth of 255.
Reviewed By: yfeldblum
Differential Revision:
D5827332
fbshipit-source-id:
b08268c88db10c607b27231689b3ee3ec7553c1f
Christopher Dykes [Tue, 19 Sep 2017 02:02:08 +0000 (19:02 -0700)]
Set names in NamedThreadFactory in the new thread
Summary: This makes it now both work, and compile, on Windows.
Reviewed By: yfeldblum
Differential Revision:
D5811100
fbshipit-source-id:
5d6bfc04ed8e60417615da15bd197769e0c79c11
Eric Niebler [Mon, 18 Sep 2017 22:21:34 +0000 (15:21 -0700)]
fix strange recursive std::is_constructible instantiation involving the Function converting constructor
Summary: In rare and obscure cases, the fact that `folly::Function`'s perfectly-forwarding, implicit converting constructor was SFINAE-ing on the argument's constructibility was causing a recursive template instantiation of std::is_constructible. Switch to passing the argument by value to avoid the need to test for constructibility.
Reviewed By: yfeldblum
Differential Revision:
D5847034
fbshipit-source-id:
ce2ad1d2490206c6cae84c17544bd9fcd6ff47bb
Eric Niebler [Fri, 15 Sep 2017 21:21:45 +0000 (14:21 -0700)]
Fix coroutine feature test macro on MSVC
Summary: Coroutines are only available on MSVC when the /await compiler switch was passed, in which case the `_RESUMABLE_FUNCTIONS_SUPPORTED` macro is defined.
Reviewed By: Orvid
Differential Revision:
D5837303
fbshipit-source-id:
af3349646e8875e3eac1bc3bbf47203f41f0bbde
Dylan Yudaken [Fri, 15 Sep 2017 17:13:16 +0000 (10:13 -0700)]
Allow awaiting on a folly::Optional that returns a move-only type
Summary:
await_resume is only called once, so this allows it to move the value out.
At the same time remove a redundant clear (but keep the existing requirement that the promise type is an OptionalPromise), and clean up the tests.
Also add a test to make sure the coroutine is cleaned up
Reviewed By: ericniebler
Differential Revision:
D5834861
fbshipit-source-id:
7ad487e818969cdf6fe27c9e82931aa247daf4e4
Stella Lau [Fri, 15 Sep 2017 17:13:08 +0000 (10:13 -0700)]
Allow getAutoUncompressionCodec() to have 1 terminal decoder
Summary: getAutoUncompressionCodec() currently only allows unambiguous headers. Allow a single "terminal codec" to be called if all other codecs can't uncompress or throw.
Reviewed By: terrelln
Differential Revision:
D5804833
fbshipit-source-id:
057cb6e13a48fea20508d5c028234afddf7435f6
Pádraig Brady [Fri, 15 Sep 2017 07:56:25 +0000 (00:56 -0700)]
fix usingJEMalloc() with LTO
Summary:
LTO has better optimization which results in the malloc() being optimized away in this function.
Note we don't use folly::dontOptimizeAway() because
that introduces a circular dependency between the
malloc and benchmark targets.
Reviewed By: marksantaniello, meyering, interwq
Differential Revision:
D5840883
fbshipit-source-id:
5dd9b152f70b7a49f125b6d79b4dfa40f4cdac59
Martin Martin [Thu, 14 Sep 2017 20:04:20 +0000 (13:04 -0700)]
NoHeap small_vector's no longer require a move constructor.
Summary:
NoHeap small_vector's no longer require a move constructor.
Also changes const -> constexpr in a bunch of places.
Reviewed By: nbronson
Differential Revision:
D5804361
fbshipit-source-id:
0f00fee6d318fa9296612409805d4ffcfbadb974
Tom Jackson [Thu, 14 Sep 2017 02:01:02 +0000 (19:01 -0700)]
Window, mainly for futures
Summary: Just a circular buffer in the middle of a pipeline.
Reviewed By: yfeldblum
Differential Revision:
D5791551
fbshipit-source-id:
2808a53df9b8cd2a402da0678a6b4ed0e6ca6e00
Christopher Dykes [Thu, 14 Sep 2017 01:59:20 +0000 (18:59 -0700)]
Workaround a bug in template instation in MSVC 2017.3 with /permissive-
Summary:
As described in the comment in `folly/stats/Histogram.h`, MSVC 2017.3 has issues with `/permissive-`.
The bug has been fixed upstream, it's just waiting for release.
These explicit template instantiations are never forward-declared anywhere, so, as long as `Histogram-defs.h` has been included, it's perfectly safe to just not do them.
https://developercommunity.visualstudio.com/content/problem/81223/incorrect-error-c5037-with-permissive.html
Reviewed By: yfeldblum
Differential Revision:
D5828891
fbshipit-source-id:
4db8407c9d35aa5bb3f7b81aa24f611b5787fb6e
Christopher Dykes [Wed, 13 Sep 2017 21:41:27 +0000 (14:41 -0700)]
Fix build without zlib compression enabled
Summary: The namespace alias was trying to alias a namespace that doesn't exist unless Folly is being compiled with zlib support.
Reviewed By: terrelln
Differential Revision:
D5810929
fbshipit-source-id:
c659d8f775fc9b99e57cc95f5914418507e546fb
Stephen Chen [Wed, 13 Sep 2017 21:19:14 +0000 (14:19 -0700)]
fixing namespacing issue for the dummy non sse crc32c_hw
Summary:
Because the way the #if was written, the dummy crc32c_hw function accidentally
ended in folly namespace instead of folly::details as expected. Fix this.
Reviewed By: yfeldblum
Differential Revision:
D5826187
fbshipit-source-id:
ba0f2207a00bc21eda7a727f3f1025e1106d55f9
Marcus Holland-Moritz [Wed, 13 Sep 2017 08:39:44 +0000 (01:39 -0700)]
Fix UB from signed integer overflow in RWSpinLock
Summary:
The signed counters used in a couple of places can in theory (and practice)
overflow, yielding UB. Use unsigned counters instead.
Reviewed By: luciang, philippv
Differential Revision:
D5818606
fbshipit-source-id:
c5928b779e76b309b00b7f6308a220e2bf6cbf79
Jon Maltiel Swenson [Wed, 13 Sep 2017 04:30:08 +0000 (21:30 -0700)]
Backed out changeset
ea9041ce2280
Summary: Revert
D5787837. Breaks `onSet()`/`onUnset()` behavior.
Reviewed By: palmtenor
Differential Revision:
D5817063
fbshipit-source-id:
c7dea636fa60eb616d4ebe0a9d418bc96b3018ae
Michael Lee [Tue, 12 Sep 2017 23:05:54 +0000 (16:05 -0700)]
Include glog/logging.h in SmallLocksTest for DCHECK
Summary: The test uses DCHECK, but does not include glog/logging.h.
Reviewed By: yfeldblum
Differential Revision:
D5818647
fbshipit-source-id:
fcb2630ac2b12acd1a7b84e228349b2887e976cd
Alberto Schiabel [Tue, 12 Sep 2017 21:47:03 +0000 (14:47 -0700)]
Update String.h
Summary:
Fixed typo in doc comment related to `void toLowerAscii(char* str, size_t length)`.
This fixes the annoying xCode's warning `Parameter 'len' not found in the function declaration`.
Closes https://github.com/facebook/folly/pull/670
Reviewed By: yfeldblum
Differential Revision:
D5815034
Pulled By: Orvid
fbshipit-source-id:
9580cd0bbd4924d4ed461a5435f525316e5c285a
Christopher Dykes [Tue, 12 Sep 2017 20:54:49 +0000 (13:54 -0700)]
Don't use std::void_t
Summary: I was wrong, MSVC's implementation has the same bug as everything else.
Reviewed By: yfeldblum
Differential Revision:
D5810646
fbshipit-source-id:
9caabbbc2115f57b7e836bb85c9b108588c94ad9
Martin Martin [Tue, 12 Sep 2017 18:51:07 +0000 (11:51 -0700)]
const -> constexpr in folly::small_vector
Summary: const -> constexpr in folly::small_vector
Reviewed By: yfeldblum
Differential Revision:
D5814264
fbshipit-source-id:
4631bb7f3f04906636e5a188d4aa0d33ad796a3c
Philip Jameson [Tue, 12 Sep 2017 18:49:14 +0000 (11:49 -0700)]
Remove unneeded parts of build script
Summary: Remove an unneeded autoconf flag, as it causes the build to fail on missing boost-context
Reviewed By: yfeldblum
Differential Revision:
D5815646
fbshipit-source-id:
cb6544593de9fbf8248506b09c56412b4635b30c
Martin Martin [Tue, 12 Sep 2017 18:34:55 +0000 (11:34 -0700)]
clang-format folly::small_vector. No functional change.
Summary: clang-format folly::small_vector. No functional change.
Reviewed By: Orvid
Differential Revision:
D5808357
fbshipit-source-id:
d2ee831e25c60778c699214b875635c22854832d
Jon Maltiel Swenson [Tue, 12 Sep 2017 16:09:42 +0000 (09:09 -0700)]
Make RequestContext provider overridable in order to save cost of setContext() on each fiber context switch
Summary:
Each fiber context switch currently involves the cost of saving/restoring `RequestContext`. Certain
fibers-based applications such as mcrouter don't use `RequestContext` at all, so updating the current
thread-global `RequestContext` on each fiber context switch is unnecessary overhead. Avoid this cost
by allowing `FiberManager` to override the `RequestContext` provider at the start and end of each fiber drain
loop.
Reviewed By: andriigrynenko
Differential Revision:
D5787837
fbshipit-source-id:
ea9041ce228063c8701165366fd1e34132868d22
Christopher Dykes [Tue, 12 Sep 2017 02:15:15 +0000 (19:15 -0700)]
Fix CMake build
Summary: Spookyhash got moved a long time ago, and a duplicate test name was added with the migration of executors from wangle to folly.
Reviewed By: yfeldblum
Differential Revision:
D5811321
fbshipit-source-id:
789b4d3187a2e1e21c6cf8297f733bb4dffdbd60
Phil Willoughby [Mon, 11 Sep 2017 19:20:45 +0000 (12:20 -0700)]
Dead shift in ConcurrentHashMapSegment
Summary: Original problem detected by compiling with `-Werror,-Wunused-value`. On further inspection the only place which uses this detail class ensures that the `max_size` parameter is a power of two already, so we can discard the logic to manipulate `max_size` and put a `CHECK` clause in its place to guard against future changes to the caller that break this assumption.
Reviewed By: yfeldblum
Differential Revision:
D5799110
fbshipit-source-id:
d21ed9ff196d54ef91e38254df8b1b88bbf29275
Anirudh Ramachandran [Mon, 11 Sep 2017 11:54:57 +0000 (04:54 -0700)]
Move SSL_CTX sessionContext initialization into main SSL_CTX initialization path
Summary: This field was only previously set if setupSessionCache was called on the wangle::ServerSSLContext
Reviewed By: yfeldblum
Differential Revision:
D5776057
fbshipit-source-id:
ecdbe83816fee2ecbe7ea1b26a67b682a571309a
Giuseppe Ottaviano [Sun, 10 Sep 2017 16:59:56 +0000 (09:59 -0700)]
Add convenience std::string overload for toLowerAscii
Summary:
`toLowerAscii` is surprisingly hard to use with `std::string` because (until C++17) `data()` returns a `const char*`. In addition, it is not widely known that `s[0]` is legal even if the string is empty. This can lead to a variety of suboptimal code, from explicitly checking emptiness, to casting away the `const` (which causes UB).
Let's just have a simple overload for it.
Reviewed By: pixelb, philippv, yfeldblum
Differential Revision:
D5801970
fbshipit-source-id:
407e2e9e66147a0662a5e09c75921255adff0702
Giuseppe Ottaviano [Sun, 10 Sep 2017 06:59:18 +0000 (23:59 -0700)]
Fix typo in async/README.md
Reviewed By: yfeldblum
Differential Revision:
D5802013
fbshipit-source-id:
472b09da2be7234157a7886018004e2f4ed4f279
Benjamin Jaeger [Fri, 8 Sep 2017 20:59:20 +0000 (13:59 -0700)]
Optional.h - make == operators constexprs
Summary: This more closely matches std optional and allows folly Optional to be a drop in replacement.
Reviewed By: aary, yfeldblum
Differential Revision:
D5775541
fbshipit-source-id:
f754c006429fa3c5a866b6b5ffdfd8883ec2dd4f
Eric Niebler [Fri, 8 Sep 2017 19:36:10 +0000 (12:36 -0700)]
support using co_await with folly::Optional when it is available
Summary:
Coroutines can be used to simulate the monadic "do" notion of Haskell. Use coroutines to enable monadic composition with folly::Optional.
```
Optional<int> f() {
return 7;
}
Optional<int> g(int) {
return folly::none;
}
void MonadicOptional() {
Optional<int> r = []() -> Optional<int> {
int x = co_await f();
assert(x == 7);
int y = co_await g(x);
assert(false); // not executed
co_return y;
}();
assert(!r.hasValue());
}
```
Reviewed By: yfeldblum
Differential Revision:
D5763371
fbshipit-source-id:
9babc682244f38da7006d0b3a8444fd4efec1747