Asynchronous library for D
To use this package, run the following command in your project's root directory:
Put the following dependency into your project's dependences section:
This library provides infrastructure for writing concurrent code using coroutines, multiplexing I/O access over sockets and other resources, running network clients and servers, and other related primitives.
It implements most of the python 3 [asyncio API](https://docs.python.org/3/library/asyncio.html).
Can be found at: http://dcarp.github.io/asynchronous/index.html
- Timers (done)
- Futures, Tasks (done)
- Sockets (done)
- Streams (done)
- Subprocesses (not implemented)
- Locks and semaphores (done)
- Queues (done)
Why yet another async library? What is wrong with vibe.d?
asynchronousis a library and not a framework
- it is not web-oriented, compatible with
- arguably nicer API
- event loop start/stop control
@CoroutineUDA to mark functions that could trigger a task (fiber) switch, although this is not enforced by the compiler yet.
Examples and tutorials
Some small examples can be found in the test directory or as unittests.
For larger examples please use the python resources. Just keep in mind that in contrast with Python in D a coroutine MUST NOT be called from outside of a task (it causes a run-time error on fiber switch). So you may need to add
EventLoop.createTask on the first calling level.
- Registered by Dragos Carp
- 0.6.4 released 7 years ago
- Boost 1.0
- Copyright © 2015-2016 Dragoş Carp