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

octopus-async

v0.1.2

Published

Simple asynchronous helpers

Downloads

10

Readme

Octopus

   /\
 ∠___ゝ  
 )|’ー’| / 
(ノノノ从し' 

Deprecation

Note: this package is deprecated. If you need to do asynchronous tasks you should use promises and/or async/await syntax which should work in all modern browsers as well as in the latest versions of node.js.

You could achieve the same thing as octopus natively:

octopus.run

const results = await Promise.all([one(), two()]);

// or

const [result1, result2] = await Promise.all([one(), two()]);

octopus.step

const calls = [one, two, three];
let value;
for (const call of calls) {
    value = await call(value);
}

Octopus is a couple of simple asynchronous helper functions. It is designed for use in the browser and is < 500 bytes gzipped. It works in node.js as well.

It is available in NPM

npm install octopus-async

There are two calls

octopus.run

Run a bunch of functions in parallel and receive a callback with the results of all of them.

var calls = [
    function one(callback) {
        setTimeout(function() {
            callback(10);
        }, 200);
    },
    function two(callback) {
        callback(20);
    }
];

octopus.run(calls, function(results) {
    console.log(results); // [10, 20]
});

Notice that even though function one finished after function two the results still come back in the order you passed the functions in originally.

You can also pass in an object with names as the keys

var calls = {
    one: function(callback) { callback(10); },
    two: function(callback) { callback(20); }
};

octopus.run(calls, function(results)) {
    console.log(results); // {one: 10, two: 20}
});

octopus.step

Steps through functions one after the other passing the result from one function to the next.

var calls = [
    function one(callback) {
        callback(10);
    },
    function two(value, callback) {
        callback(value * 2);
    },
    function three(value, callback) {
        callback(value * 3);
    }
];

octopus.step(calls, function(result) {
    console.log(result); // 60
});

To achieve the same thing with those 3 functions in vanilla Javascript you would have to do something like

one(function(result) {
    two(result, function(result) {
        three(result, function(result) {
            console.log(result);
        });
    });
});

Note about using with node

In node.js the convention is to pass back an error before the actual result in callback functions. To use any of the above examples in node, just be consistent and pass back an error argument as the first argument in your callbacks.

Octopus will stop running and fire the final callback as soon as it receives an error. In the step call it will stop after the step that errored. In the run call it will fire the callback with the error, but the other calls will continue running until they finish. There is no easy way to cancel a function from executing.