- 12 Jun, 2019 2 commits
-
-
Nick Terrell authored
Summary: Fix https://github.com/facebook/folly/issues/1111 by calling `assign()` directly. All `ExpectedStorage::assign()` implementations eventually call `doEmplaceAssign()` which uses SFINAE to assign, and if that fails emplace. Therefore, they only need `std::is_constructible`. Reviewed By: yfeldblum Differential Revision: D15756301 fbshipit-source-id: e7759128c13344ed6e3d58d6ea143fd68af8121b
-
Yedidya Feldblum authored
Summary: [Folly] Rename `FOLLY_ASAN_ENABLED` to `FOLLY_LIBRARY_SANITIZE_ADDRESS`. Reviewed By: simpkins Differential Revision: D10414837 fbshipit-source-id: b7ca2a36dd7f91ccab2f8051f78c75909f378d16
-
- 11 Jun, 2019 5 commits
-
-
Adam Simpkins authored
Summary: This is a hack for now to allow fbsource-based watchman getdeps builds to succeed. In the long run we need to update Watchman's CMakeLists.txt to depend on a proper EdenFS build, rather than copying Eden's thrift files into Watchman's source tree. Reviewed By: wez Differential Revision: D15753320 fbshipit-source-id: 2dea483c2053c4ea1cf64021c4bbc3239fce645d
-
Yedidya Feldblum authored
Summary: [Folly] Support various operations on empty `IPAddress` and `SocketAddress`, i.e. default-constructed instances, such as `operator==` and `hash`. V.s. throwing exceptions. Reviewed By: simpkins Differential Revision: D15750100 fbshipit-source-id: 89853635f6aab3c295f6fca4e66e6435b0839357
-
Shrikrishna Khare authored
Summary: The previous diffs in the stack add fbcode_builder manifests for FBOSS dependencies iproute2 and OpenNSL. The other FBOSS dependencies already have fbcode_builder support. Thus, add FBOSS manifest. Additionally, this patch also modifies fboss CMakeLists.txt to get FBOSS to build using fbcode_builder. Reviewed By: wez Differential Revision: D15626298 fbshipit-source-id: 31802ef695ae69b08f526bbeb299c59f3b9d44be
-
Shrikrishna Khare authored
Summary: D15683387 introduced manifest for libcurl and used cmake instead of autoconf (rationale: having cmake build curl would make it easy as we want curl to build on windows and macos). if libcurl finds ldap.h, then it builds with ldap enabled. On my devserver, ldap library is not installed, and thus libcurl builds without it, and links with FBOSS binaries fine. In sandbox, ldap seems to be installed, thus libcurl builds with ldap. However, linking fails for FBOSS binaries as those don't link against ldap - FBOSS does not depend on ldap. Thus, we need a way to configure libcurl with ldap disabled. [cmake.defines] CURL_DISABLE_LDAP=OFF, does not quite do it. Thus, am going with autoconf, with args --disable-ldap for now for Linux and cmake for non-Linux environments. Reviewed By: wez Differential Revision: D15730947 fbshipit-source-id: 2ce48976ee785401d550720cbdccb22f9d416675
-
Shrikrishna Khare authored
Summary: D15588809 introduced manifest and customer builder for iproute2. While the Iproute2Builder copies include/* from build to install directory, it does not copy lib/* which contains the libnetlink.a As a result, the build system looks up libnetlink.a on local machine (which it may not find). Fix it by explicitly coping lib/* as well. Reviewed By: wez Differential Revision: D15708835 fbshipit-source-id: 3f5906eb48ce982b6e887cca0d3c11314425beab
-
- 10 Jun, 2019 1 commit
-
-
Jingyi Yang authored
Summary: This diff allows zmq socket to run on folly::fibers Reviewed By: saifhhasan Differential Revision: D15113447 fbshipit-source-id: 8a0e1f91d719a9deda48837d4ff1065408280b72
-
- 09 Jun, 2019 2 commits
-
-
Eric Niebler authored
Summary: Build failures with gcc-7 suggest that gcc-7 is not property short-circuiting SFINAE conditions in the parameter list of function templates. Re-express as cascading tests to avoid the hard error. Reviewed By: yfeldblum Differential Revision: D15730238 fbshipit-source-id: 793e12630d609d4e135b4a55714be0cb0496f6f7
-
Luca Niccolini authored
Summary: Original commit changeset: 5e101fc38417 Reviewed By: snarkmaster Differential Revision: D15726457 fbshipit-source-id: 001ee9ebaee81ebc60996e5fb95c1870121b2dec
-
- 08 Jun, 2019 1 commit
-
-
Yedidya Feldblum authored
Summary: [Folly] Fixed constexpr append in `FixedString` tests after {D15618465}. ``` folly/test/FixedStringTest.cpp: In member function 'virtual void FixedStringAssignTest_ConstexprAppendLiteral_Test::TestBody()': folly/test/FixedStringTest.cpp:360:3: error: non-constant condition for static assertion static_assert(constexpr_append_literal_test() == "hello world!", ""); ^~~~~~~~~~~~~ In file included from folly/Range.h:25:0, from folly/FixedString.h:33, from folly/test/FixedStringTest.cpp:20: folly/test/FixedStringTest.cpp:360:47: in constexpr expansion of 'constexpr_append_literal_test()' folly/test/FixedStringTest.cpp:355:18: in constexpr expansion of '#'result_decl' not supported by dump_expr#<expression error>.folly::BasicFixedString<char, 20>::append((& s[7]))' folly/FixedString.h:1277:48: in constexpr expansion of 'folly::constexpr_strlen<char>(that)' folly/portability/Constexpr.h:68:21: error: 'strlen((& s[7]))' is not a constant expression return std::strlen(s); ~~~~~~~~~~~^~~ ``` Reviewed By: simpkins Differential Revision: D15643402 fbshipit-source-id: c7e26a0c37c956300364c566f211c866985d9dc2
-
- 07 Jun, 2019 3 commits
-
-
Nathan Bronson authored
Summary: It's common for people reading the F14 code to see the fallback implementation without noticing the #if !FOLLY_F14_VECTOR_INTRINSICS_AVAILABLE at the top, which leads them to incorrect conclusions about the code. This diff flips the order in the file to reduce confusion. Reviewed By: shixiao Differential Revision: D15571969 fbshipit-source-id: 10d2aa29da3f1b8dd48af490a53f1f845f103fa8
-
Yedidya Feldblum authored
Summary: [Folly] Merge `folly/futures/helpers.h` into `folly/futures/Future.h` to avoid the cyclic include trap. Differential Revision: D15600550 fbshipit-source-id: a0d14c0092bb433f7af797201d9fafebab370502
-
Anton Likhtarov authored
Summary: pthread_getname_np() tries to dereference 0 when called with it, let's turn it into an error instead Reviewed By: yfeldblum Differential Revision: D15708351 fbshipit-source-id: aa2dd92e12e33174c8998daed056de50d4111774
-
- 06 Jun, 2019 14 commits
-
-
Zeyi (Rice) Fan authored
Summary: This diff adds an option "level" to standard log handler configuration so handlers can have individual logging level set. This allows us to have multiple handler that handles messages with different level settings. For example, > eden=DBG3:default:other; default=stream; other=stream:level=WARN; This configuration creates two log handlers "default" and "other". Both of the handlers will be receiving log messages level "DBG3" from "eden" log category. In this example, "other" handler will only be receiving log messages that is >= "WARN" while the "default" handler still receives all messages >= "DBG3". However, one catch of this diff is that, when the log category is set to a higher logging level and the log handler has a lower logging level. The log handler will NOT receive any log messages that is lower than the log category logging level. The test `LogLevelReverseTest` illustrate this situation. Reviewed By: simpkins Differential Revision: D15541101 fbshipit-source-id: 741aa97d2d5e93c40324bf6a3dd1d9e38f4dc6a5
-
Dan Melnic authored
Change SharedInfoObserverEntryBase::beforeFreeExtBuffer to SharedInfoObserverEntryBase::afterFreeExtBuffer Summary: Change SharedInfoObserverEntryBase::beforeFreeExtBuffer to SharedInfoObserverEntryBase::afterFreeExtBuffer Reviewed By: yfeldblum Differential Revision: D15687084 fbshipit-source-id: 8f77a123f1bdc0e0ee7391dee7da47d9b9addc6d
-
Shrikrishna Khare authored
Summary: This is towards getting open source FBOSS to build using fbcode_builder. libnl is one of the dependencies for FBOSS. This patch adds a manifest file to build libnl. Reviewed By: wez Differential Revision: D15686853 fbshipit-source-id: f7549df6dc1005630193b024be6e1ea330cc6646
-
Shrikrishna Khare authored
Summary: This is towards getting open source FBOSS to build using fbcode_builder. libcurl is one of the dependencies for FBOSS. This patch adds a manifest file to build libcurl. Reviewed By: wez Differential Revision: D15683387 fbshipit-source-id: 8df5c413e7dff06d1a19e0ce3b1706bff2f1ab54
-
Shrikrishna Khare authored
Summary: This is towards getting open source FBOSS to build using fbcode_builder. libusb is one of the dependencies for FBOSS. This patch adds a manifest file to build libusb. FBOSS does not need libudev, so we avoid unncessary dependency by passing right argument to ./configure. Reviewed By: wez Differential Revision: D15683386 fbshipit-source-id: 1d35caecf4012ddc0df24a7305019d522b4763fa
-
Andrii Grynenko authored
Summary: If fiber was activated with an exception it's safe for that fiber to be preempted. Differential Revision: D15640534 fbshipit-source-id: d908aacd81e1ec57874324a58b180587a1fe2eeb
-
Yedidya Feldblum authored
Summary: Replace inclusions of `folly/futures/helpers.h` with `folly/futures/Future.h` to avoid the cyclic include trap. Differential Revision: D15600549 fbshipit-source-id: 19950be24a7437fb1fbec293e24058adf17343ca
-
Wez Furlong authored
Summary: We sometimes see some flakeyness in our internal CI, so we can live without it there. Reviewed By: pkaush Differential Revision: D15695124 fbshipit-source-id: 1d76ae89e245d9c95937e8818826c544c0ae8fc3
-
Takshak Chahande authored
Summary: Currently, AsyncSocket's `connect` API creates new socket, set various options, bind it to passed argument address and used it for connecting to server. While most of the things are handled inside that single connect routine; sometimes if the caller would like to do few more additional operations before actual connect happens; caller would like to have hold on the underneath used socket. In order to do that additional operation on the socket, this diff provides the facility to provide custom pre-connect hook `preConnect(NetworkSocket fd)` in the `ConnectCallback` which will be invoked just before the actual server connect. Reviewed By: yfeldblum Differential Revision: D15282727 fbshipit-source-id: 5beac55c77a9537ee4f26856dd5f78c5224a1f49
-
Uladzislau Paulovich authored
Summary: Input and output types for the cast are the same (except const qualifier) and therefore it's not required. Reviewed By: milend Differential Revision: D15694981 fbshipit-source-id: d5a811d97cc145ba9c232b79f6c8fa52041b0cf0
-
Yedidya Feldblum authored
Summary: [Folly] `XLOG_EVERY_N_THREAD`. Implemented with a single per-thread map for all `XLOG_EVERY_N_THREAD` collectively. This approach has better TLS overhad than a `thread_local` counter per `XLOG_EVERY_N_THREAD`, at the cost of integer-keyed map lookups. While the `thread_local` counter approach is twice as fast as this approach for a noop log-handler, it is expected that the runtime overhead of real log-handlers will make this type of saving immaterial. Reviewed By: simpkins, luciang Differential Revision: D15293529 fbshipit-source-id: 7af535a0d329473126a0e4dcffc19d750e8b8b10
-
Miroslav Crnic authored
Summary: Lifo sem exposes allocateNode and tryWaitOrPush as protected which allows inherited classes custom Node implementation, creation and enqueueing. tryRemoveNode was private which prevented inherited classes from dequeueing a Node without signaling shutdown. This diff fixes it Reviewed By: shixiao Differential Revision: D15647287 fbshipit-source-id: 5b26a9616f6de559224f9d8c38230780c78a7cf5
-
Yedidya Feldblum authored
Summary: [Folly] Let `KeepAlive::copy()` allow dummy executors to expire, and not attempt to dereference them to perform an acquire - which, as is known in advance, would fail and return false were the executor still to be alive. Reviewed By: andrewcox Differential Revision: D15683240 fbshipit-source-id: e2026493af6936b8f0f1b8fe3c1cb97d2bf0f96e
-
Yedidya Feldblum authored
Summary: [Folly] Split KeepAlive concepts of dummy and alias. A dummy KeepAlive is one for an executor which does not actually support keep-alive semantics. An alias KeepAlive is one for which there is another KeepAlive, with a surrounding lifetime, to the same executor. Reviewed By: andrewcox Differential Revision: D15683241 fbshipit-source-id: a5809b06c90ed4a655a6973fac67137b5e1981dc
-
- 05 Jun, 2019 7 commits
-
-
Yedidya Feldblum authored
Summary: [Folly] Avoid gcc7 lambda-captures bug in `SerialExecutor` test. ``` folly/executors/test/SerialExecutorTest.cpp: In lambda function: folly/executors/test/SerialExecutorTest.cpp:66:40: error: declaration of 'i' shadows a previous local [-Werror=shadow] folly/executors/test/SerialExecutorTest.cpp:60:12: note: shadowed declaration is here folly/executors/test/SerialExecutorTest.cpp: In function 'void simpleTest(const std::shared_ptr<folly::Executor>&)': folly/executors/test/SerialExecutorTest.cpp:74:45: error: already captured 'i' in lambda expression [-Werror] folly/executors/test/SerialExecutorTest.cpp: In lambda function: folly/executors/test/SerialExecutorTest.cpp:74:62: error: 'i' is not captured folly/executors/test/SerialExecutorTest.cpp:74:46: note: the lambda has no capture-default folly/executors/test/SerialExecutorTest.cpp:60:12: note: 'int i' declared here ``` Fixes #1154. Reviewed By: andriigrynenko Differential Revision: D15629657 fbshipit-source-id: fec82e9d54b2c79a7f54f366ec8a19ad7dc198e9
-
Joe Loser authored
Summary: - Cut `FOLLY_HAVE_COMPARE_EQUIVALENT` as this is `1` for Clang 3.4 onward (regardless of `libstdc++` or `libc++`) and also `1` for GCC versions we support. Pull Request resolved: https://github.com/facebook/folly/pull/1157 Reviewed By: Orvid Differential Revision: D15641688 Pulled By: yfeldblum fbshipit-source-id: 0602913b375a406cce6337e43ba708362a94d444
-
Shrikrishna Khare authored
Summary: This is towards getting open source FBOSS to build using fbcode_builder. libmnl is one of the dependencies for FBOSS. This patch adds a manifest file to build the specific version of libmnl for FBOSS. Reviewed By: wez Differential Revision: D15633176 fbshipit-source-id: dd51997ae950f53842711fbf2d044e84cdf437e7
-
Shrikrishna Khare authored
Summary: This is towards getting open source FBOSS to build using fbcode_builder. OpenNSL is one of the dependencies for FBOSS. OpenNSL is github repository with headers and prebuilt opaque library. Thus, we can't/don't need to build it. Thus, OpenNSL manifest uses NopBuilder. fbcode_builder expects the library to be in installed/lib and headers to be in installed/include, but OpenNSL lib structure is different. Thus, add explicit [install.fields] rule for bin/wedge => lib. Once a rule(s) is provided, we must provide rule(s) for all, so add rule for include => include as well. Reviewed By: wez Differential Revision: D15593639 fbshipit-source-id: facb36ff7b9a31f5952ecbc1a9fdb834c0e68d11
-
Shrikrishna Khare authored
Summary: This is towards getting open source FBOSS to build using fbcode_builder. iproute2 is one of the dependencies for FBOSS. This patch adds a manifest file to build the specific version of iproute2 needed for FBOSS. Additionally, the default git clone depth of 100 is insufficient for the version of iproute2 FBOSS depends on. Thus, this patch extends the git SCHEMA to add optional argument depth. The default remains 100. The usual /configure --prefix does not work for iproute2. Thus, we need to add a custom builder that: - copies sources to build directory, builds, and - installs to installed directory using DEST_DIR. - it must also explicitly copy include from build dir to install dir Reviewed By: wez Differential Revision: D15588809 fbshipit-source-id: ac5eab24134e078d88b85b4be433c78b05ef8ce5
-
Yedidya Feldblum authored
Summary: [Folly] Use std interface in fibers mutex types: `try_lock_for`, `lock_shared`, etc. This makes fibers mutex types play well with `Synchronized`. Reviewed By: mnv104 Differential Revision: D15440755 fbshipit-source-id: 068b0c0b973577729f76f78c9063ff2ec06f4d90
-
Marshall Cline authored
Summary: Create pipe-adapters ("pipe fittings") that allow a `|`-based pipeline mixing {std-containers and/or range-v3} with folly::gen, e.g., ``` auto result = myVec // anything consistent with range-v3 or these adapters | ranges::view::filter(...) // zero-or-more range-v3 pipe-elems | <adapter-goes-here> // <==**one of the pipe-adapters provided by this task** | folly::gen::blah(); // trailing pipe-elems are folly::gen ``` This diff supplies only adapters that transition from {std-containers and/or range-v3} to folly::gen, but not the other way around. Q&A: * Why distinguish containers from range-v3's? E.g., container_to_gen vs. rangev3_to_gen? * Containers and range-v3's have different copy-costs: range-v3's have O(1) copy * Using two different names lets us separate the implementations so we can know which can be copied without significant overhead. * Why `#include` range-v3 from inside folly::gen? Why the dependency? * That `#include` / dependency adds value to the process, and it is included only for the client-files that need it. * It adds value to the process since the subset of client-files to be migrated are precisely the same subset of client-files that _need_ to include range-v3. * The alternative would be to add the `#include` out in all the various client-files during the migration process, and we will do that as the last step in the migration process. * The migration process is sped up by including range-v3 for that specific subset of client-files _and_ it hurts no one since only those who need that `#include` actually get it. * Note: we limit the `#include` to the subset of files to be migrated via the `FOLLY_USE_RANGEV3` define; see folly-config.h. Reviewed By: yfeldblum Differential Revision: D15035294 fbshipit-source-id: 694979850d1f35dd382e3afde792ea51a2397af0
-
- 04 Jun, 2019 5 commits
-
-
Adam Simpkins authored
Summary: Change the EventBaseTest code to request precise timing from libevent. libevent 2.1+ uses a coarse monotonic clock by default on Linux. This causes several of folly's timing-related tests for EventBase to fail most of the time. This changes the tests to request precise timing from libevent2, using the `EVENT_PRECISE_TIMER`. While we can request this programmatically, doing so portably across libevent versions is awkward, so the environment variable is the easiest solution for now. Alternatively we could change the tests to use larger, coarser timeouts to make them pass reliably. However, this would make the tests slower. Differential Revision: D15528322 fbshipit-source-id: 20dc55de36235e63910cf7fb5b67c6f2d509cc15
-
Adam Simpkins authored
Summary: Put file-local classes and helper functions into an unnamed namespace. Reviewed By: yfeldblum Differential Revision: D15528323 fbshipit-source-id: 9e90aafe4382d9ba237823fea1e68dbea7fa1f2f
-
Yedidya Feldblum authored
Summary: [Folly] Fix references to `TTransportException` in `folly/io/async/` to refer to `AsyncSocketException`. Reviewed By: jmswen, knekritz Differential Revision: D15628173 fbshipit-source-id: f6d36ede5e8b33d9407751733bcc9a7fa764815c
-
Joe Loser authored
Summary: - Clang 8 warns about appending integers to a string using `operator+` without a cast. ``` ../folly/test/FixedStringTest.cpp:353:23: warning: adding 'unsigned int' to a string does not append to the string [-Wstring-plus-int] a.append("X world!" + 2u, 5u); ~~~~~~~~~~~^~~~ ../folly/test/FixedStringTest.cpp:353:23: note: use array indexing to silence this warning a.append("X world!" + 2u, 5u); ^ & [ ] ../folly/test/FixedStringTest.cpp:354:23: warning: adding 'unsigned int' to a string does not append to the string [-Wstring-plus-int] a.append("X world!" + 7u); ~~~~~~~~~~~^~~~ ../folly/test/FixedStringTest.cpp:354:23: note: use array indexing to silence this warning a.append("X world!" + 7u); ^ & [ ] ../folly/test/FixedStringTest.cpp:365:23: warning: adding 'unsigned int' to a string does not append to the string [-Wstring-plus-int] a.append("X world!" + 2u, 5u); ~~~~~~~~~~~^~~~ ../folly/test/FixedStringTest.cpp:365:23: note: use array indexing to silence this warning a.append("X world!" + 2u, 5u); ^ & [ ] ../folly/test/FixedStringTest.cpp:366:23: warning: adding 'unsigned int' to a string does not append to the string [-Wstring-plus-int] a.append("X world!" + 7u); ~~~~~~~~~~~^~~~ ../folly/test/FixedStringTest.cpp:366:23: note: use array indexing to silence this warning a.append("X world!" + 7u); ^ & [ ] ``` - Fix this warning by creating a local char[] and using that to append to the fixed string Pull Request resolved: https://github.com/facebook/folly/pull/1148 Reviewed By: ericniebler Differential Revision: D15618465 Pulled By: yfeldblum fbshipit-source-id: 7f72b3597f51d99665da85744aeb8805eb2e8f00
-
Yedidya Feldblum authored
Summary: [Folly] Fix `PriorityUnboundedBlockingQueue` priority translation from `Executor` priorities to offsets as used by `PriorityUnboundedBlockingQueueSet`. Reviewed By: andriigrynenko Differential Revision: D15619435 fbshipit-source-id: 1c5d4d68dfde7f9db07d64f40e73717b48a05ed1
-