tracey-cli
Version:
A markdown-based requirements tool
33 lines (32 loc) • 1.53 kB
JavaScript
;
var __spreadArrays = (this && this.__spreadArrays) || function () {
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
for (var r = Array(s), k = 0, i = 0; i < il; i++)
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
r[k] = a[j];
return r;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.createCollector = void 0;
var glob_1 = require("glob");
var ignore_1 = __importDefault(require("ignore"));
var Condition_1 = require("./Condition");
/**
* Create a collector
* A collector recursivley walks the file system from given configured startingpoints
* collecting all files that pass all conditions
* @param configuration The collector configuration
* @param conditions A list of collector conditions
*/
var createCollector = function (configuration, conditions) {
var filter = ignore_1.default().add(configuration.excludes); /** @requirement #[ Requirement.Collect, Annotation.Collect ]# #( Files must not be excluded )# */
var allFiles = configuration.startingpoints.reduce(function (result, startingpoint) {
var files = glob_1.glob.sync(startingpoint, { nodir: true });
return __spreadArrays(result, files);
}, []);
return filter.filter(allFiles).filter(Condition_1.and(conditions));
};
exports.createCollector = createCollector;