An IOExecutor that executes under mapped fiber context.
authorRushi Desai <rushix@fb.com>
Wed, 29 Apr 2015 06:17:06 +0000 (23:17 -0700)
committerAndrii Grynenko <andrii@fb.com>
Wed, 29 Apr 2015 22:57:36 +0000 (15:57 -0700)
Summary:
This should help executing sync thrift handlers on fibers. This allows the handler methods to achieve concurrency by awaiting.

Test Plan: Chimera unit tests (which also accesses running FacebookBase methods in fiber context!)

Reviewed By: davejwatson@fb.com

Subscribers: trunkagent, hannesr, andrii, folly-diffs@, jsedgwick, haijunz, yfeldblum, alandau, chalfant

FB internal diff: D2015886

Signature: t1:2015886:1430156870:a84499e0e781f5e6e77f48f1f3063f53d0968698

folly/Makefile.am
folly/experimental/fibers/FiberIOExecutor.h [new file with mode: 0644]

index 45296006996a3763e7aef27f230bc0bf23f73aec..245f4c8991444c288ac20f183b86330acb0243d7 100644 (file)
@@ -83,6 +83,7 @@ nobase_follyinclude_HEADERS = \
        experimental/fibers/ExecutionObserver.h \
        experimental/fibers/Fiber.h \
        experimental/fibers/Fiber-inl.h \
+       experimental/fibers/FiberIOExecutor.h \
        experimental/fibers/FiberManager.h \
        experimental/fibers/FiberManager-inl.h \
        experimental/fibers/FiberManagerMap.h \
diff --git a/folly/experimental/fibers/FiberIOExecutor.h b/folly/experimental/fibers/FiberIOExecutor.h
new file mode 100644 (file)
index 0000000..cd6e675
--- /dev/null
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2015 Facebook, Inc.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *   http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+#pragma once
+
+#include <folly/experimental/fibers/FiberManagerMap.h>
+#include <folly/wangle/concurrent/IOExecutor.h>
+
+namespace folly { namespace fibers {
+
+/**
+ * @class FiberIOExecutor
+ * @brief An IOExecutor that executes funcs under mapped fiber context
+ *
+ * A FiberIOExecutor wraps an IOExecutor, but executes funcs on the FiberManager
+ * mapped to the underlying IOExector's event base.
+ */
+class FiberIOExecutor : public folly::wangle::IOExecutor {
+ public:
+  explicit FiberIOExecutor(
+      const std::shared_ptr<folly::wangle::IOExecutor>& ioExecutor)
+      : ioExecutor_(ioExecutor) {}
+
+  virtual void add(std::function<void()> f) override {
+    auto eventBase = ioExecutor_->getEventBase();
+    getFiberManager(*eventBase).add(std::move(f));
+  }
+
+  virtual EventBase* getEventBase() override {
+    return ioExecutor_->getEventBase();
+  }
+
+ private:
+  std::shared_ptr<folly::wangle::IOExecutor> ioExecutor_;
+};
+
+}}