@aws-cdk/core
Version:
AWS Cloud Development Kit Core Library
197 lines • 22 kB
JavaScript
var _a, _b, _c, _d;
Object.defineProperty(exports, "__esModule", { value: true });
exports.DockerIgnoreStrategy = exports.GitIgnoreStrategy = exports.GlobIgnoreStrategy = exports.IgnoreStrategy = void 0;
const jsiiDeprecationWarnings = require("../../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const path = require("path");
const dockerignore_1 = require("@balena/dockerignore");
const ignore_1 = require("ignore");
const minimatch = require("minimatch");
const options_1 = require("./options");
/**
* Represents file path ignoring behavior.
*/
class IgnoreStrategy {
/**
* Ignores file paths based on simple glob patterns.
*
* @returns `GlobIgnorePattern` associated with the given patterns.
* @param absoluteRootPath the absolute path to the root directory of the paths to be considered
* @param patterns
*/
static glob(absoluteRootPath, patterns) {
return new GlobIgnoreStrategy(absoluteRootPath, patterns);
}
/**
* Ignores file paths based on the [`.gitignore specification`](https://git-scm.com/docs/gitignore).
*
* @returns `GitIgnorePattern` associated with the given patterns.
* @param absoluteRootPath the absolute path to the root directory of the paths to be considered
* @param patterns
*/
static git(absoluteRootPath, patterns) {
return new GitIgnoreStrategy(absoluteRootPath, patterns);
}
/**
* Ignores file paths based on the [`.dockerignore specification`](https://docs.docker.com/engine/reference/builder/#dockerignore-file).
*
* @returns `DockerIgnorePattern` associated with the given patterns.
* @param absoluteRootPath the absolute path to the root directory of the paths to be considered
* @param patterns
*/
static docker(absoluteRootPath, patterns) {
return new DockerIgnoreStrategy(absoluteRootPath, patterns);
}
/**
* Creates an IgnoreStrategy based on the `ignoreMode` and `exclude` in a `CopyOptions`.
*
* @returns `IgnoreStrategy` based on the `CopyOptions`
* @param absoluteRootPath the absolute path to the root directory of the paths to be considered
* @param options the `CopyOptions` to create the `IgnoreStrategy` from
*/
static fromCopyOptions(options, absoluteRootPath) {
try {
jsiiDeprecationWarnings._aws_cdk_core_CopyOptions(options);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.fromCopyOptions);
}
throw error;
}
const ignoreMode = options.ignoreMode || options_1.IgnoreMode.GLOB;
const exclude = options.exclude || [];
switch (ignoreMode) {
case options_1.IgnoreMode.GLOB:
return this.glob(absoluteRootPath, exclude);
case options_1.IgnoreMode.GIT:
return this.git(absoluteRootPath, exclude);
case options_1.IgnoreMode.DOCKER:
return this.docker(absoluteRootPath, exclude);
}
}
}
exports.IgnoreStrategy = IgnoreStrategy;
_a = JSII_RTTI_SYMBOL_1;
IgnoreStrategy[_a] = { fqn: "@aws-cdk/core.IgnoreStrategy", version: "1.204.0" };
/**
* Ignores file paths based on simple glob patterns.
*/
class GlobIgnoreStrategy extends IgnoreStrategy {
constructor(absoluteRootPath, patterns) {
super();
if (!path.isAbsolute(absoluteRootPath)) {
throw new Error('GlobIgnoreStrategy expects an absolute file path');
}
this.absoluteRootPath = absoluteRootPath;
this.patterns = patterns;
}
/**
* Adds another pattern.
* @params pattern the pattern to add
*/
add(pattern) {
this.patterns.push(pattern);
}
/**
* Determines whether a given file path should be ignored or not.
*
* @param absoluteFilePath absolute file path to be assessed against the pattern
* @returns `true` if the file should be ignored
*/
ignores(absoluteFilePath) {
if (!path.isAbsolute(absoluteFilePath)) {
throw new Error('GlobIgnoreStrategy.ignores() expects an absolute path');
}
let relativePath = path.relative(this.absoluteRootPath, absoluteFilePath);
let excludeOutput = false;
for (const pattern of this.patterns) {
const negate = pattern.startsWith('!');
const match = minimatch(relativePath, pattern, { matchBase: true, flipNegate: true });
if (!negate && match) {
excludeOutput = true;
}
if (negate && match) {
excludeOutput = false;
}
}
return excludeOutput;
}
}
exports.GlobIgnoreStrategy = GlobIgnoreStrategy;
_b = JSII_RTTI_SYMBOL_1;
GlobIgnoreStrategy[_b] = { fqn: "@aws-cdk/core.GlobIgnoreStrategy", version: "1.204.0" };
/**
* Ignores file paths based on the [`.gitignore specification`](https://git-scm.com/docs/gitignore).
*/
class GitIgnoreStrategy extends IgnoreStrategy {
constructor(absoluteRootPath, patterns) {
super();
if (!path.isAbsolute(absoluteRootPath)) {
throw new Error('GitIgnoreStrategy expects an absolute file path');
}
this.absoluteRootPath = absoluteRootPath;
this.ignore = ignore_1.default().add(patterns);
}
/**
* Adds another pattern.
* @params pattern the pattern to add
*/
add(pattern) {
this.ignore.add(pattern);
}
/**
* Determines whether a given file path should be ignored or not.
*
* @param absoluteFilePath absolute file path to be assessed against the pattern
* @returns `true` if the file should be ignored
*/
ignores(absoluteFilePath) {
if (!path.isAbsolute(absoluteFilePath)) {
throw new Error('GitIgnoreStrategy.ignores() expects an absolute path');
}
let relativePath = path.relative(this.absoluteRootPath, absoluteFilePath);
return this.ignore.ignores(relativePath);
}
}
exports.GitIgnoreStrategy = GitIgnoreStrategy;
_c = JSII_RTTI_SYMBOL_1;
GitIgnoreStrategy[_c] = { fqn: "@aws-cdk/core.GitIgnoreStrategy", version: "1.204.0" };
/**
* Ignores file paths based on the [`.dockerignore specification`](https://docs.docker.com/engine/reference/builder/#dockerignore-file).
*/
class DockerIgnoreStrategy extends IgnoreStrategy {
constructor(absoluteRootPath, patterns) {
super();
if (!path.isAbsolute(absoluteRootPath)) {
throw new Error('DockerIgnoreStrategy expects an absolute file path');
}
this.absoluteRootPath = absoluteRootPath;
this.ignore = dockerignore_1.default().add(patterns);
}
/**
* Adds another pattern.
* @params pattern the pattern to add
*/
add(pattern) {
this.ignore.add(pattern);
}
/**
* Determines whether a given file path should be ignored or not.
*
* @param absoluteFilePath absolute file path to be assessed against the pattern
* @returns `true` if the file should be ignored
*/
ignores(absoluteFilePath) {
if (!path.isAbsolute(absoluteFilePath)) {
throw new Error('DockerIgnoreStrategy.ignores() expects an absolute path');
}
let relativePath = path.relative(this.absoluteRootPath, absoluteFilePath);
return this.ignore.ignores(relativePath);
}
}
exports.DockerIgnoreStrategy = DockerIgnoreStrategy;
_d = JSII_RTTI_SYMBOL_1;
DockerIgnoreStrategy[_d] = { fqn: "@aws-cdk/core.DockerIgnoreStrategy", version: "1.204.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ignore.js","sourceRoot":"","sources":["ignore.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport dockerIgnore, * as DockerIgnore from '@balena/dockerignore';\nimport gitIgnore, * as GitIgnore from 'ignore';\nimport * as minimatch from 'minimatch';\nimport { CopyOptions, IgnoreMode } from './options';\n\n/**\n * Represents file path ignoring behavior.\n */\nexport abstract class IgnoreStrategy {\n  /**\n   * Ignores file paths based on simple glob patterns.\n   *\n   * @returns `GlobIgnorePattern` associated with the given patterns.\n   * @param absoluteRootPath the absolute path to the root directory of the paths to be considered\n   * @param patterns\n   */\n  public static glob(absoluteRootPath: string, patterns: string[]): GlobIgnoreStrategy {\n    return new GlobIgnoreStrategy(absoluteRootPath, patterns);\n  }\n\n  /**\n   * Ignores file paths based on the [`.gitignore specification`](https://git-scm.com/docs/gitignore).\n   *\n   * @returns `GitIgnorePattern` associated with the given patterns.\n   * @param absoluteRootPath the absolute path to the root directory of the paths to be considered\n   * @param patterns\n   */\n  public static git(absoluteRootPath: string, patterns: string[]): GitIgnoreStrategy {\n    return new GitIgnoreStrategy(absoluteRootPath, patterns);\n  }\n\n  /**\n   * Ignores file paths based on the [`.dockerignore specification`](https://docs.docker.com/engine/reference/builder/#dockerignore-file).\n   *\n   * @returns `DockerIgnorePattern` associated with the given patterns.\n   * @param absoluteRootPath the absolute path to the root directory of the paths to be considered\n   * @param patterns\n   */\n  public static docker(absoluteRootPath: string, patterns: string[]): DockerIgnoreStrategy {\n    return new DockerIgnoreStrategy(absoluteRootPath, patterns);\n  }\n\n  /**\n   * Creates an IgnoreStrategy based on the `ignoreMode` and `exclude` in a `CopyOptions`.\n   *\n   * @returns `IgnoreStrategy` based on the `CopyOptions`\n   * @param absoluteRootPath the absolute path to the root directory of the paths to be considered\n   * @param options the `CopyOptions` to create the `IgnoreStrategy` from\n   */\n  public static fromCopyOptions(options: CopyOptions, absoluteRootPath: string): IgnoreStrategy {\n    const ignoreMode = options.ignoreMode || IgnoreMode.GLOB;\n    const exclude = options.exclude || [];\n\n    switch (ignoreMode) {\n      case IgnoreMode.GLOB:\n        return this.glob(absoluteRootPath, exclude);\n\n      case IgnoreMode.GIT:\n        return this.git(absoluteRootPath, exclude);\n\n      case IgnoreMode.DOCKER:\n        return this.docker(absoluteRootPath, exclude);\n    }\n  }\n\n  /**\n   * Adds another pattern.\n   * @params pattern the pattern to add\n   */\n  public abstract add(pattern: string): void;\n\n  /**\n   * Determines whether a given file path should be ignored or not.\n   *\n   * @param absoluteFilePath absolute file path to be assessed against the pattern\n   * @returns `true` if the file should be ignored\n   */\n  public abstract ignores(absoluteFilePath: string): boolean;\n}\n\n/**\n * Ignores file paths based on simple glob patterns.\n */\nexport class GlobIgnoreStrategy extends IgnoreStrategy {\n  private readonly absoluteRootPath: string;\n  private readonly patterns: string[];\n\n  constructor(absoluteRootPath: string, patterns: string[]) {\n    super();\n\n    if (!path.isAbsolute(absoluteRootPath)) {\n      throw new Error('GlobIgnoreStrategy expects an absolute file path');\n    }\n\n    this.absoluteRootPath = absoluteRootPath;\n    this.patterns = patterns;\n  }\n\n  /**\n   * Adds another pattern.\n   * @params pattern the pattern to add\n   */\n  public add(pattern: string): void {\n    this.patterns.push(pattern);\n  }\n\n  /**\n   * Determines whether a given file path should be ignored or not.\n   *\n   * @param absoluteFilePath absolute file path to be assessed against the pattern\n   * @returns `true` if the file should be ignored\n   */\n  public ignores(absoluteFilePath: string): boolean {\n    if (!path.isAbsolute(absoluteFilePath)) {\n      throw new Error('GlobIgnoreStrategy.ignores() expects an absolute path');\n    }\n\n    let relativePath = path.relative(this.absoluteRootPath, absoluteFilePath);\n    let excludeOutput = false;\n\n    for (const pattern of this.patterns) {\n      const negate = pattern.startsWith('!');\n      const match = minimatch(relativePath, pattern, { matchBase: true, flipNegate: true });\n\n      if (!negate && match) {\n        excludeOutput = true;\n      }\n\n      if (negate && match) {\n        excludeOutput = false;\n      }\n    }\n\n    return excludeOutput;\n  }\n}\n\n/**\n * Ignores file paths based on the [`.gitignore specification`](https://git-scm.com/docs/gitignore).\n */\nexport class GitIgnoreStrategy extends IgnoreStrategy {\n  private readonly absoluteRootPath: string;\n  private readonly ignore: GitIgnore.Ignore;\n\n  constructor(absoluteRootPath: string, patterns: string[]) {\n    super();\n\n    if (!path.isAbsolute(absoluteRootPath)) {\n      throw new Error('GitIgnoreStrategy expects an absolute file path');\n    }\n\n    this.absoluteRootPath = absoluteRootPath;\n    this.ignore = gitIgnore().add(patterns);\n  }\n\n  /**\n   * Adds another pattern.\n   * @params pattern the pattern to add\n   */\n  public add(pattern: string): void {\n    this.ignore.add(pattern);\n  }\n\n  /**\n   * Determines whether a given file path should be ignored or not.\n   *\n   * @param absoluteFilePath absolute file path to be assessed against the pattern\n   * @returns `true` if the file should be ignored\n   */\n  public ignores(absoluteFilePath: string): boolean {\n    if (!path.isAbsolute(absoluteFilePath)) {\n      throw new Error('GitIgnoreStrategy.ignores() expects an absolute path');\n    }\n\n    let relativePath = path.relative(this.absoluteRootPath, absoluteFilePath);\n\n    return this.ignore.ignores(relativePath);\n  }\n}\n\n/**\n * Ignores file paths based on the [`.dockerignore specification`](https://docs.docker.com/engine/reference/builder/#dockerignore-file).\n */\nexport class DockerIgnoreStrategy extends IgnoreStrategy {\n  private readonly absoluteRootPath: string;\n  private readonly ignore: DockerIgnore.Ignore;\n\n  constructor(absoluteRootPath: string, patterns: string[]) {\n    super();\n\n    if (!path.isAbsolute(absoluteRootPath)) {\n      throw new Error('DockerIgnoreStrategy expects an absolute file path');\n    }\n\n    this.absoluteRootPath = absoluteRootPath;\n    this.ignore = dockerIgnore().add(patterns);\n  }\n\n  /**\n   * Adds another pattern.\n   * @params pattern the pattern to add\n   */\n  public add(pattern: string): void {\n    this.ignore.add(pattern);\n  }\n\n  /**\n   * Determines whether a given file path should be ignored or not.\n   *\n   * @param absoluteFilePath absolute file path to be assessed against the pattern\n   * @returns `true` if the file should be ignored\n   */\n  public ignores(absoluteFilePath: string): boolean {\n    if (!path.isAbsolute(absoluteFilePath)) {\n      throw new Error('DockerIgnoreStrategy.ignores() expects an absolute path');\n    }\n\n    let relativePath = path.relative(this.absoluteRootPath, absoluteFilePath);\n\n    return this.ignore.ignores(relativePath);\n  }\n}\n"]}
;