0.1.3 • Published 10 years ago

rcloader2 v0.1.3

Weekly downloads
2
License
MIT
Repository
github
Last release
10 years ago

rcloader

Travis CI

For build system plugins that need to fetch relative config files (like .jshintrc).

Features

  • Find the closest config file (like .jshintrc) relative to the file you are linting
  • Lookups are cahched to limit IO operations
  • Accepts input directly from plugin consumers to
    • specifiy a file that should always be used
    • specify overrides
    • disable file lookup

Install

npm install rcloader

Use

This plugin was written to specifcally address this issue for a couple gulp plugins.

within a gulp plugin

var RcLoader = require('rcloader');
var map = require('map-stream');

module.exports = function MyGulpPlugin(options) {
  var rcLoader = new RcFinder('.configfilename', options);

  return map(function (file, cb) {
    // get the options for this file specifically
    rcLoader.for(file.path, function (err, fileOpts) {
      // do something cool

      // send the file along
      cb(null, file);
    });
  });
};

If you would rather, just skip the callback and it will run synchronously.

var fileOpts = rcLoader.for(file.path, options);

Options

The second argument to the RcFinder constructor should be the options that plugin consumers define, and they can take can take a few different forms.

If the user specifies a string, it is used as a path to the only config file that they care about. Calling rcLoader.for(path) will always return a copy of the config file at that path.

If the user specifies an object, the following keys will be striped from it and the remaining values will override values found in the config files.

  • lookup, Boolean, Find the closest config file each time .for() is called. default is true, unless config is a path.