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 🙏

© 2025 – Pkg Stats / Ryan Hefner

for-each-project

v0.6.1

Published

Processes a set of project directories defined in a package.json file

Downloads

67

Readme

for-each-project

for-each-project npm package version for-each-project License: GPLv3 for-each-project monthly downloads Follow this project on Twitter

Processes a set of project directories defined in a package.json file

About

for-each-project is one of several utility packages in the buildverse tool suite. It is a command-line utility that is intended to be invoked as part of an npm package script to process a set of project directories defined in the enclosing package.json file.

To see how some projects are using for-each-project, peruse the package.json files the following projects. Note that these projects will generally contain several package.json files spread across different folders within the project.

Like the concept of this project? Let other developers know with a tweet.

Installing

for-each-project requires

and, at your option, any of these package managers:

  • npm version 5.3.0+
  • pnpm version 1.16.0+
  • yarn version 1.1.0+

This package is automatically installed alongside all other packages in the buildverse tool suite with the single install command

npm install --save-dev buildverse

though it can be installed and used separately on its own by

npm install --save-dev for-each-project

if you wish to use it standalone.

Note the use of --save-dev since buildverse tool suite packages are typically used during development as opposed to being deployed in production, runtime environment.

Using

The following demonstration is for a Linux terminal session. Use on Windows systems is the same, albeit modulo Windows command-line idiosyncrasies such as the use of backslashes ('\') versus foreslashes ('/') for path separators, etc.

Commands

# Create a directory as a top-level development project,
# change into that directory and initialize a
# package.json file.
$ mkdir foobar-project
$ cd foobar-project
$ npm init -y

# Choose only one of the following install commands:
$ npm install --save-dev buildverse
# or
$ npm install --save-dev for-each-project

# Create a subdirectory as a subproject/package, change
# into that directory and initialize a package.json
# file.
$ mkdir foo
$ cd foo
$ npm init -y
$ cd ..

# For the purpose of this example, repeat for a second
# subproject/package.
$ mkdir bar
$ cd bar
$ npm init -y
$ cd ..

Result

At this point the foobar-project directory layout is:

foobar-project/
  bar/
    package.json
  foo/
    package.json
  node_modules/
    ...
  package.json
  package-lock.json

Configure package.json to use for-each-project

Now edit foobar-project/package.json making these changes:

  1. add a private property with the value true,
  2. change the test script to for-each-project apply-cmdline, and
  3. add a buildverse section containing an array of subproject names (["foo", "bar"]) under the key, subprojects.

The result should look something like this (irrelevant fields omitted):

foobar-project/package.json:

{
  "private": true,
  "name": "foobar-project",
  "version": "1.0.0",
  "scripts": {
    "test": "for-each-project apply-cmdline"
  },
  "devDependencies": {
    "for-each-project": "^0.2.20"
  },
  "buildverse": {
    "subprojects": [
      "foo",
      "bar"
    ]
  }
}

Commands

From the command line now run the npm test script (while still in the foobar-project directory).

$ npm test

Output

> [email protected] test /home/.../tmp/foobar-project
> for-each-project apply-cmdline

(cd foo && /usr/lib/node_modules/npm/bin/npm-cli.js test)

> [email protected] test /home/.../tmp/foobar-project/foo
> echo "Error: no test specified" && exit 1

Error: no test specified
npm ERR! Test failed.  See above for more details.
npm ERR! Test failed.  See above for more details.

Notice what happened. The effect of for-each-project apply-cmdline was to cause the shell to change into the foo subdirectory and execute the test script contained in the package.json file from that directory. At that point the npm test command abruptly ended with Test failed errors. This is because foo's test script shell command exited with code 1 which indicates failure:

echo \"Error: no test specified\" && exit 1`

Let's change that outcome to achieve a successful run. Edit the test script in both foo/package.json and bar/package.json to now read:

foo/package.json:

  "scripts": {
    "test": "echo testing-foo-subproject"
  }

bar/package.json:

  "scripts": {
    "test": "echo testing-bar-subproject"
  }

Commands

The effect now of running npm test from (the parent) directory foobar-project is that both subproject (child) directories foo and bar are visted and their respective test scripts are executed (since both their associated shell commands exited with code 0 which indicates success).

$ npm test

Output

> [email protected] test /home/.../tmp/foobar-project
> for-each-project apply-cmdline

(cd foo && /usr/lib/node_modules/npm/bin/npm-cli.js test)

> [email protected] test /home/.../tmp/foobar-project/foo
> echo testing-foo-subproject

testing-foo-subproject
(cd bar && /usr/lib/node_modules/npm/bin/npm-cli.js test)

> [email protected] test /home/.../tmp/foobar-project/bar
> echo testing-bar-subproject

testing-bar-subproject

Summary

Summing up, when used in an npm package script for-each-project apply-cmdline does the following things:

  1. Consults the package.json file in the current working directory for a special configuration object under the key buildverse. This object contains an array, subprojects, of directory pathnames representing (sub)projects. The pathnames are relative to the location of the containing package.json file.
  2. Each directory entry in this array is then processed by:
  • Changing the current working directory to the given directory
  • Recursively executing the package manager program (npm, pnpm or yarn) with the same command line arguments that it was originally executed with.

If for-each-project is invoked with the --reverse switch, the directory set is processed in reverse order.

This is the bare bones of information you need to start using for-each-project in your own npm package scripts. See the Command-line Usage Docs section for detailed information about the for-each-project command.

Command-line Usage Docs

Support

If you run into any problems or have constructive criticism, suggestions for improvement or just plain encouragement to offer please open or comment on an issue on GitHub.

**Note that issues are managed under the buildverse-sdk umbrella project. **

You can also show your support for this project by following BuildverseJS, @buildverse on Twitter or simply by letting other developers know with a tweet.

License

Currently this project is licensed GPLv3.

The author is working however towards gaining community-funding so as to make this a successful and sustainable, quality open-source project with an MIT license.

Copyright © 2017 Justin Johansson (https://github.com/indiescripter).