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

traverse-directory

v0.3.0

Published

Clone directories using copy/symlink

Readme

traverse-directory

Build
Status

Traverse directories with various ways of reading/copying/symlink directories. The intent is primarily cases where you want to do complex cloning of one directory into another.

Usage

Traverse directory is an async queue. Each operation is added to the queue (but operations run in parallel) and when no more operations are left on the queue the traverse directory is complete.

var TraverseDirectory = require('traverse-directory');

var traverse = new TraverseDirectory(
  '/path/to/source', /* source directory */
  '/path/to/dest' /* path to target */
);

// the target directory will be created if it does not exist already.

/**
Handle directories starting with the source

@param {String} source directory.
@param {String} target directory (this does not exist yet).
@param {Function} next see usage below.
*/
traverse.directory(function(source, target, next) {
  /**
  the "next" argument is a function which expects three arguments
  which handle how the source / target are handled.

  You must call next() to indicate that the item has been handled.
  If you have no action to take, just call next() with no arguments.

  @param {Function} action (see below) to handle source/target.
  @param {String} source path.
  @param {String} target path.
  */
  next(TraverseDirectory.copydir, source, target);
});

/**
Handle file found in a directory. Unlike the directory
command file is optional (though generally needed).

@param {String} source directory.
@param {String} target directory (this does not exist yet).
@param {Function} next see usage below.
*/
traverse.file(function(source, target, next) {
  // see directory
});

traverse.run(function(err) {
  // traversal is complete
});

// after run is called event listeners can be added in addition.
traverse.on('error', ...);
traverse.on('complete', ...);

Actions

The "next" argument above takes an action as the first argument.

TraverseDirectory = require('traverse-directory');
// ...

// somewhere in the directory or file methods.
next(TraverseDirectory[ACTION_NAME], source, target);

// If you are doing something inline that doesn't need handing
// off to an action, just call without arguments
next();

For examples on how to write actions see index.js.

For files:

TraverseDirectory.copyfile

copies the contents of a file

TraverseDirectory.symlinkfile

symlinks file from source to dest

For directories:

TraverseDirectory.readdir

reads all files in directory (triggers the call to traverse.file)

TraverseDirectory.copydir

Calls readdir and creates a directory in the target path. This action does not affect files.

TraverseDirectory.symlinkdir

Symlinks target directory to source directory.