tree: 2622f8e5594d815c51d209eb01bbb43baaf267be [path history] [tgz]
  1. examples/
  2. include/
  3. kokoro/
  4. src/
  5. .clang-format
  6. .gitignore
  7. .gitmodules
  8. Android.bp
  9. AUTHORS
  10. BUILD.gn
  11. CMakeLists.txt
  12. CONTRIBUTING.md
  13. LICENSE
  14. README.md
third_party/marl/README.md

Marl

Marl is a hybrid thread / fiber task scheduler written in C++ 11.

About

Marl is a C++ 11 library that provides a fluent interface for running tasks across a number of threads.

Marl uses a combination of fibers and threads to allow efficient execution of tasks that can block, while keeping a fixed number of hardware threads.

Marl supports Windows, macOS, Linux, Fuchsia and Android (arm, aarch64, ppc64 (ELFv2), x86 and x64).

Marl has no dependencies on other libraries (with exception on googletest fo building the optional unit tests).

Marl is in early development and will have breaking API changes.

More documentation and examples coming soon.

Note: This is not an officially supported Google product