task.js

Beautiful concurrency for JavaScript

  • Owner: mozilla/task.js
  • Platform:
  • License:: Other
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

task.js

task.js provides an automatic task scheduler along with a library of first-class, synchronizable
events, making it easy to do I/O without callbacks.

With task.js you can write non-blocking I/O in a synchronous style, even with error handling:

spawn(function*() {
    try {
        var [foo, bar] = yield join(read("foo.json"),
                                    read("bar.json")).timeout(1000);
        render(foo);
        render(bar);
    } catch (e) {
        console.log("read failed: " + e);
    }
});

Compared with callbacks:

var foo, bar;
var tid = setTimeout(function() { failure(new Error("timed out")) }, 1000);

var xhr1 = makeXHR("foo.json",
                   function(txt) { foo = txt; success() },
                   function(err) { failure() });
var xhr2 = makeXHR("bar.json",
                   function(txt) { bar = txt; success() },
                   function(e) { failure(e) });

function success() {
    if (typeof foo === "string" && typeof bar === "string") {
        cancelTimeout(tid);
        xhr1 = xhr2 = null;
        render(foo);
        render(bar);
    }
}
    
function failure(e) {
    xhr1 && xhr1.abort();
    xhr1 = null;
    xhr2 && xhr2.abort();
    xhr2 = null;
    console.log("read failed: " + e);
}

...tasks can be a lot simpler and cleaner. And unlike pre-emptive
threads, yield always makes it clear where tasks block.

Contributing

Currently the best way to contribute is to hang out on IRC: the
channel is #task.js on irc.mozilla.org. Or
you can always send me email (my Github nick at mozilla.com). And I'm
always happy to accept pull requests!

If you're looking for interesting things to work on, check out the
issue tracker.

Main metrics

Overview
Name With Ownermozilla/task.js
Primary LanguageJavaScript
Program languageJavaScript (Language Count: 1)
Platform
License:Other
所有者活动
Created At2010-10-12 23:43:51
Pushed At2019-03-28 03:38:53
Last Commit At2013-11-27 23:37:13
Release Count0
用户参与
Stargazers Count1.6k
Watchers Count48
Fork Count73
Commits Count48
Has Issues Enabled
Issues Count37
Issue Open Count24
Pull Requests Count2
Pull Requests Open Count6
Pull Requests Close Count3
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private