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

throque

v1.0.5

Published

Simple async function decorator which limits how many invocations of said function can be active at once.

Downloads

23

Readme

throque

Simple async function decorator which limits how many invocations of said function can be active at once.

Pronounced: throck

Etymology: Throttle + Queue = throque

Installation and usage

yarn add throque or npm install --save throque

const throque = require('throque');
const writeFileThroqued = throque(fs.writeFile, 200, false);

History

throque was born from this pesky Node.js error: Error: EMFILE: too many open files. This error gets thrown when Nodes' file-system module has too many open files at once (obviously.) throque alleviates this problem by creating a decorated version of your function which Queues excessive calls until the appropriate conditions are met.

Example

This snippet throws the error mentioned above:

for (let i = 0; i < 10000; i += 1) {
  fs.readFile(filePath, { encoding: 'utf8' }, err => {
    if (err) throw err;
  });
}

throque to the rescue:

const throque = require('throque');
const readFileThroqued = throque(fs.readFile, 200, false);

for (let i = 0; i < 10000; i += 1) {
  readFileThroqued(filePath, { encoding: 'utf8' }) // We can still pass the same arguments to fs.readFile (but not the callback)
    .then(console.log)   // That's a lot of logs
    .catch(console.log); // No error! :)
}

Notice how we are no longer using callbacks when using a throqued function. This is because throque will promisify your functiontoThrottle if you set the returnsPromise argument to false. There are some important things to note when setting this flag to false however (see API below.)

API

throque currently exports a single function which is relatively simple to use.

throttleAndQueue aka throque

throque(functionToThrottle, maxConcurrentCalls, returnsPromise);

Parameters

functionToThrottle: function
maxConcurrentCalls: number (default: 100)
  • Maximum amount of invocations of the throttled function that can be active at any given time.
returnsPromise: boolean (default: true)
  • Indicates whether or not your functionToThrottle returns a promise (true) or calls a callback when finished (false).
  • If this flag is set to false, there are some important things to note:
    • The returned throttled function will be a promisified version of functionToThrottle.
    • functionToThrottle must follow the Node.js error-first callback pattern, or the internal promisification will fail. Even though Node native library methods should all work perfectly fine this way, it is recomended to not set this value to false (which means your functiontoThrottle returns a promise.)
    • If your functionToThrottle only passes a single argument to its' callback, your promisified function will resolve with this value, otherwise it will resolve with an array of values in the same order that would of been passed into the callback. You can use destructuring assignment to mimic the callback signature.

Plans for the future

Tests

Currently throque is not tested, but tests will be added soon, and future additions to the library will be developed test-first.

Extensive error handling

Although tracking errors at the time of writing should be extremely simple (the library is very small), more robust and descriptive error handling will be added.

Features

  • Ability to group multiple functionsToThrottle into one throttle-queue.

  • Tracking calls made and ability to generate reports.