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 🙏

© 2026 – Pkg Stats / Ryan Hefner

astalim

v1.0.3

Published

A lightweight async task limiter. Run asynchronous operations with controlled concurrency and minimal overhead.

Readme

Русский

ASync TAsk LIMiter

(Parallel manager for asynchronous tasks with a limit on the number of concurrently executing tasks)

import astalim from "astalim"

// Number of concurrently running tasks
const limit: number = 5

// Create task executor
const tasks = astalim.taskPool(limit)

// Add tasks in a loop
for (const path of <paths>) {
  await tasks.addTask(async () => {
    ...
    <Some work with the current path>
    ...
  })
}

// Get processing result
const results = await tasks.waitResult()

1. Creating the Executor

const tasks = astalim.taskPool(limit: number)

At most limit tasks will be running concurrently.

2. Adding Tasks

for (const path of <paths>) {
  await tasks.addTask(async () => {
    ...
    <Some work with the current path>
    ...
  })
}

The addTask method accepts either a Promise or a function that returns a Promise. Once the limit is reached, the next task will not start until space in the pool is freed and it's added to the pool.

🔴 IMPORTANT: Regardless of what happens inside a task, the main execution flow will not be interrupted. All thrown exceptions (errors) will silently be recorded in the result’s shared error array.

3. Getting the Result

const results = await tasks.waitResult()

Waits for all tasks to fully complete and returns the results. The results object contains two arrays:

  • successful: results of successfully completed tasks,
  • failed: array of errors, where each object includes:
    • error: the error description,
    • index: index of the task (in the order they were added).

⚠️ The waitResult() call resets the internal state, so you can reuse addTask() afterward without creating a new tasks instance.

import astalim from "astalim"

// Task executor with a pool of 3 tasks
const tasks = astalim.taskPool(3)

// Generator for pseudo-random events
function* randGen() {
  let i = 0
  while (i++ < 10) yield Math.random()
}

// Task handling
for (const rand of randGen()) {
  await tasks.addTask(async () => {
    // Successful task execution, return data
    if (rand > .5) return rand
    // Failed execution, trigger error
    else JSON.parse("") // OR else throw `Error: ${rand}`
  })
}

// Get result
const results = await tasks.waitResult()

console.log("results:", results)

Expected Output:

results: {
  successful: [
    0.5774501276332757,
    0.8140335738582891,
    0.9180485044161926,
    0.9421955524500936,
    0.8163302889107125,
    0.8032588867553216,
    0.783284406112269
  ],
  failed: [
    {
      error: SyntaxError: Unexpected end of JSON input
          at JSON.parse (<anonymous>)
          ...
      index: 1
    },
    {
      error: SyntaxError: Unexpected end of JSON input
          at JSON.parse (<anonymous>)
          ...
      index: 2
    },
    {
      error: SyntaxError: Unexpected end of JSON input
          at JSON.parse (<anonymous>)
          ...
      index: 4
    }
  ]
}