0.1.5 • Published 10 years ago

findup v0.1.5

Weekly downloads
367,174
License
-
Repository
github
Last release
10 years ago

build status

Find-up

Install

npm install -g findup

Usage

Find up a file in ancestor's dir

.
├── config.json
└── f
    └── e
        └── d
            └── c
                ├── b
                │   └── a
                └── config.json

Async

findup(dir, fileName, callback) findup(dir, iterator, callback) with iterator(dir, cb) where cb only accept true or false

var findup = require('findup');


findup(__dirname + '/f/e/d/c/b/a', 'config.json', function(err, dir){
  // if(e) e === new Error('not found')
  // dir === '/f/e/d/c'
});

or

findup(__dirname + '/f/e/d/c/b/a', function(dir, cb){
  require('path').exists(dir + '/config.json', cb);
}, function(err, dir){
  // if(e) e === new Error('not found')
  // dir === '/f/e/d/c'
});

EventEmitter

findup(dir, fileName)

var findup = require('findup');
var fup = findup(__dirname + '/f/e/d/c/b/a', 'config.json');

findup(dir, iterator) with iterator(dir, cb) where cb only accept true or false

var findup = require('findup');
var fup = findup(__dirname + '/f/e/d/c/b/a', function(dir, cb){
  require('path').exists(dir + '/config.json', cb);
});

findup return an EventEmitter. 3 events are emitted: found, error, end

found event is emitted each time a file is found.

You can stop the traversing by calling stop manually.

fup.on('found', function(dir){
  // dir === '/f/e/d/c'
  fup.stop();
});

error event is emitted when error happens

fup.on('error', function(e){
  // if(e) e === new Error('not found')
});

end event is emitted at the end of the traversing or after stop() is called.

fup.on('end', function(){
  // happy end
});

Sync

findup(dir, fileName) findup(dir, iteratorSync) with iteratorSync return true or false

var findup = require('findup');

try{
  var dir = findup.sync(__dirname + '/f/e/d/c/b/a', 'config.json'); // dir === '/f/e/d/c'
}catch(e){
  // if(e) e === new Error('not found')
}

CLI

npm install -g findup

$ cd test/fixture/f/e/d/c/b/a/
$ findup package.json
/root/findup/package.json

Usage

$ findup -h

Usage: findup [FILE]

    --name, -n       The name of the file to found
    --dir, -d        The directoy where we will start walking up    $PWD
    --help, -h       show usage                                     false
    --verbose, -v    print log                                      false

LICENSE MIT

Read the tests :)

@texttree/demo-bsa-reference-rclnpm-globfdt-react-styleguidist@infinitebrahmanuniverse/nolb-find@everything-registry/sub-chunk-1669@314oner_npm/universal-components-library@dvhb/cli@dvhb/webpack@effectfuljs/compilervue-component-docsvue-styleguidistvue-styleguidist-jimmyvue-styleguidist2whechwhoshomewebgl-workshopvx-confwitchthickshakethe-healthtfux-command-inittsdmeslint-plugin-implicit-dependencies@fable/eslint-plugin-implicit-dependencieseslint-plugin-undocumented-envuse-importvisualtesting-adminvisualtesting-apivalidate-commit-msgvalidate-commit-msg-regexpvalidate-commit-msg-smartvalidate-commit-msg-yqbvenus-confuniversal-clifekeyfekey-command-initfile-deployfe@itwin/core-webpack-toolssvn-project-rootcldr-clicleaproondeviantpublish-if-neededqlik-templatereact-styleguidistreact-styleguidist-extendedreact-styleguide-enterpriseregular-weaselresolve-recurserollup-plugin-inline-postcsssenro-command-initsailfish-reloadsane-clisassdoc-webpack-loaderscoped-bulkrn-storybook-loaderslack-wrapsourcejs-react-styleguidistsran.nvimstyle-depsstart-starwars-libstrict-requirebower-install-lowest@omneedia/npm-sass@mavenlink/react-styleguidist@matthieulemoine/react-styleguidistgitconfig-allgit-modulesez-changelog@jsmaestro/commit-validateformily-ant-mobile-componentsgenerator-log-wp-plugin@phoenix-plugin-registry/globexdesigns.brackets-jscsgrunt-laxarjson-packagekss-loaderkintsugi-build@bentley/webpack-tools-core@bitionaire/react-styleguidist@atakama/qtestng-cli-2nemoblanditiisngcli-task-runnerbodhi-cli@axelhzf/react-styleguidist-ts@aws/pdkawemxd-command-initmxt-command-initmvn-deploy-filemya-command-vuedocmya-command-initloballjve-idenpm-install-if-needednpm-payload-testnpm-quick-runnpm-sass
0.1.5

10 years ago

0.1.4

10 years ago

0.1.3

11 years ago

0.1.2

12 years ago

0.1.1

12 years ago

0.1.0

12 years ago