@codedrifters/configulator 0.0.78 → 0.0.80
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/index.d.ts +1 -0
- package/lib/index.js +2 -1
- package/lib/projects/monorepo-project.d.ts +11 -0
- package/lib/projects/monorepo-project.js +23 -1
- package/lib/projects/typescript-project.d.ts +17 -1
- package/lib/projects/typescript-project.js +34 -3
- package/lib/tasks/index.d.ts +1 -0
- package/lib/tasks/index.js +18 -0
- package/lib/tasks/reset-task.d.ts +51 -0
- package/lib/tasks/reset-task.js +149 -0
- package/package.json +2 -1
package/lib/index.d.ts
CHANGED
package/lib/index.js
CHANGED
|
@@ -19,8 +19,9 @@ __exportStar(require("./git/"), exports);
|
|
|
19
19
|
__exportStar(require("./jsii/"), exports);
|
|
20
20
|
__exportStar(require("./pnpm/"), exports);
|
|
21
21
|
__exportStar(require("./projects/"), exports);
|
|
22
|
+
__exportStar(require("./tasks/"), exports);
|
|
22
23
|
__exportStar(require("./turbo/"), exports);
|
|
23
24
|
__exportStar(require("./typescript/"), exports);
|
|
24
25
|
__exportStar(require("./vscode/"), exports);
|
|
25
26
|
__exportStar(require("./workflows/"), exports);
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHlDQUF1QjtBQUN2Qix5Q0FBdUI7QUFDdkIsMENBQXdCO0FBQ3hCLDBDQUF3QjtBQUN4Qiw4Q0FBNEI7QUFDNUIsMkNBQXlCO0FBQ3pCLDJDQUF5QjtBQUN6QixnREFBOEI7QUFDOUIsNENBQTBCO0FBQzFCLCtDQUE2QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2F3cy9cIjtcbmV4cG9ydCAqIGZyb20gXCIuL2dpdC9cIjtcbmV4cG9ydCAqIGZyb20gXCIuL2pzaWkvXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9wbnBtL1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcHJvamVjdHMvXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90YXNrcy9cIjtcbmV4cG9ydCAqIGZyb20gXCIuL3R1cmJvL1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHlwZXNjcmlwdC9cIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZzY29kZS9cIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dvcmtmbG93cy9cIjtcbiJdfQ==
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { TypeScriptAppProject, TypeScriptProjectOptions } from "projen/lib/typescript";
|
|
2
2
|
import { PnpmWorkspaceOptions } from "../pnpm/pnpm-workspace";
|
|
3
|
+
import { ResetTaskOptions } from "../tasks/reset-task";
|
|
3
4
|
import { TurboRepoOptions } from "../turbo/turbo-repo";
|
|
4
5
|
/*******************************************************************************
|
|
5
6
|
*
|
|
@@ -25,6 +26,16 @@ export interface MonorepoProjectOptions extends Omit<TypeScriptProjectOptions, "
|
|
|
25
26
|
* Optionsal options for turborepo config
|
|
26
27
|
*/
|
|
27
28
|
turboOptions?: TurboRepoOptions;
|
|
29
|
+
/**
|
|
30
|
+
* Enable the reset task that deletes all build artifacts.
|
|
31
|
+
*
|
|
32
|
+
* @default true
|
|
33
|
+
*/
|
|
34
|
+
resetTask?: boolean;
|
|
35
|
+
/**
|
|
36
|
+
* Options for the reset task.
|
|
37
|
+
*/
|
|
38
|
+
resetTaskOptions?: ResetTaskOptions;
|
|
28
39
|
/**
|
|
29
40
|
* PNPM options for the monorepo.
|
|
30
41
|
*/
|
|
@@ -5,6 +5,7 @@ const javascript_1 = require("projen/lib/javascript");
|
|
|
5
5
|
const typescript_1 = require("projen/lib/typescript");
|
|
6
6
|
const ts_deepmerge_1 = require("ts-deepmerge");
|
|
7
7
|
const pnpm_workspace_1 = require("../pnpm/pnpm-workspace");
|
|
8
|
+
const reset_task_1 = require("../tasks/reset-task");
|
|
8
9
|
const turbo_repo_1 = require("../turbo/turbo-repo");
|
|
9
10
|
const versions_1 = require("../versions");
|
|
10
11
|
const vscode_1 = require("../vscode/vscode");
|
|
@@ -91,6 +92,10 @@ class MonorepoProject extends typescript_1.TypeScriptAppProject {
|
|
|
91
92
|
* Enable turborepo by default.
|
|
92
93
|
*/
|
|
93
94
|
turbo: true,
|
|
95
|
+
/**
|
|
96
|
+
* Enable reset task by default.
|
|
97
|
+
*/
|
|
98
|
+
resetTask: true,
|
|
94
99
|
/**
|
|
95
100
|
* Include self as a devDep
|
|
96
101
|
*/
|
|
@@ -185,6 +190,23 @@ class MonorepoProject extends typescript_1.TypeScriptAppProject {
|
|
|
185
190
|
run: `npx projen ${turbo_repo_1.ROOT_CI_TASK_NAME}`,
|
|
186
191
|
});
|
|
187
192
|
}
|
|
193
|
+
/**
|
|
194
|
+
* Add reset task if enabled.
|
|
195
|
+
*/
|
|
196
|
+
if (options.resetTask !== false) {
|
|
197
|
+
const defaultResetTaskOptions = {
|
|
198
|
+
pathsToRemove: ["node_modules", ".turbo", "dist", "lib"],
|
|
199
|
+
};
|
|
200
|
+
const userResetTaskOptions = options.resetTaskOptions ?? {};
|
|
201
|
+
const resetTaskOptions = (0, ts_deepmerge_1.merge)(defaultResetTaskOptions, {
|
|
202
|
+
...userResetTaskOptions,
|
|
203
|
+
pathsToRemove: [
|
|
204
|
+
...(defaultResetTaskOptions.pathsToRemove ?? []),
|
|
205
|
+
...(userResetTaskOptions.pathsToRemove ?? []),
|
|
206
|
+
],
|
|
207
|
+
});
|
|
208
|
+
new reset_task_1.ResetTask(this, resetTaskOptions);
|
|
209
|
+
}
|
|
188
210
|
/**
|
|
189
211
|
* Specify package manager
|
|
190
212
|
*/
|
|
@@ -201,4 +223,4 @@ class MonorepoProject extends typescript_1.TypeScriptAppProject {
|
|
|
201
223
|
}
|
|
202
224
|
}
|
|
203
225
|
exports.MonorepoProject = MonorepoProject;
|
|
204
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monorepo-project.js","sourceRoot":"","sources":["../../src/projects/monorepo-project.ts"],"names":[],"mappings":"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","sourcesContent":["import { BuildWorkflowOptions } from \"projen/lib/build\";\nimport { NodePackageManager } from \"projen/lib/javascript\";\nimport {\n  TypeScriptAppProject,\n  TypeScriptProjectOptions,\n} from \"projen/lib/typescript\";\nimport { merge } from \"ts-deepmerge\";\nimport { PnpmWorkspace, PnpmWorkspaceOptions } from \"../pnpm/pnpm-workspace\";\nimport {\n  ROOT_CI_TASK_NAME,\n  TurboRepo,\n  TurboRepoOptions,\n} from \"../turbo/turbo-repo\";\nimport { VERSION } from \"../versions\";\nimport { VSCodeConfig } from \"../vscode/vscode\";\n\n/*******************************************************************************\n *\n * Monorepo Root Project\n *\n * This project should be used as the base project for other projects in a\n * monorepo. The Monorepo root project generally won't contain any code, but it\n * will contain configuration for the monorepo, such as package management,\n * linting, testing, and other project-wide settings.\n *\n ******************************************************************************/\n\n/**\n * Configuration options for the monorepo.\n */\nexport interface MonorepoProjectOptions extends Omit<\n  TypeScriptProjectOptions,\n  \"defaultReleaseBranch\"\n> {\n  /**\n   * Turn on Turborepo support.\n   *\n   * @default true\n   */\n  turbo?: boolean;\n\n  /**\n   * Optionsal options for turborepo config\n   */\n  turboOptions?: TurboRepoOptions;\n\n  /**\n   * PNPM options for the monorepo.\n   */\n  pnpmOptions?: {\n    /**\n     * The version of PNPM to use in the monorepo.\n     * @default VERSION.PNPM_VERSION\n     * @see {@link src/versions.ts}\n     */\n    version?: string;\n\n    /**\n     * Optional pnpm options for the monorepo workspace file.\n     */\n    pnpmWorkspaceOptions?: PnpmWorkspaceOptions;\n  };\n}\n\ninterface AppliedOptions\n  extends TypeScriptProjectOptions, MonorepoProjectOptions {}\n\nexport class MonorepoProject extends TypeScriptAppProject {\n  /**\n   * Version of PNPM which the whole monorepo should use.\n   */\n  readonly pnpmVersion: string;\n\n  constructor(userOptions: MonorepoProjectOptions) {\n    /***************************************************************************\n     *\n     * BUILD WORKFLOW OPTIONS\n     *\n     * discover some turbo options for build workflow, if needed.\n     *\n     **************************************************************************/\n\n    const buildWorkflowOptions: Partial<BuildWorkflowOptions> = userOptions\n      .turboOptions?.remoteCacheOptions\n      ? TurboRepo.buildWorkflowOptions(\n          userOptions.turboOptions.remoteCacheOptions,\n        )\n      : {};\n\n    /***************************************************************************\n     *\n     * DEFAULT OPTIONS\n     *\n     * These are the default options unless you override with option inputs.\n     *\n     **************************************************************************/\n\n    const defaultOptions: Omit<\n      MonorepoProjectOptions,\n      \"name\" | \"defaultReleaseBranch\"\n    > = {\n      /**\n       * Use typescript based config file.\n       */\n      projenrcTs: true,\n\n      /**\n       * Projen version should be pinned to the local specified version.\n       */\n      projenVersion: \"catalog:\",\n\n      /**\n       * Use Prettier for code formatting.\n       */\n      prettier: true,\n\n      /**\n       * Not licensed by default.\n       */\n      licensed: false,\n\n      /**\n       * GitHub options for the monorepo.\n       * Don't enable mergify by default.\n       */\n      githubOptions: {\n        mergify: false,\n      },\n\n      /**\n       * Default PNPM version to use in the monorepo.\n       */\n      pnpmVersion: VERSION.PNPM_VERSION,\n\n      /**\n       * We don't want sample code generated for the root project.\n       */\n      sampleCode: false,\n\n      /**\n       * Jest is not required in the root project.\n       */\n      jest: false,\n\n      /**\n       * Don't release the root project.\n       */\n      release: false,\n\n      /**\n       * Don't upgrade dependencies automatically.\n       */\n      depsUpgrade: false,\n\n      /**\n       * Disable tsconfig.dev.json in the root since we aren't going to be\n       * developing any code here. It's just a task runner and configuration\n       * tool for sub-projects.\n       */\n      disableTsconfigDev: true,\n\n      /**\n       * Kill the srcdir in the root since we aren't using one.\n       */\n      tsconfig: {\n        compilerOptions: {\n          rootDir: undefined,\n        },\n        exclude: [\"node_modules\"],\n      },\n\n      /**\n       * Enable turborepo by default.\n       */\n      turbo: true,\n\n      /**\n       * Include self as a devDep\n       */\n      devDeps: [\"@codedrifters/configulator\"],\n\n      pnpmOptions: {\n        pnpmWorkspaceOptions: {\n          defaultCatalog: {\n            [\"aws-cdk\"]: VERSION.AWS_CDK_CLI_VERSION,\n            [\"aws-cdk-lib\"]: VERSION.AWS_CDK_LIB_VERSION,\n            [\"projen\"]: VERSION.PROJEN_VERSION,\n            [\"constructs\"]: VERSION.AWS_CONSTRUCTS_VERSION,\n            [\"turbo\"]: VERSION.TURBO_VERSION,\n          },\n        },\n      },\n    };\n\n    /***************************************************************************\n     *\n     * REQUIRED OPTIONS\n     *\n     * These options cannot be changed by the user.\n     *\n     **************************************************************************/\n\n    const requiredOptions: Omit<TypeScriptProjectOptions, \"name\"> = {\n      /**\n       * This is required because it's standard practice and also to simplify\n       * some workflow design.\n       */\n      defaultReleaseBranch: \"main\",\n\n      /**\n       * Use PNPM instead of the default (Yarn). Much of the ecosystem depends\n       * on PNPM and making monorepos PNPM only simplifies many configurations.\n       */\n      packageManager: NodePackageManager.PNPM,\n\n      /**\n       * Some additional pre-build steps if we're using turbo's remote cache.\n       */\n      buildWorkflowOptions: {\n        permissions: {\n          ...buildWorkflowOptions?.permissions,\n          ...userOptions.buildWorkflowOptions?.permissions,\n        },\n        preBuildSteps: [\n          ...(buildWorkflowOptions?.preBuildSteps ?? []),\n          ...(userOptions.buildWorkflowOptions?.preBuildSteps ?? []),\n        ],\n      },\n    };\n\n    /***************************************************************************\n     *\n     * CONSTRUCTOR\n     *\n     * Combines default options with user provided options and required options.\n     * Store the options in a const so we can use them after super(), farther\n     * into the constructor for additional configuration.\n     *\n     **************************************************************************/\n\n    const options: AppliedOptions = merge(\n      defaultOptions,\n      userOptions,\n      requiredOptions,\n    );\n\n    super({ ...options });\n\n    /***************************************************************************\n     *\n     * PUBLIC PROPS\n     *\n     * Some props are hidden by Projen and we need to expose them for the\n     * monorepo to work properly. This is where we store them.\n     *\n     **************************************************************************/\n\n    this.pnpmVersion = options.pnpmVersion!;\n\n    /***************************************************************************\n     *\n     * CUSTOM CONFIGS\n     *\n     * We add some additional configurations to the monorepo root project below\n     * such as Turborepo, VS Code config, and the PNPM workspace file.\n     *\n     **************************************************************************/\n\n    /**\n     * Add VSCode configuration\n     */\n    new VSCodeConfig(this);\n\n    /**\n     * Add workspace definition to PNPM root\n     */\n    new PnpmWorkspace(this, options.pnpmOptions?.pnpmWorkspaceOptions);\n\n    /**\n     * Turn on turborepo support if requested.\n     */\n    if (options.turbo) {\n      new TurboRepo(this, options.turboOptions);\n\n      this.buildWorkflow?.addPostBuildSteps({\n        name: \"Build Sub Projects\",\n        run: `npx projen ${ROOT_CI_TASK_NAME}`,\n      });\n    }\n\n    /**\n     * Specify package manager\n     */\n    // const pnpmVersion = options.pnpmVersion ?? VERSION.PNPM_VERSION;\n    this.package.file.addOverride(\n      \"packageManager\",\n      `pnpm@${options.pnpmVersion}`,\n    );\n\n    /**\n     * Add some silly things to the gitignore.\n     */\n    this.gitignore?.addPatterns(\".DS_Store\");\n\n    /**\n     * Use catalog version for constructs version\n     */\n    this.addDevDeps(\"constructs@catalog:\");\n  }\n}\n"]}
|
|
226
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monorepo-project.js","sourceRoot":"","sources":["../../src/projects/monorepo-project.ts"],"names":[],"mappings":"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","sourcesContent":["import { BuildWorkflowOptions } from \"projen/lib/build\";\nimport { NodePackageManager } from \"projen/lib/javascript\";\nimport {\n  TypeScriptAppProject,\n  TypeScriptProjectOptions,\n} from \"projen/lib/typescript\";\nimport { merge } from \"ts-deepmerge\";\nimport { PnpmWorkspace, PnpmWorkspaceOptions } from \"../pnpm/pnpm-workspace\";\nimport { ResetTask, ResetTaskOptions } from \"../tasks/reset-task\";\nimport {\n  ROOT_CI_TASK_NAME,\n  TurboRepo,\n  TurboRepoOptions,\n} from \"../turbo/turbo-repo\";\nimport { VERSION } from \"../versions\";\nimport { VSCodeConfig } from \"../vscode/vscode\";\n\n/*******************************************************************************\n *\n * Monorepo Root Project\n *\n * This project should be used as the base project for other projects in a\n * monorepo. The Monorepo root project generally won't contain any code, but it\n * will contain configuration for the monorepo, such as package management,\n * linting, testing, and other project-wide settings.\n *\n ******************************************************************************/\n\n/**\n * Configuration options for the monorepo.\n */\nexport interface MonorepoProjectOptions extends Omit<\n  TypeScriptProjectOptions,\n  \"defaultReleaseBranch\"\n> {\n  /**\n   * Turn on Turborepo support.\n   *\n   * @default true\n   */\n  turbo?: boolean;\n\n  /**\n   * Optionsal options for turborepo config\n   */\n  turboOptions?: TurboRepoOptions;\n\n  /**\n   * Enable the reset task that deletes all build artifacts.\n   *\n   * @default true\n   */\n  resetTask?: boolean;\n\n  /**\n   * Options for the reset task.\n   */\n  resetTaskOptions?: ResetTaskOptions;\n\n  /**\n   * PNPM options for the monorepo.\n   */\n  pnpmOptions?: {\n    /**\n     * The version of PNPM to use in the monorepo.\n     * @default VERSION.PNPM_VERSION\n     * @see {@link src/versions.ts}\n     */\n    version?: string;\n\n    /**\n     * Optional pnpm options for the monorepo workspace file.\n     */\n    pnpmWorkspaceOptions?: PnpmWorkspaceOptions;\n  };\n}\n\ninterface AppliedOptions\n  extends TypeScriptProjectOptions, MonorepoProjectOptions {}\n\nexport class MonorepoProject extends TypeScriptAppProject {\n  /**\n   * Version of PNPM which the whole monorepo should use.\n   */\n  readonly pnpmVersion: string;\n\n  constructor(userOptions: MonorepoProjectOptions) {\n    /***************************************************************************\n     *\n     * BUILD WORKFLOW OPTIONS\n     *\n     * discover some turbo options for build workflow, if needed.\n     *\n     **************************************************************************/\n\n    const buildWorkflowOptions: Partial<BuildWorkflowOptions> = userOptions\n      .turboOptions?.remoteCacheOptions\n      ? TurboRepo.buildWorkflowOptions(\n          userOptions.turboOptions.remoteCacheOptions,\n        )\n      : {};\n\n    /***************************************************************************\n     *\n     * DEFAULT OPTIONS\n     *\n     * These are the default options unless you override with option inputs.\n     *\n     **************************************************************************/\n\n    const defaultOptions: Omit<\n      MonorepoProjectOptions,\n      \"name\" | \"defaultReleaseBranch\"\n    > = {\n      /**\n       * Use typescript based config file.\n       */\n      projenrcTs: true,\n\n      /**\n       * Projen version should be pinned to the local specified version.\n       */\n      projenVersion: \"catalog:\",\n\n      /**\n       * Use Prettier for code formatting.\n       */\n      prettier: true,\n\n      /**\n       * Not licensed by default.\n       */\n      licensed: false,\n\n      /**\n       * GitHub options for the monorepo.\n       * Don't enable mergify by default.\n       */\n      githubOptions: {\n        mergify: false,\n      },\n\n      /**\n       * Default PNPM version to use in the monorepo.\n       */\n      pnpmVersion: VERSION.PNPM_VERSION,\n\n      /**\n       * We don't want sample code generated for the root project.\n       */\n      sampleCode: false,\n\n      /**\n       * Jest is not required in the root project.\n       */\n      jest: false,\n\n      /**\n       * Don't release the root project.\n       */\n      release: false,\n\n      /**\n       * Don't upgrade dependencies automatically.\n       */\n      depsUpgrade: false,\n\n      /**\n       * Disable tsconfig.dev.json in the root since we aren't going to be\n       * developing any code here. It's just a task runner and configuration\n       * tool for sub-projects.\n       */\n      disableTsconfigDev: true,\n\n      /**\n       * Kill the srcdir in the root since we aren't using one.\n       */\n      tsconfig: {\n        compilerOptions: {\n          rootDir: undefined,\n        },\n        exclude: [\"node_modules\"],\n      },\n\n      /**\n       * Enable turborepo by default.\n       */\n      turbo: true,\n\n      /**\n       * Enable reset task by default.\n       */\n      resetTask: true,\n\n      /**\n       * Include self as a devDep\n       */\n      devDeps: [\"@codedrifters/configulator\"],\n\n      pnpmOptions: {\n        pnpmWorkspaceOptions: {\n          defaultCatalog: {\n            [\"aws-cdk\"]: VERSION.AWS_CDK_CLI_VERSION,\n            [\"aws-cdk-lib\"]: VERSION.AWS_CDK_LIB_VERSION,\n            [\"projen\"]: VERSION.PROJEN_VERSION,\n            [\"constructs\"]: VERSION.AWS_CONSTRUCTS_VERSION,\n            [\"turbo\"]: VERSION.TURBO_VERSION,\n          },\n        },\n      },\n    };\n\n    /***************************************************************************\n     *\n     * REQUIRED OPTIONS\n     *\n     * These options cannot be changed by the user.\n     *\n     **************************************************************************/\n\n    const requiredOptions: Omit<TypeScriptProjectOptions, \"name\"> = {\n      /**\n       * This is required because it's standard practice and also to simplify\n       * some workflow design.\n       */\n      defaultReleaseBranch: \"main\",\n\n      /**\n       * Use PNPM instead of the default (Yarn). Much of the ecosystem depends\n       * on PNPM and making monorepos PNPM only simplifies many configurations.\n       */\n      packageManager: NodePackageManager.PNPM,\n\n      /**\n       * Some additional pre-build steps if we're using turbo's remote cache.\n       */\n      buildWorkflowOptions: {\n        permissions: {\n          ...buildWorkflowOptions?.permissions,\n          ...userOptions.buildWorkflowOptions?.permissions,\n        },\n        preBuildSteps: [\n          ...(buildWorkflowOptions?.preBuildSteps ?? []),\n          ...(userOptions.buildWorkflowOptions?.preBuildSteps ?? []),\n        ],\n      },\n    };\n\n    /***************************************************************************\n     *\n     * CONSTRUCTOR\n     *\n     * Combines default options with user provided options and required options.\n     * Store the options in a const so we can use them after super(), farther\n     * into the constructor for additional configuration.\n     *\n     **************************************************************************/\n\n    const options: AppliedOptions = merge(\n      defaultOptions,\n      userOptions,\n      requiredOptions,\n    );\n\n    super({ ...options });\n\n    /***************************************************************************\n     *\n     * PUBLIC PROPS\n     *\n     * Some props are hidden by Projen and we need to expose them for the\n     * monorepo to work properly. This is where we store them.\n     *\n     **************************************************************************/\n\n    this.pnpmVersion = options.pnpmVersion!;\n\n    /***************************************************************************\n     *\n     * CUSTOM CONFIGS\n     *\n     * We add some additional configurations to the monorepo root project below\n     * such as Turborepo, VS Code config, and the PNPM workspace file.\n     *\n     **************************************************************************/\n\n    /**\n     * Add VSCode configuration\n     */\n    new VSCodeConfig(this);\n\n    /**\n     * Add workspace definition to PNPM root\n     */\n    new PnpmWorkspace(this, options.pnpmOptions?.pnpmWorkspaceOptions);\n\n    /**\n     * Turn on turborepo support if requested.\n     */\n    if (options.turbo) {\n      new TurboRepo(this, options.turboOptions);\n\n      this.buildWorkflow?.addPostBuildSteps({\n        name: \"Build Sub Projects\",\n        run: `npx projen ${ROOT_CI_TASK_NAME}`,\n      });\n    }\n\n    /**\n     * Add reset task if enabled.\n     */\n    if (options.resetTask !== false) {\n      const defaultResetTaskOptions: ResetTaskOptions = {\n        pathsToRemove: [\"node_modules\", \".turbo\", \"dist\", \"lib\"],\n      };\n      const userResetTaskOptions = options.resetTaskOptions ?? {};\n      const resetTaskOptions: ResetTaskOptions = merge(\n        defaultResetTaskOptions,\n        {\n          ...userResetTaskOptions,\n          pathsToRemove: [\n            ...(defaultResetTaskOptions.pathsToRemove ?? []),\n            ...(userResetTaskOptions.pathsToRemove ?? []),\n          ],\n        },\n      );\n      new ResetTask(this, resetTaskOptions);\n    }\n\n    /**\n     * Specify package manager\n     */\n    // const pnpmVersion = options.pnpmVersion ?? VERSION.PNPM_VERSION;\n    this.package.file.addOverride(\n      \"packageManager\",\n      `pnpm@${options.pnpmVersion}`,\n    );\n\n    /**\n     * Add some silly things to the gitignore.\n     */\n    this.gitignore?.addPatterns(\".DS_Store\");\n\n    /**\n     * Use catalog version for constructs version\n     */\n    this.addDevDeps(\"constructs@catalog:\");\n  }\n}\n"]}
|
|
@@ -1,4 +1,20 @@
|
|
|
1
1
|
import { typescript } from "projen";
|
|
2
|
+
import { ResetTaskOptions } from "../tasks/reset-task";
|
|
3
|
+
/**
|
|
4
|
+
* Configuration options for TypeScriptProject.
|
|
5
|
+
*/
|
|
6
|
+
export interface TypeScriptProjectOptions extends Omit<typescript.TypeScriptProjectOptions, "defaultReleaseBranch"> {
|
|
7
|
+
/**
|
|
8
|
+
* Enable the reset task that deletes all build artifacts.
|
|
9
|
+
*
|
|
10
|
+
* @default true
|
|
11
|
+
*/
|
|
12
|
+
readonly resetTask?: boolean;
|
|
13
|
+
/**
|
|
14
|
+
* Options for the reset task.
|
|
15
|
+
*/
|
|
16
|
+
readonly resetTaskOptions?: ResetTaskOptions;
|
|
17
|
+
}
|
|
2
18
|
export declare class TypeScriptProject extends typescript.TypeScriptProject {
|
|
3
|
-
constructor(userOptions:
|
|
19
|
+
constructor(userOptions: TypeScriptProjectOptions);
|
|
4
20
|
}
|
|
@@ -7,6 +7,7 @@ const release_1 = require("projen/lib/release");
|
|
|
7
7
|
const ts_deepmerge_1 = require("ts-deepmerge");
|
|
8
8
|
const monorepo_project_1 = require("./monorepo-project");
|
|
9
9
|
const pnpm_1 = require("../pnpm");
|
|
10
|
+
const reset_task_1 = require("../tasks/reset-task");
|
|
10
11
|
const turbo_1 = require("../turbo");
|
|
11
12
|
const versions_1 = require("../versions");
|
|
12
13
|
class TypeScriptProject extends projen_1.typescript.TypeScriptProject {
|
|
@@ -35,6 +36,10 @@ class TypeScriptProject extends projen_1.typescript.TypeScriptProject {
|
|
|
35
36
|
* This is a standard, so don't require it to passed in everywhere.
|
|
36
37
|
*/
|
|
37
38
|
defaultReleaseBranch: "main",
|
|
39
|
+
/**
|
|
40
|
+
* Enable reset task by default.
|
|
41
|
+
*/
|
|
42
|
+
resetTask: true,
|
|
38
43
|
/**
|
|
39
44
|
* Packaging options
|
|
40
45
|
*/
|
|
@@ -92,10 +97,10 @@ class TypeScriptProject extends projen_1.typescript.TypeScriptProject {
|
|
|
92
97
|
: {}),
|
|
93
98
|
},
|
|
94
99
|
/**
|
|
95
|
-
* Only release when the package folder content changes
|
|
100
|
+
* Only release when the package folder sourcce content changes
|
|
96
101
|
*/
|
|
97
102
|
releaseTrigger: release_1.ReleaseTrigger.continuous({
|
|
98
|
-
paths: [`${userOptions.outdir}/**`],
|
|
103
|
+
paths: [`${userOptions.outdir}/src/**`],
|
|
99
104
|
}),
|
|
100
105
|
};
|
|
101
106
|
/*************************************************************************
|
|
@@ -144,7 +149,33 @@ class TypeScriptProject extends projen_1.typescript.TypeScriptProject {
|
|
|
144
149
|
turbo.compileTask?.outputs.push("lib/**");
|
|
145
150
|
//turbo.testTask?.inputs.push("src/**");
|
|
146
151
|
}
|
|
152
|
+
/**
|
|
153
|
+
* Add reset task if enabled.
|
|
154
|
+
*/
|
|
155
|
+
if (options.resetTask !== false) {
|
|
156
|
+
const defaultResetTaskOptions = {
|
|
157
|
+
pathsToRemove: [
|
|
158
|
+
"node_modules",
|
|
159
|
+
"dist",
|
|
160
|
+
"lib",
|
|
161
|
+
"coverage",
|
|
162
|
+
"test-reports",
|
|
163
|
+
".turbo",
|
|
164
|
+
"tsconfig.tsbuildinfo",
|
|
165
|
+
this.artifactsDirectory,
|
|
166
|
+
],
|
|
167
|
+
};
|
|
168
|
+
const userResetTaskOptions = options.resetTaskOptions ?? {};
|
|
169
|
+
const resetTaskOptions = (0, ts_deepmerge_1.merge)(defaultResetTaskOptions, {
|
|
170
|
+
...userResetTaskOptions,
|
|
171
|
+
pathsToRemove: [
|
|
172
|
+
...(defaultResetTaskOptions.pathsToRemove ?? []),
|
|
173
|
+
...(userResetTaskOptions.pathsToRemove ?? []),
|
|
174
|
+
],
|
|
175
|
+
});
|
|
176
|
+
new reset_task_1.ResetTask(this, resetTaskOptions);
|
|
177
|
+
}
|
|
147
178
|
}
|
|
148
179
|
}
|
|
149
180
|
exports.TypeScriptProject = TypeScriptProject;
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typescript-project.js","sourceRoot":"","sources":["../../src/projects/typescript-project.ts"],"names":[],"mappings":"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","sourcesContent":["import { typescript } from \"projen\";\nimport {\n  NodePackageManager,\n  Transform,\n  UpgradeDependenciesSchedule,\n} from \"projen/lib/javascript\";\nimport { ReleaseTrigger } from \"projen/lib/release\";\nimport { TypeScriptProjectOptions } from \"projen/lib/typescript\";\nimport { merge } from \"ts-deepmerge\";\nimport { MonorepoProject } from \"./monorepo-project\";\nimport { PnpmWorkspace } from \"../pnpm\";\nimport { TurboRepo } from \"../turbo\";\nimport { VERSION } from \"../versions\";\n\nexport class TypeScriptProject extends typescript.TypeScriptProject {\n  constructor(\n    userOptions: Omit<\n      typescript.TypeScriptProjectOptions,\n      \"defaultReleaseBranch\"\n    >,\n  ) {\n    /**\n     * Default PNPM version to use. This will either come from the MonoRepo\n     * root or from the default specified in configulator. If the user passes\n     * in a different pnpmVersion it will also override this.\n     */\n    const pnpmVersion =\n      userOptions.parent && userOptions.parent instanceof MonorepoProject\n        ? userOptions.parent.pnpmVersion\n        : VERSION.PNPM_VERSION;\n\n    /**\n     * Get the pnpm workspace from the parent project.\n     */\n    const pnpmWorkspace =\n      userOptions.parent && userOptions.parent instanceof MonorepoProject\n        ? PnpmWorkspace.of(userOptions.parent as MonorepoProject)\n        : undefined;\n\n    /*************************************************************************\n     *\n     * Default Options\n     *\n     ************************************************************************/\n\n    const defaultOptions: Omit<TypeScriptProjectOptions, \"name\"> = {\n      /**\n       * This is a standard, so don't require it to passed in everywhere.\n       */\n      defaultReleaseBranch: \"main\",\n\n      /**\n       * Packaging options\n       */\n      packageManager: NodePackageManager.PNPM,\n      pnpmVersion: pnpmVersion,\n      licensed: userOptions.license !== undefined || false,\n      copyrightOwner: \"CodeDrifters\",\n      release: false,\n\n      /**\n       * Don't add sample code.\n       */\n      sampleCode: false,\n\n      /**\n       * Make sure jest config is stored outside of package.json\n       */\n      jestOptions: {\n        configFilePath: \"jest.config.json\",\n        jestConfig: {\n          roots: [`<rootDir>/src`],\n          transform: {\n            [\"^.+\\\\.[t]sx?$\"]: new Transform(\"@swc/jest\"),\n          },\n          moduleFileExtensions: [\"js\", \"ts\"],\n        },\n      },\n\n      /**\n       * Turn on prettier formatting\n       */\n      prettier: true,\n\n      /**\n       * SWC for faster testing\n       */\n      devDeps: [\"@swc/jest\", \"@swc/core\"],\n\n      /**\n       * Don't package test files.\n       */\n      npmIgnoreOptions: {\n        ignorePatterns: [\"*.spec.*\", \"*.test.*\"],\n      },\n\n      /**\n       * Options for the automated dependency upgrade task / workflow\n       * Automatically exclude any packages that are managed by the root\n       * project as default catalog dependencies since we want to let the\n       * catalog manage those dependencies.\n       */\n      depsUpgradeOptions: {\n        exclude: Object.keys(pnpmWorkspace?.defaultCatalog || {}),\n        ...(userOptions.parent && userOptions.parent instanceof MonorepoProject\n          ? {\n              workflowOptions: {\n                schedule: UpgradeDependenciesSchedule.WEEKLY,\n              },\n              cooldown: 1,\n            }\n          : {}),\n      },\n\n      /**\n       * Only release when the package folder content changes\n       */\n      releaseTrigger: ReleaseTrigger.continuous({\n        paths: [`${userOptions.outdir}/**`],\n      }),\n    };\n\n    /*************************************************************************\n     *\n     * Merge defaults into user options\n     *\n     ************************************************************************/\n\n    const options: TypeScriptProjectOptions = merge(\n      defaultOptions,\n      userOptions,\n    );\n\n    super(options);\n\n    /**\n     * Remove jest since we've swapped in @swc/jest instead of ts-jest.\n     */\n    this.deps.removeDependency(\"ts-jest\");\n\n    /**\n     * Specify package manager\n     */\n    this.package.file.addOverride(\n      \"packageManager\",\n      `pnpm@${options.pnpmVersion}`,\n    );\n\n    /**\n     *\n     * Disable this rule for all test files.\n     *\n     * Unless we turn this off, ESLint will suggest that anything found in a test\n     * needs to be a dep instead of a devDep. Projen actually already turns off\n     * the rule for files in the tests/* folder but since we commonly put tests\n     * next to the code it's testing, we need to do this ourselves.\n     *\n     */\n    this.eslint?.addOverride({\n      files: [\"**/*.test.*\", \"**/*.spec.*\"],\n      rules: {\n        \"import/no-extraneous-dependencies\": \"off\",\n      },\n    });\n\n    /**\n     * Some standard ignores for all projects.\n     */\n    this.gitignore?.addPatterns(\".DS_Store\");\n    this.npmignore?.addPatterns(\"*.spec.*\", \"*.test.*\", \"__fixtures__\");\n\n    /**\n     * If turbo is active in the parent project, configure it here.\n     */\n    const turboActive =\n      userOptions.parent && TurboRepo.of(userOptions.parent) !== undefined;\n    if (turboActive) {\n      const turbo = new TurboRepo(this);\n      turbo.compileTask?.outputs.push(\"dist/**\");\n      turbo.compileTask?.outputs.push(\"lib/**\");\n      //turbo.testTask?.inputs.push(\"src/**\");\n    }\n  }\n}\n"]}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typescript-project.js","sourceRoot":"","sources":["../../src/projects/typescript-project.ts"],"names":[],"mappings":"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","sourcesContent":["import { typescript } from \"projen\";\nimport {\n  NodePackageManager,\n  Transform,\n  UpgradeDependenciesSchedule,\n} from \"projen/lib/javascript\";\nimport { ReleaseTrigger } from \"projen/lib/release\";\nimport { merge } from \"ts-deepmerge\";\nimport { MonorepoProject } from \"./monorepo-project\";\nimport { PnpmWorkspace } from \"../pnpm\";\nimport { ResetTask, ResetTaskOptions } from \"../tasks/reset-task\";\nimport { TurboRepo } from \"../turbo\";\nimport { VERSION } from \"../versions\";\n\n/**\n * Configuration options for TypeScriptProject.\n */\nexport interface TypeScriptProjectOptions extends Omit<\n  typescript.TypeScriptProjectOptions,\n  \"defaultReleaseBranch\"\n> {\n  /**\n   * Enable the reset task that deletes all build artifacts.\n   *\n   * @default true\n   */\n  readonly resetTask?: boolean;\n\n  /**\n   * Options for the reset task.\n   */\n  readonly resetTaskOptions?: ResetTaskOptions;\n}\n\nexport class TypeScriptProject extends typescript.TypeScriptProject {\n  constructor(userOptions: TypeScriptProjectOptions) {\n    /**\n     * Default PNPM version to use. This will either come from the MonoRepo\n     * root or from the default specified in configulator. If the user passes\n     * in a different pnpmVersion it will also override this.\n     */\n    const pnpmVersion =\n      userOptions.parent && userOptions.parent instanceof MonorepoProject\n        ? userOptions.parent.pnpmVersion\n        : VERSION.PNPM_VERSION;\n\n    /**\n     * Get the pnpm workspace from the parent project.\n     */\n    const pnpmWorkspace =\n      userOptions.parent && userOptions.parent instanceof MonorepoProject\n        ? PnpmWorkspace.of(userOptions.parent as MonorepoProject)\n        : undefined;\n\n    /*************************************************************************\n     *\n     * Default Options\n     *\n     ************************************************************************/\n\n    const defaultOptions: Omit<TypeScriptProjectOptions, \"name\"> & {\n      defaultReleaseBranch: string;\n    } = {\n      /**\n       * This is a standard, so don't require it to passed in everywhere.\n       */\n      defaultReleaseBranch: \"main\",\n\n      /**\n       * Enable reset task by default.\n       */\n      resetTask: true,\n\n      /**\n       * Packaging options\n       */\n      packageManager: NodePackageManager.PNPM,\n      pnpmVersion: pnpmVersion,\n      licensed: userOptions.license !== undefined || false,\n      copyrightOwner: \"CodeDrifters\",\n      release: false,\n\n      /**\n       * Don't add sample code.\n       */\n      sampleCode: false,\n\n      /**\n       * Make sure jest config is stored outside of package.json\n       */\n      jestOptions: {\n        configFilePath: \"jest.config.json\",\n        jestConfig: {\n          roots: [`<rootDir>/src`],\n          transform: {\n            [\"^.+\\\\.[t]sx?$\"]: new Transform(\"@swc/jest\"),\n          },\n          moduleFileExtensions: [\"js\", \"ts\"],\n        },\n      },\n\n      /**\n       * Turn on prettier formatting\n       */\n      prettier: true,\n\n      /**\n       * SWC for faster testing\n       */\n      devDeps: [\"@swc/jest\", \"@swc/core\"],\n\n      /**\n       * Don't package test files.\n       */\n      npmIgnoreOptions: {\n        ignorePatterns: [\"*.spec.*\", \"*.test.*\"],\n      },\n\n      /**\n       * Options for the automated dependency upgrade task / workflow\n       * Automatically exclude any packages that are managed by the root\n       * project as default catalog dependencies since we want to let the\n       * catalog manage those dependencies.\n       */\n      depsUpgradeOptions: {\n        exclude: Object.keys(pnpmWorkspace?.defaultCatalog || {}),\n        ...(userOptions.parent && userOptions.parent instanceof MonorepoProject\n          ? {\n              workflowOptions: {\n                schedule: UpgradeDependenciesSchedule.WEEKLY,\n              },\n              cooldown: 1,\n            }\n          : {}),\n      },\n\n      /**\n       * Only release when the package folder sourcce content changes\n       */\n      releaseTrigger: ReleaseTrigger.continuous({\n        paths: [`${userOptions.outdir}/src/**`],\n      }),\n    };\n\n    /*************************************************************************\n     *\n     * Merge defaults into user options\n     *\n     ************************************************************************/\n\n    const options: TypeScriptProjectOptions &\n      typescript.TypeScriptProjectOptions = merge(defaultOptions, userOptions);\n\n    super(options);\n\n    /**\n     * Remove jest since we've swapped in @swc/jest instead of ts-jest.\n     */\n    this.deps.removeDependency(\"ts-jest\");\n\n    /**\n     * Specify package manager\n     */\n    this.package.file.addOverride(\n      \"packageManager\",\n      `pnpm@${options.pnpmVersion}`,\n    );\n\n    /**\n     *\n     * Disable this rule for all test files.\n     *\n     * Unless we turn this off, ESLint will suggest that anything found in a test\n     * needs to be a dep instead of a devDep. Projen actually already turns off\n     * the rule for files in the tests/* folder but since we commonly put tests\n     * next to the code it's testing, we need to do this ourselves.\n     *\n     */\n    this.eslint?.addOverride({\n      files: [\"**/*.test.*\", \"**/*.spec.*\"],\n      rules: {\n        \"import/no-extraneous-dependencies\": \"off\",\n      },\n    });\n\n    /**\n     * Some standard ignores for all projects.\n     */\n    this.gitignore?.addPatterns(\".DS_Store\");\n    this.npmignore?.addPatterns(\"*.spec.*\", \"*.test.*\", \"__fixtures__\");\n\n    /**\n     * If turbo is active in the parent project, configure it here.\n     */\n    const turboActive =\n      userOptions.parent && TurboRepo.of(userOptions.parent) !== undefined;\n    if (turboActive) {\n      const turbo = new TurboRepo(this);\n      turbo.compileTask?.outputs.push(\"dist/**\");\n      turbo.compileTask?.outputs.push(\"lib/**\");\n      //turbo.testTask?.inputs.push(\"src/**\");\n    }\n\n    /**\n     * Add reset task if enabled.\n     */\n    if (options.resetTask !== false) {\n      const defaultResetTaskOptions: ResetTaskOptions = {\n        pathsToRemove: [\n          \"node_modules\",\n          \"dist\",\n          \"lib\",\n          \"coverage\",\n          \"test-reports\",\n          \".turbo\",\n          \"tsconfig.tsbuildinfo\",\n          this.artifactsDirectory,\n        ],\n      };\n      const userResetTaskOptions = options.resetTaskOptions ?? {};\n      const resetTaskOptions: ResetTaskOptions = merge(\n        defaultResetTaskOptions,\n        {\n          ...userResetTaskOptions,\n          pathsToRemove: [\n            ...(defaultResetTaskOptions.pathsToRemove ?? []),\n            ...(userResetTaskOptions.pathsToRemove ?? []),\n          ],\n        },\n      );\n      new ResetTask(this, resetTaskOptions);\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./reset-task";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./reset-task"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGFza3MvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLCtDQUE2QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL3Jlc2V0LXRhc2tcIjtcbiJdfQ==
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Component, Project } from "projen";
|
|
2
|
+
/*******************************************************************************
|
|
3
|
+
*
|
|
4
|
+
* Reset Task Component
|
|
5
|
+
*
|
|
6
|
+
* Adds a "reset" task that deletes all build artifacts produced by the build
|
|
7
|
+
* process. This includes node_modules, lib, dist, coverage, test-reports,
|
|
8
|
+
* .turbo, and tsconfig.tsbuildinfo.
|
|
9
|
+
*
|
|
10
|
+
******************************************************************************/
|
|
11
|
+
export interface ResetTaskOptions {
|
|
12
|
+
/**
|
|
13
|
+
* Custom output directory to delete (overrides tsconfig artifactsDirectory detection).
|
|
14
|
+
*
|
|
15
|
+
* @default - detected from typescript project.artifactsDirectory or "lib"
|
|
16
|
+
*/
|
|
17
|
+
readonly artifactsDirectory?: string;
|
|
18
|
+
/**
|
|
19
|
+
* Array of glob patterns for paths to remove.
|
|
20
|
+
* If empty, the artifactsDirectory will be added automatically.
|
|
21
|
+
*
|
|
22
|
+
* @default []
|
|
23
|
+
*/
|
|
24
|
+
readonly pathsToRemove?: string[];
|
|
25
|
+
/**
|
|
26
|
+
* Name of the task to create.
|
|
27
|
+
*
|
|
28
|
+
* @default "reset"
|
|
29
|
+
*/
|
|
30
|
+
readonly taskName?: string;
|
|
31
|
+
}
|
|
32
|
+
export declare class ResetTask extends Component {
|
|
33
|
+
readonly project: Project;
|
|
34
|
+
/**
|
|
35
|
+
* Static method to discover reset task in a project.
|
|
36
|
+
*/
|
|
37
|
+
static of(project: Project): ResetTask | undefined;
|
|
38
|
+
/**
|
|
39
|
+
* The output directory to delete (from tsconfig or custom).
|
|
40
|
+
*/
|
|
41
|
+
readonly artifactsDirectory: string;
|
|
42
|
+
/**
|
|
43
|
+
* The final array of paths that will be removed by the reset task.
|
|
44
|
+
*/
|
|
45
|
+
readonly pathsToRemove: string[];
|
|
46
|
+
/**
|
|
47
|
+
* The name of the task that was created.
|
|
48
|
+
*/
|
|
49
|
+
readonly taskName: string;
|
|
50
|
+
constructor(project: Project, options?: ResetTaskOptions);
|
|
51
|
+
}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ResetTask = void 0;
|
|
4
|
+
const projen_1 = require("projen");
|
|
5
|
+
const typescript_project_1 = require("../projects/typescript-project");
|
|
6
|
+
const turbo_repo_1 = require("../turbo/turbo-repo");
|
|
7
|
+
const turbo_repo_task_1 = require("../turbo/turbo-repo-task");
|
|
8
|
+
class ResetTask extends projen_1.Component {
|
|
9
|
+
/**
|
|
10
|
+
* Static method to discover reset task in a project.
|
|
11
|
+
*/
|
|
12
|
+
static of(project) {
|
|
13
|
+
const isDefined = (c) => c instanceof ResetTask;
|
|
14
|
+
return project.components.find(isDefined);
|
|
15
|
+
}
|
|
16
|
+
constructor(project, options = {}) {
|
|
17
|
+
super(project);
|
|
18
|
+
this.project = project;
|
|
19
|
+
/**
|
|
20
|
+
* Determine the output directory.
|
|
21
|
+
* 1. Use custom artifactsDirectory if provided
|
|
22
|
+
* 2. Use the artifacts directory if project is TypeScriptProject
|
|
23
|
+
* 3. Default to "lib"
|
|
24
|
+
*/
|
|
25
|
+
this.artifactsDirectory = options.artifactsDirectory
|
|
26
|
+
? options.artifactsDirectory
|
|
27
|
+
: project instanceof typescript_project_1.TypeScriptProject
|
|
28
|
+
? project.artifactsDirectory
|
|
29
|
+
: "lib";
|
|
30
|
+
/**
|
|
31
|
+
* Build the paths array to remove.
|
|
32
|
+
* If pathsToRemove is empty, add artifactsDirectory.
|
|
33
|
+
* If pathsToRemove is not empty, use it as-is (artifactsDirectory is not automatically added).
|
|
34
|
+
* Remove duplicate entries from the array.
|
|
35
|
+
*/
|
|
36
|
+
const pathsToRemove = options.pathsToRemove ?? [];
|
|
37
|
+
const finalPaths = pathsToRemove.length === 0 ? [this.artifactsDirectory] : pathsToRemove;
|
|
38
|
+
/**
|
|
39
|
+
* Remove duplicate paths from the array.
|
|
40
|
+
*/
|
|
41
|
+
this.pathsToRemove = Array.from(new Set(finalPaths));
|
|
42
|
+
/**
|
|
43
|
+
* Determine the task name.
|
|
44
|
+
*/
|
|
45
|
+
this.taskName = options.taskName ?? "reset";
|
|
46
|
+
/**
|
|
47
|
+
* Create the reset task.
|
|
48
|
+
*/
|
|
49
|
+
const resetTask = this.project.tasks.addTask(this.taskName, {
|
|
50
|
+
description: "Delete build artifacts specified by pathsToRemove option, or artifactsDirectory if pathsToRemove is empty",
|
|
51
|
+
});
|
|
52
|
+
/**
|
|
53
|
+
* Delete build artifacts with existence checks.
|
|
54
|
+
* Using shell conditionals to only delete if paths exist.
|
|
55
|
+
* Using -e to check existence (works for both files and directories).
|
|
56
|
+
*/
|
|
57
|
+
this.pathsToRemove.forEach((path) => {
|
|
58
|
+
resetTask.exec(`[ -e "${path}" ] && rm -rf ${path} || true`);
|
|
59
|
+
});
|
|
60
|
+
/**
|
|
61
|
+
* Turbo tasks are added after all components are created.
|
|
62
|
+
* This assumes turbo is built first so that it's available to be
|
|
63
|
+
* referenced. This could introduce problems in future but works for now.
|
|
64
|
+
*/
|
|
65
|
+
/**
|
|
66
|
+
* Check if turborepo is active.
|
|
67
|
+
*/
|
|
68
|
+
const rootHasTurbo = turbo_repo_1.TurboRepo.of(this.project.root) !== undefined;
|
|
69
|
+
const isSubproject = this.project !== this.project.root;
|
|
70
|
+
const isRootProject = this.project === this.project.root;
|
|
71
|
+
/**
|
|
72
|
+
* If turborepo is active for the subproject, add turbo tasks.
|
|
73
|
+
*/
|
|
74
|
+
if (isSubproject && rootHasTurbo) {
|
|
75
|
+
/**
|
|
76
|
+
* Get TurboRepo instance for this subproject.
|
|
77
|
+
* It should exist by now since preSynthesize runs after all components are created.
|
|
78
|
+
*/
|
|
79
|
+
const turbo = turbo_repo_1.TurboRepo.of(this.project);
|
|
80
|
+
if (turbo && !turbo.isRootProject) {
|
|
81
|
+
/**
|
|
82
|
+
* Create turbo:reset task (or turbo:${taskName}).
|
|
83
|
+
*/
|
|
84
|
+
const turboResetTask = new turbo_repo_task_1.TurboRepoTask(this.project, {
|
|
85
|
+
name: `turbo:${this.taskName}`,
|
|
86
|
+
cache: false,
|
|
87
|
+
});
|
|
88
|
+
turbo.tasks.push(turboResetTask);
|
|
89
|
+
/**
|
|
90
|
+
* Create a turbo task with the same name as the reset task.
|
|
91
|
+
*/
|
|
92
|
+
const turboTaskWithSameName = new turbo_repo_task_1.TurboRepoTask(this.project, {
|
|
93
|
+
name: this.taskName,
|
|
94
|
+
cache: false,
|
|
95
|
+
});
|
|
96
|
+
turbo.tasks.push(turboTaskWithSameName);
|
|
97
|
+
/**
|
|
98
|
+
* turboResetTask depends on turboTaskWithSameName so that the reset task
|
|
99
|
+
* can be run across all suprojects using turbo:reset as the entry point.
|
|
100
|
+
*/
|
|
101
|
+
turboResetTask.dependsOn.push(turboTaskWithSameName.name);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* If reset-task is in the root project, add a turbo task that will trigger
|
|
106
|
+
* all the subtasks using dependsOn of "^turbo:reset".
|
|
107
|
+
*/
|
|
108
|
+
if (isRootProject && rootHasTurbo) {
|
|
109
|
+
const turbo = turbo_repo_1.TurboRepo.of(this.project);
|
|
110
|
+
if (turbo && turbo.isRootProject) {
|
|
111
|
+
/**
|
|
112
|
+
* Create turbo:reset task (or turbo:${taskName}) in the root project.
|
|
113
|
+
* The ^ prefix means "run this task in all dependencies first".
|
|
114
|
+
*/
|
|
115
|
+
const rootTurboResetTask = new turbo_repo_task_1.TurboRepoTask(this.project, {
|
|
116
|
+
name: `turbo:${this.taskName}`,
|
|
117
|
+
dependsOn: [`^turbo:${this.taskName}`],
|
|
118
|
+
cache: false,
|
|
119
|
+
});
|
|
120
|
+
turbo.tasks.push(rootTurboResetTask);
|
|
121
|
+
/**
|
|
122
|
+
* Create a turbo task with the same name as the reset task.
|
|
123
|
+
*/
|
|
124
|
+
const turboTaskWithSameName = new turbo_repo_task_1.TurboRepoTask(this.project, {
|
|
125
|
+
name: this.taskName,
|
|
126
|
+
cache: false,
|
|
127
|
+
});
|
|
128
|
+
turbo.tasks.push(turboTaskWithSameName);
|
|
129
|
+
/**
|
|
130
|
+
* rootTurboResetTask depends on turboTaskWithSameName so that the reset task
|
|
131
|
+
* can be run across all suprojects using turbo:reset as the entry point.
|
|
132
|
+
*/
|
|
133
|
+
rootTurboResetTask.dependsOn.push(turboTaskWithSameName.name);
|
|
134
|
+
/**
|
|
135
|
+
* Create reset:all task - a projen task that calls the turbo task.
|
|
136
|
+
* This is similar to build:all in turbo-repo.ts.
|
|
137
|
+
*/
|
|
138
|
+
const resetAllTask = this.project.tasks.addTask(`${this.taskName}:all`, {
|
|
139
|
+
description: `Reset all build artifacts across the monorepo by running turbo:${this.taskName} in all subprojects.`,
|
|
140
|
+
});
|
|
141
|
+
resetAllTask.exec("turbo telemetry disable");
|
|
142
|
+
resetAllTask.exec(`turbo turbo:${this.taskName} --summarize --concurrency=10`);
|
|
143
|
+
resetAllTask.exec(`pnpm ${this.taskName}`);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
exports.ResetTask = ResetTask;
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reset-task.js","sourceRoot":"","sources":["../../src/tasks/reset-task.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Project } from \"projen\";\nimport { TypeScriptProject } from \"../projects/typescript-project\";\nimport { TurboRepo } from \"../turbo/turbo-repo\";\nimport { TurboRepoTask } from \"../turbo/turbo-repo-task\";\n\n/*******************************************************************************\n *\n * Reset Task Component\n *\n * Adds a \"reset\" task that deletes all build artifacts produced by the build\n * process. This includes node_modules, lib, dist, coverage, test-reports,\n * .turbo, and tsconfig.tsbuildinfo.\n *\n ******************************************************************************/\n\nexport interface ResetTaskOptions {\n  /**\n   * Custom output directory to delete (overrides tsconfig artifactsDirectory detection).\n   *\n   * @default - detected from typescript project.artifactsDirectory or \"lib\"\n   */\n  readonly artifactsDirectory?: string;\n\n  /**\n   * Array of glob patterns for paths to remove.\n   * If empty, the artifactsDirectory will be added automatically.\n   *\n   * @default []\n   */\n  readonly pathsToRemove?: string[];\n\n  /**\n   * Name of the task to create.\n   *\n   * @default \"reset\"\n   */\n  readonly taskName?: string;\n}\n\nexport class ResetTask extends Component {\n  /**\n   * Static method to discover reset task in a project.\n   */\n  public static of(project: Project): ResetTask | undefined {\n    const isDefined = (c: Component): c is ResetTask => c instanceof ResetTask;\n    return project.components.find(isDefined);\n  }\n\n  /**\n   * The output directory to delete (from tsconfig or custom).\n   */\n  public readonly artifactsDirectory: string;\n\n  /**\n   * The final array of paths that will be removed by the reset task.\n   */\n  public readonly pathsToRemove: string[];\n\n  /**\n   * The name of the task that was created.\n   */\n  public readonly taskName: string;\n\n  constructor(\n    public readonly project: Project,\n    options: ResetTaskOptions = {},\n  ) {\n    super(project);\n\n    /**\n     * Determine the output directory.\n     * 1. Use custom artifactsDirectory if provided\n     * 2. Use the artifacts directory if project is TypeScriptProject\n     * 3. Default to \"lib\"\n     */\n    this.artifactsDirectory = options.artifactsDirectory\n      ? options.artifactsDirectory\n      : project instanceof TypeScriptProject\n        ? project.artifactsDirectory\n        : \"lib\";\n\n    /**\n     * Build the paths array to remove.\n     * If pathsToRemove is empty, add artifactsDirectory.\n     * If pathsToRemove is not empty, use it as-is (artifactsDirectory is not automatically added).\n     * Remove duplicate entries from the array.\n     */\n    const pathsToRemove = options.pathsToRemove ?? [];\n    const finalPaths =\n      pathsToRemove.length === 0 ? [this.artifactsDirectory] : pathsToRemove;\n\n    /**\n     * Remove duplicate paths from the array.\n     */\n    this.pathsToRemove = Array.from(new Set(finalPaths));\n\n    /**\n     * Determine the task name.\n     */\n    this.taskName = options.taskName ?? \"reset\";\n\n    /**\n     * Create the reset task.\n     */\n    const resetTask = this.project.tasks.addTask(this.taskName, {\n      description:\n        \"Delete build artifacts specified by pathsToRemove option, or artifactsDirectory if pathsToRemove is empty\",\n    });\n\n    /**\n     * Delete build artifacts with existence checks.\n     * Using shell conditionals to only delete if paths exist.\n     * Using -e to check existence (works for both files and directories).\n     */\n    this.pathsToRemove.forEach((path) => {\n      resetTask.exec(`[ -e \"${path}\" ] && rm -rf ${path} || true`);\n    });\n\n    /**\n     * Turbo tasks are added after all components are created.\n     * This assumes turbo is built first so that it's available to be\n     * referenced. This could introduce problems in future but works for now.\n     */\n\n    /**\n     * Check if turborepo is active.\n     */\n    const rootHasTurbo = TurboRepo.of(this.project.root) !== undefined;\n    const isSubproject = this.project !== this.project.root;\n    const isRootProject = this.project === this.project.root;\n\n    /**\n     * If turborepo is active for the subproject, add turbo tasks.\n     */\n    if (isSubproject && rootHasTurbo) {\n      /**\n       * Get TurboRepo instance for this subproject.\n       * It should exist by now since preSynthesize runs after all components are created.\n       */\n      const turbo = TurboRepo.of(this.project);\n      if (turbo && !turbo.isRootProject) {\n        /**\n         * Create turbo:reset task (or turbo:${taskName}).\n         */\n        const turboResetTask = new TurboRepoTask(this.project, {\n          name: `turbo:${this.taskName}`,\n          cache: false,\n        });\n        turbo.tasks.push(turboResetTask);\n\n        /**\n         * Create a turbo task with the same name as the reset task.\n         */\n        const turboTaskWithSameName = new TurboRepoTask(this.project, {\n          name: this.taskName,\n          cache: false,\n        });\n        turbo.tasks.push(turboTaskWithSameName);\n\n        /**\n         * turboResetTask depends on turboTaskWithSameName so that the reset task\n         * can be run across all suprojects using turbo:reset as the entry point.\n         */\n        turboResetTask.dependsOn.push(turboTaskWithSameName.name);\n      }\n    }\n\n    /**\n     * If reset-task is in the root project, add a turbo task that will trigger\n     * all the subtasks using dependsOn of \"^turbo:reset\".\n     */\n    if (isRootProject && rootHasTurbo) {\n      const turbo = TurboRepo.of(this.project);\n      if (turbo && turbo.isRootProject) {\n        /**\n         * Create turbo:reset task (or turbo:${taskName}) in the root project.\n         * The ^ prefix means \"run this task in all dependencies first\".\n         */\n        const rootTurboResetTask = new TurboRepoTask(this.project, {\n          name: `turbo:${this.taskName}`,\n          dependsOn: [`^turbo:${this.taskName}`],\n          cache: false,\n        });\n        turbo.tasks.push(rootTurboResetTask);\n\n        /**\n         * Create a turbo task with the same name as the reset task.\n         */\n        const turboTaskWithSameName = new TurboRepoTask(this.project, {\n          name: this.taskName,\n          cache: false,\n        });\n        turbo.tasks.push(turboTaskWithSameName);\n\n        /**\n         * rootTurboResetTask depends on turboTaskWithSameName so that the reset task\n         * can be run across all suprojects using turbo:reset as the entry point.\n         */\n        rootTurboResetTask.dependsOn.push(turboTaskWithSameName.name);\n\n        /**\n         * Create reset:all task - a projen task that calls the turbo task.\n         * This is similar to build:all in turbo-repo.ts.\n         */\n        const resetAllTask = this.project.tasks.addTask(\n          `${this.taskName}:all`,\n          {\n            description: `Reset all build artifacts across the monorepo by running turbo:${this.taskName} in all subprojects.`,\n          },\n        );\n        resetAllTask.exec(\"turbo telemetry disable\");\n        resetAllTask.exec(\n          `turbo turbo:${this.taskName} --summarize --concurrency=10`,\n        );\n        resetAllTask.exec(`pnpm ${this.taskName}`);\n      }\n    }\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -41,7 +41,7 @@
|
|
|
41
41
|
},
|
|
42
42
|
"main": "lib/index.js",
|
|
43
43
|
"license": "MIT",
|
|
44
|
-
"version": "0.0.
|
|
44
|
+
"version": "0.0.80",
|
|
45
45
|
"types": "lib/index.d.ts",
|
|
46
46
|
"//": "~~ Generated by projen. To modify, edit .projenrc.js and run \"npx projen\".",
|
|
47
47
|
"scripts": {
|
|
@@ -55,6 +55,7 @@
|
|
|
55
55
|
"post-upgrade": "npx projen post-upgrade",
|
|
56
56
|
"pre-compile": "npx projen pre-compile",
|
|
57
57
|
"release": "npx projen release",
|
|
58
|
+
"reset": "npx projen reset",
|
|
58
59
|
"test": "npx projen test",
|
|
59
60
|
"test:watch": "npx projen test:watch",
|
|
60
61
|
"unbump": "npx projen unbump",
|