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.
rcloader
For build system plugins that need to fetch relative config files (like .jshintrc).
Features
Install
Use
This plugin was written to specifcally address this issue for a couple gulp plugins.
within a gulp plugin
If you would rather, just skip the callback and it will run synchronously.
Options
The second argument to the
RcFinderconstructor 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.