JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 89457
  • Score
    100M100P100Q43797F
  • License MIT

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

Package Exports

  • rcloader

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (rcloader) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

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.