2018-11-19 19:26:51 +01:00
.github Add contribution templates 2018-03-09 03:34:43 +01:00
cmake Fix CMake scripts 2018-11-17 12:10:01 +01:00
dep Implement a benchmark against boost::future 2018-11-18 17:46:25 +01:00
doc Implement continuables as return types for coroutines 2018-03-14 10:29:45 +01:00
examples Make it possible to remap the result from promisified expressions 2018-03-17 13:24:57 +01:00
include/continuable Move from std::decay to std::decay_t 2018-11-19 19:26:18 +01:00
test Move from std::decay to std::decay_t 2018-11-19 19:26:18 +01:00
tools Reformat the travis-ci shell script 2018-11-19 19:26:51 +01:00
.clang-format Rearrange the internal headers 2018-11-18 18:46:15 +01:00
.clang-tidy Some minor improvements to clang-tidy 2018-01-30 05:15:19 +01:00
.editorconfig Split the header into multiple files 2017-09-24 19:55:58 +02:00
.gitattributes Update editor, formatting and CI files 2017-09-21 23:29:21 +02:00
.gitignore Add vscode files to gitignore 2018-11-19 19:26:30 +01:00
.gitmodules Initial work on benchmarking 2018-11-18 17:46:24 +01:00
.travis.yml Reduce the amount of instantiations tested inside the CI 2018-03-12 09:56:53 +01:00
appveyor.yml Fix a copy paste mistake 2018-03-12 09:48:09 +01:00
CMakeLists.txt Disable benchmarks by default 2018-11-18 17:46:25 +01:00
LICENSE.txt Happy new Year! 2018-01-04 01:45:09 +01:00
Readme.md Update the online compilers 2018-03-12 16:32:28 +01:00

Continuable

Current version Travic-CI build status AppVeyor CI status MIT Licensed Documentation Try continuable online Compiler explorer


Continuable is a C++14 library that provides full support for:

  • lazy async continuation chaining based on callbacks (then) and expression templates, callbacks are wrapped nicely as promises.
  • no enforced type-erasure which means we need less heap allocations than comparable libraries, strictly following the "don't pay for what you don't use" principle.
  • support for all, any and sequential connections between continuables through expressive operator overloads &&, || and >> as well as free functions when_all, when_any and when_seq.
  • asynchronous error handling through exceptions, error codes and user defined types.
  • syntactic sugar for instance: partial invocation, tuple unpacking, co_await support and executors.
  • encapsuled from any runtime, larger framework or executors makes it possible to use continuable even in smaller or esoteric usage scenarios.

Getting started:

The documentation offers everything you need:

Issues and contributions

Issue reports are accepted through the Github issue tracker as well as Pull requests. Every contribution is welcome! Don't hesitate to ask for help if you need any support in improving the implementation or if you have any troubles in using the library.