npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

task-group

v0.0.3

Published

Node module to run a graph of tasks

Downloads

4

Readme

task-group

Node module to run a graph of tasks

This module manages a list of tasks and their dependencies. It will run tasks in parallel and will complete all of a tasks dependencies before running a task.

A task is very similar to a Makefile task, except that it will run a plain JS function. As in Makefile tasks, a task can have zero or more dependencies that must be completed before the task can be run. A TaskGroup will run as many tasks as possible in parallel, including dependencies, but will always ensure that all dependencies are complete before calling the task action.

Example

Also see the tests in the spec directory.

var TaskGroup = require('task-group');

var tasks = new TaskGroup();
tasks.task('dir', function(done) {
    fs.mkdir('my-dir', done);
});

tasks.task('file', ['dir'], function(done) {
    fs.writeFile('my-dir/file', 'Test file', done);
});

// Runs `dir` task first, and then `file` task
tasks.run('file', function(err) {
    // `err` contains the error if an error occurred in any of the tasks that
    // were run.
});

// Runs all tasks
tasks.run(function(err) {

});

// Run multiple tasks
tasks.run(['file', ...], function(err) {

});

Reference

TaskGroup()

This is the main class to use to manage the tasks. It contains an object containing the task names mapped to their dependencies and actions. The TaskGroup constructor is the only export from the module.

#task(name, [dependencies], [action])

This method registers a task with the specified name. The name must be a string. Dependencies can be specified as an array containing the names of tasks that must be run before this task. If dependencies is omitted, it is assumed that there are not dependencies. action is a function that will be called when the task is to be run. It will be provided a callback function that it must call when the task is complete, optionally passing an error to it.

#run([tasks], [callback])

Runs the specified tasks. tasks can be a single string or an array of strings specifying all the tasks to run. If tasks is null or omitted, it will run all the registered tasks. callback is a function that is called when all tasks are complete, with the first parameter being the error if an error occured, or null.