UNPKG

@atomist/sdm-pack-aspect

Version:

an Atomist SDM Extension Pack for visualizing drift across an organization

91 lines 4.13 kB
"use strict"; /* * Copyright © 2019 Atomist, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const projectUtils_1 = require("@atomist/automation-client/lib/project/util/projectUtils"); const sdm_pack_fingerprint_1 = require("@atomist/sdm-pack-fingerprint"); function isGlobMatchFingerprint(fp) { const maybe = fp.data; return !!maybe && maybe.kind === "glob" && !!maybe.glob && maybe.matches !== undefined; } exports.isGlobMatchFingerprint = isGlobMatchFingerprint; function isExtracted(gao) { const maybe = gao; return !!maybe.extract; } /** * Check for presence of a glob. * Always extracts a fingerprint, but may have an empty array of matches. * Entropy stat is disabled by default, but callers can override this. * Can optionally test file content to exclude matches, or extract additional data for * each match with the extract method. */ function globAspect(config) { if (!config.glob) { throw new Error("Glob pattern must be supplied"); } return Object.assign(Object.assign({ toDisplayableFingerprintName: name => `Glob pattern '${name}'`, toDisplayableFingerprint: fp => fp.data.matches.length === 0 ? "None" : fp.data.matches .map(m => `${m.path}(${m.size})`) .join(), stats: { defaultStatStatus: { entropy: false, }, } }, config), { extract: (p) => __awaiter(this, void 0, void 0, function* () { const data = { glob: config.glob, kind: "glob", matches: yield projectUtils_1.gatherFromFiles(p, config.glob, (f) => __awaiter(this, void 0, void 0, function* () { const content = yield f.getContent(); if (isExtracted(config)) { const extracted = yield config.extract(content, f.path); return extracted ? Object.assign({ path: f.path, size: content.length }, extracted) : undefined; } else { const testToUse = config.contentTest || (() => true); return testToUse(content, f.path) ? { path: f.path, size: content.length, } : undefined; } })), }; return sdm_pack_fingerprint_1.fingerprintOf({ type: config.name, data, }); }) }); } exports.globAspect = globAspect; /** * Count the number of glob matches of the given type */ function countGlobMatches(fps, type) { const matches = fps.find(fp => fp.type === type && isGlobMatchFingerprint(fp)); return matches ? matches.data.matches.length : 0; } exports.countGlobMatches = countGlobMatches; //# sourceMappingURL=globAspect.js.map