2018-11-26 04:12:17 +01:00
.github Add contribution templates 2018-03-09 03:34:43 +01:00
cmake Improve 4ae560156348 and allow it to be set as an option 2018-11-19 19:53:02 +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 Introduce the continuable primitive header which supplies tags 2018-11-19 23:59:01 +01:00
include/continuable Implement the exception invokers which fully implements recover, rethrow and cancel now 2018-11-26 04:12:17 +01:00
test Implement the exception invokers which fully implements recover, rethrow and cancel now 2018-11-26 04:12:17 +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 Move some methods out of the attorney 2018-11-24 15:02:23 +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 Improve 4ae560156348 and allow it to be set as an option 2018-11-19 19:53:02 +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.