Making async code sync#
Such generators, much synchronous, so stacktraces, wow.
syncio
makes your IO related code look synchronous by using generators and generator delegation
from upcoming ES6 standard. And it makes your stack traces long and shiny!
To use syncio
you need Node.js >= 0.11.10 running with --harmony
flag. Version for browsers is coming soon
npm install syncio
Differences from other libraries##
Unlike other libraries the main idea of syncio
is than you have to use it in one place,
generally to start up the application, and then you just use generators and yield*
a.k.a "yield from" a.k.a
generator delegation to compose functions.
Because syncio
encourages to use generator delegation it preserves relevant stack traces.
Examples##
var sync = ; // turning async node-style function into generatorvar sleep = ; // wraps and executes the generator;
Now let's say, you have another function where you want to use sleep, this is how you do it with syncio
var { ; // straightforward stack traces console; return value;}; var { return ;}; ;
syncio
tries its best to keep generator call stack when asynchronous functions throw errors
// that what you'd get in the greeting example above if sleep function returns an error and you don't use syncio
Error: 1000
at null._onTimeout (/home/qweqwe/sleep.js:43:32)
at Timer.listOnTimeout (timers.js:124:15)
// and this is what you get when you use syncio
Error: 1000
at null._onTimeout (/home/qweqwe/sleep.js:43:32)
at Timer.listOnTimeout (timers.js:124:15)
from syncio generator (cleaned):
at echo (/home/qweqwe/sleep.js:47:10)
at greet (/home/qweqwe/sleep.js:54:17)
at /home/qweqwe/sleep.js:58:25
Parallel execution##
syncio
also supports parallel execution of generators
var sync = ;// transform node-style function into a generatorvar request = ; { var response = ; return response0statusCode;} ;
License##
MIT