@atomist/sdm-pack-aspect
Version:
an Atomist SDM Extension Pack for visualizing drift across an organization
91 lines • 4.13 kB
JavaScript
;
/*
* 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