8ff885a3a8
Closes #17 Implements the IsGenerated helper function to filter out generated files using the rules and matchers in: - https://github.com/github/linguist/blob/master/lib/linguist/generated.rb Since the vast majority of matchers have very different logic, it cannot be autogenerated directly from linguist like other logics in enry, so it's translated by hand. There are three different types of matchers in this implementation: - By extension, which mark as generated based only in the extension. These are the fastest matchers, so they're done first. - By file name, which matches patterns against the filename. These are performed in second place. Unlike linguist, we try to use string functions instead of regexps as much as possible. - Finally, the rest of the matchers, which go into the content and try to identify if they're generated or not based on the content. Unlike linguist, we try to only read the content we need and not split it all unless it's necessary and use byte functions instead of regexps as much as possible. Signed-off-by: Miguel Molina <miguel@erizocosmi.co>
93 lines
2.3 KiB
JavaScript
93 lines
2.3 KiB
JavaScript
(function(root, factory) {
|
|
if (typeof define === 'function' && define.amd) {
|
|
define(['lodash'], factory);
|
|
} else if (typeof exports !== 'undefined') {
|
|
module.exports = factory(require('lodash'));
|
|
} else {
|
|
root.Namespace = factory(root._);
|
|
}
|
|
})(this, function(_) {
|
|
'use strict';
|
|
|
|
/**
|
|
* @module namespace
|
|
* @class namespace
|
|
*/
|
|
function Namespace() {}
|
|
|
|
/**
|
|
* Regex for splitting keypaths into arrays.
|
|
*
|
|
* @private
|
|
* @const {RegExp}
|
|
* @type
|
|
*/
|
|
var KEYPATH_SPLITTER = /\./g;
|
|
|
|
/**
|
|
* An internal cache to avoid calculating a keypath more than once.
|
|
*
|
|
* @private
|
|
* @type {Object}
|
|
*/
|
|
var _keypaths = {};
|
|
|
|
_.extend(Namespace.prototype, {
|
|
|
|
/**
|
|
* Adds a definition to the namespace object.
|
|
*
|
|
* @public
|
|
* @instance
|
|
* @method add
|
|
* @param {String} keypath - The keypath for the definition to be added at.
|
|
* @param {Function|Object} definition - The definition to be added.
|
|
* @return {Function|Object} - The definition.
|
|
*/
|
|
add: function(keypath, definition) {
|
|
return this._walk(keypath, function(memo, name, index, keypath) {
|
|
if (index + 1 === keypath.length) {
|
|
memo[name] = _.extend(definition, memo[name]);
|
|
}
|
|
return memo[name] || (memo[name] = {});
|
|
});
|
|
},
|
|
|
|
/**
|
|
* Retrieves a definition from the namespace safely.
|
|
*
|
|
* @public
|
|
* @instance
|
|
* @method get
|
|
* @param {String} keypath - The keypath to lookup a definition for.
|
|
* @returns {Function|Object|undefined} - The definition if it exists, otherwise `undefined`.
|
|
*/
|
|
get: function(keypath) {
|
|
return this._walk(keypath);
|
|
},
|
|
|
|
/**
|
|
* An internal function for walking a keypath.
|
|
*
|
|
* @private
|
|
* @instance
|
|
* @method _walk
|
|
* @param {String} keypath - The keypath to walk through.
|
|
* @param {Function} [callback] - An optional callback to be called at each item in the path.
|
|
* @returns {function|Object|undefined} - The reduced keypath.
|
|
*/
|
|
_walk: function(keypath, callback) {
|
|
return _.reduce(
|
|
_keypaths[keypath] || (_keypaths[keypath] = keypath.split(KEYPATH_SPLITTER)),
|
|
callback || function(memo, name) {
|
|
return memo && memo[name];
|
|
},
|
|
this
|
|
);
|
|
}
|
|
});
|
|
|
|
return Namespace;
|
|
});
|
|
|
|
//# sourceMappingURL=namespace.js.map
|