projen
Version:
CDK for software projects
110 lines • 12.8 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.IgnoreFile = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const file_1 = require("./file");
const util_1 = require("./util");
class IgnoreFile extends file_1.FileBase {
/**
*
* @param project The project to tie this file to.
* @param filePath - the relative path in the project to put the file
* @param minify - whether comments/blank lines should be filtered
*/
constructor(project, filePath, options) {
super(project, filePath, { editGitignore: filePath !== ".gitignore" });
this.filterCommentLines = options?.filterCommentLines ?? true;
this.filterEmptyLines = options?.filterEmptyLines ?? true;
this._patterns = options?.ignorePatterns ?? [];
}
/**
* Add ignore patterns. Files that match this pattern will be ignored. If the
* pattern starts with a negation mark `!`, files that match will _not_ be
* ignored.
*
* Comment lines (start with `#`) and blank lines ("") are filtered by default
* but can be included using options specified when instantiating the component.
*
* @param patterns Ignore patterns.
*/
addPatterns(...patterns) {
for (const pattern of patterns) {
const isComment = pattern.startsWith("#");
const isEmptyLine = Boolean(pattern.trim().length === 0);
if (isComment && this.filterCommentLines) {
continue;
}
if (isEmptyLine && this.filterEmptyLines) {
continue;
}
if (!isComment && !isEmptyLine) {
this.normalizePatterns(pattern);
}
const normalizedPattern = (0, util_1.normalizePersistedPath)(pattern);
this._patterns.push(normalizedPattern);
}
}
normalizePatterns(pattern) {
const opposite = pattern.startsWith("!") ? pattern.slice(1) : "!" + pattern;
remove(this._patterns, pattern); // prevent duplicates
remove(this._patterns, opposite);
if (pattern.endsWith("/")) {
const prefix = opposite;
for (const p of [...this._patterns]) {
if (p.startsWith(prefix)) {
remove(this._patterns, p);
}
}
}
}
/**
* Removes patterns previously added from the ignore file.
*
* If `addPattern()` is called after this, the pattern will be added again.
*
* @param patterns patters to remove.
*/
removePatterns(...patterns) {
for (const p of patterns) {
remove(this._patterns, p);
}
}
/**
* Ignore the files that match these patterns.
* @param patterns The patterns to match.
*/
exclude(...patterns) {
return this.addPatterns(...patterns);
}
/**
* Always include the specified file patterns.
* @param patterns Patterns to include in git commits.
*/
include(...patterns) {
for (let pattern of patterns) {
if (!pattern.startsWith("!")) {
pattern = "!" + pattern;
}
this.addPatterns(pattern);
}
}
synthesizeContent(resolver) {
const lines = [
...(this.marker ? [`# ${this.marker}`] : []),
...this._patterns,
];
return `${resolver.resolve(lines).join("\n")}\n`;
}
}
exports.IgnoreFile = IgnoreFile;
_a = JSII_RTTI_SYMBOL_1;
IgnoreFile[_a] = { fqn: "projen.IgnoreFile", version: "0.99.51" };
// O(n) hooray!
function remove(arr, value) {
const idx = arr.indexOf(value);
if (idx >= 0) {
arr.splice(idx, 1);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ignore-file.js","sourceRoot":"","sources":["../src/ignore-file.ts"],"names":[],"mappings":"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","sourcesContent":["import type { IResolver } from \"./file\";\nimport { FileBase } from \"./file\";\nimport type { Project } from \"./project\";\nimport { normalizePersistedPath } from \"./util\";\n\nexport interface IgnoreFileOptions {\n  /**\n   * Filter out comment lines?\n   *\n   * @default true\n   */\n  readonly filterCommentLines?: boolean;\n\n  /**\n   * Filter out blank/empty lines?\n   *\n   * @default true\n   */\n  readonly filterEmptyLines?: boolean;\n\n  /**\n   * Patterns to add to the ignore file\n   *\n   * @default []\n   */\n  readonly ignorePatterns?: string[];\n}\n\nexport class IgnoreFile extends FileBase {\n  private readonly _patterns: string[];\n  public readonly filterCommentLines: boolean;\n  public readonly filterEmptyLines: boolean;\n\n  /**\n   *\n   * @param project The project to tie this file to.\n   * @param filePath - the relative path in the project to put the file\n   * @param minify - whether comments/blank lines should be filtered\n   */\n  constructor(project: Project, filePath: string, options?: IgnoreFileOptions) {\n    super(project, filePath, { editGitignore: filePath !== \".gitignore\" });\n    this.filterCommentLines = options?.filterCommentLines ?? true;\n    this.filterEmptyLines = options?.filterEmptyLines ?? true;\n    this._patterns = options?.ignorePatterns ?? [];\n  }\n\n  /**\n   * Add ignore patterns. Files that match this pattern will be ignored. If the\n   * pattern starts with a negation mark `!`, files that match will _not_ be\n   * ignored.\n   *\n   * Comment lines (start with `#`) and blank lines (\"\") are filtered by default\n   * but can be included using options specified when instantiating the component.\n   *\n   * @param patterns Ignore patterns.\n   */\n  public addPatterns(...patterns: string[]) {\n    for (const pattern of patterns) {\n      const isComment = pattern.startsWith(\"#\");\n      const isEmptyLine = Boolean(pattern.trim().length === 0);\n      if (isComment && this.filterCommentLines) {\n        continue;\n      }\n      if (isEmptyLine && this.filterEmptyLines) {\n        continue;\n      }\n      if (!isComment && !isEmptyLine) {\n        this.normalizePatterns(pattern);\n      }\n\n      const normalizedPattern = normalizePersistedPath(pattern);\n\n      this._patterns.push(normalizedPattern);\n    }\n  }\n\n  private normalizePatterns(pattern: string) {\n    const opposite = pattern.startsWith(\"!\") ? pattern.slice(1) : \"!\" + pattern;\n    remove(this._patterns, pattern); // prevent duplicates\n    remove(this._patterns, opposite);\n\n    if (pattern.endsWith(\"/\")) {\n      const prefix = opposite;\n      for (const p of [...this._patterns]) {\n        if (p.startsWith(prefix)) {\n          remove(this._patterns, p);\n        }\n      }\n    }\n  }\n\n  /**\n   * Removes patterns previously added from the ignore file.\n   *\n   * If `addPattern()` is called after this, the pattern will be added again.\n   *\n   * @param patterns patters to remove.\n   */\n  public removePatterns(...patterns: string[]) {\n    for (const p of patterns) {\n      remove(this._patterns, p);\n    }\n  }\n\n  /**\n   * Ignore the files that match these patterns.\n   * @param patterns The patterns to match.\n   */\n  public exclude(...patterns: string[]) {\n    return this.addPatterns(...patterns);\n  }\n\n  /**\n   * Always include the specified file patterns.\n   * @param patterns Patterns to include in git commits.\n   */\n  public include(...patterns: string[]) {\n    for (let pattern of patterns) {\n      if (!pattern.startsWith(\"!\")) {\n        pattern = \"!\" + pattern;\n      }\n\n      this.addPatterns(pattern);\n    }\n  }\n\n  protected synthesizeContent(resolver: IResolver): string | undefined {\n    const lines = [\n      ...(this.marker ? [`# ${this.marker}`] : []),\n      ...this._patterns,\n    ];\n\n    return `${resolver.resolve(lines).join(\"\\n\")}\\n`;\n  }\n}\n\n// O(n) hooray!\nfunction remove<T>(arr: T[], value: any) {\n  const idx = arr.indexOf(value);\n  if (idx >= 0) {\n    arr.splice(idx, 1);\n  }\n}\n"]}