node-find-files
TypeScript icon, indicating that this package has built-in type declarations

1.0.0 • Public • Published

node-find-files

This is a quick utility I wrote for recursively searching a directory structure and finding files and directories that match a particular spec.

What's Different About it

Similar projects that I was able to find processed the whole directory tree and then handed a set of results back at the end. This module inherits from EventEmitter so it will begin streaming results as soon as the first one is found.

My initial use case was to find files modified since a particular date, but you can also pass a filter function to return files that match any criteria you can find on the fs.stat object in node.

Usage:

var FindFiles = require("node-find-files").default;


var d = new Date()
d.setDate(d.getDate() - 1);

var finder = new FindFiles({
    rootFolder : "/Users",
    fileModifiedDate : d
});

finder.on("match", function(strPath, stat) {
    console.log(strPath + " - " + stat.mtime);
})
finder.on("complete", function() {
    console.log("Finished")
})
finder.on("patherror", function(err, strPath) {
    console.log("Error for Path " + strPath + " " + err)  // Note that an error in accessing a particular file does not stop the whole show
})
finder.on("error", function(err) {
    console.log("Global Error " + err);
})
finder.startSearch();

OK but give me more Power

You can set up the finder object with any filter function you like

//  Alternate Usage to achieve the same goal, but you can use any of the properties of the fs.stat object or the path to do your filtering
var finder = new FindFiles({
    rootFolder : "/Users",
    filterFunction : function (path, stat) {
        return (stat.mtime > d) ? true : false;
    }
});

What's new in version 1.0.0?

Main breaking change is that there was previously an export called finder that could be imported as

import {finder} from "node-find-files";.

This has been removed now due to an update in tooling so some examples of importing it properly are:

import finder from "node-find-files"; or;

const finder = require("node-find-files");

Otherwise it is mainly a bug fix release with a few minor refactorings to support the new tooling.

Versions

Current Tags

VersionDownloads (Last 7 Days)Tag
1.0.0230latest

Version History

VersionDownloads (Last 7 Days)Published
1.0.0230
0.0.42,233
0.0.31
0.0.260
0.0.16

Package Sidebar

Install

npm i node-find-files

Weekly Downloads

2,295

Version

1.0.0

License

BSD

Unpacked Size

11.6 kB

Total Files

5

Last publish

Collaborators

  • sudsy