UNPKG

@aws/pdk

Version:

All documentation is located at: https://aws.github.io/aws-pdk

29 lines 13 kB
"use strict"; /*! Copyright [Amazon.com](http://amazon.com/), Inc. or its affiliates. All Rights Reserved. SPDX-License-Identifier: Apache-2.0 */ Object.defineProperty(exports, "__esModule", { value: true }); exports.Nx = void 0; var Nx; (function (Nx) { /** * Supported enums for a TargetDependency. */ let TargetDependencyProject; (function (TargetDependencyProject) { /** * Only rely on the package where the target is called. * * This is usually done for test like targets where you only want to run unit * tests on the target packages without testing all dependent packages. */ TargetDependencyProject["SELF"] = "self"; /** * Target relies on executing the target against all dependencies first. * * This is usually done for build like targets where you want to build all * dependant projects first. */ TargetDependencyProject["DEPENDENCIES"] = "dependencies"; })(TargetDependencyProject = Nx.TargetDependencyProject || (Nx.TargetDependencyProject = {})); })(Nx || (exports.Nx = Nx = {})); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nx-types.js","sourceRoot":"","sources":["nx-types.ts"],"names":[],"mappings":";AAAA;sCACsC;;;AAItC,IAAiB,EAAE,CAiTlB;AAjTD,WAAiB,EAAE;IAwDjB;;OAEG;IACH,IAAY,uBAeX;IAfD,WAAY,uBAAuB;QACjC;;;;;WAKG;QACH,wCAAa,CAAA;QACb;;;;;WAKG;QACH,wDAA6B,CAAA;IAC/B,CAAC,EAfW,uBAAuB,GAAvB,0BAAuB,KAAvB,0BAAuB,QAelC;AAuOH,CAAC,EAjTgB,EAAE,kBAAF,EAAE,QAiTlB","sourcesContent":["/*! Copyright [Amazon.com](http://amazon.com/), Inc. or its affiliates. All Rights Reserved.\nSPDX-License-Identifier: Apache-2.0 */\n\nimport { Obj } from \"projen/lib/util\";\n\nexport namespace Nx {\n  /**\n   * Configuration for nx targetDependencies.\n   */\n  export type TargetDependencies = { [target: string]: ITargetDependency[] };\n\n  /**\n   * Configuration for project specific targets.\n   */\n  export type ProjectTargets = { [target: string]: IProjectTarget };\n\n  export interface IInput {\n    fileset?: string;\n    runtime?: string;\n    env?: string;\n  }\n\n  /** Inputs type */\n  export type Inputs = (string | IInput)[];\n\n  /** Output type */\n  export type Outputs = string[];\n\n  /**\n   * Project Target.\n   */\n  export interface IProjectTarget {\n    /**\n     * List of inputs to hash for cache key, relative to the root of the monorepo.\n     *\n     * note: must start with leading /\n     */\n    inputs?: Inputs;\n    /**\n     * List of outputs to cache, relative to the root of the monorepo.\n     *\n     * note: must start with leading /\n     */\n    outputs?: string[];\n\n    /**\n     * List of Target Dependencies.\n     */\n    dependsOn?: (string | ITargetDependency)[];\n\n    /**\n     * The function that Nx will invoke when you run this target\n     */\n    executor?: string;\n\n    /**\n     * Contains whatever configuration properties the executor needs to run.\n     */\n    options?: any;\n  }\n\n  /**\n   * Supported enums for a TargetDependency.\n   */\n  export enum TargetDependencyProject {\n    /**\n     * Only rely on the package where the target is called.\n     *\n     * This is usually done for test like targets where you only want to run unit\n     * tests on the target packages without testing all dependent packages.\n     */\n    SELF = \"self\",\n    /**\n     * Target relies on executing the target against all dependencies first.\n     *\n     * This is usually done for build like targets where you want to build all\n     * dependant projects first.\n     */\n    DEPENDENCIES = \"dependencies\",\n  }\n\n  /**\n   * Represents an NX Target Dependency.\n   */\n  export interface ITargetDependency {\n    /**\n     * Projen target i.e: build, test, etc\n     */\n    target: string;\n\n    /**\n     * Target dependencies.\n     */\n    projects: TargetDependencyProject;\n  }\n\n  /**\n   * Named inputs config\n   * @see https://nx.dev/reference/nx-json#inputs-&-namedinputs\n   */\n  export type INamedInputs = { [name: string]: string[] };\n\n  /**\n   * Target defaults config\n   * @see https://nx.dev/reference/nx-json#target-defaults\n   */\n  export type ITargetDefaults = { [name: string]: IProjectTarget };\n\n  /**\n   * Default options for `nx affected`\n   * @see https://github.com/nrwl/nx/blob/065477610605d5799babc3ba78f26cdfe8737250/packages/nx/src/config/nx-json.ts#L16\n   */\n  export interface INxAffectedConfig {\n    /** Default based branch used by affected commands. */\n    defaultBase?: string;\n  }\n\n  /**\n   * Where new apps + libs should be placed\n   */\n  export interface IWorkspaceLayout {\n    libsDir: string;\n    appsDir: string;\n  }\n\n  /**\n   * @see https://nx.dev/reference/nx-json\n   * @see https://github.com/nrwl/nx/blob/master/packages/nx/src/config/nx-json.ts\n   */\n  export interface NxJsonConfiguration {\n    /**\n     * Some presets use the extends property to hide some default options in a separate json file.\n     * The json file specified in the extends property is located in your node_modules folder.\n     * The Nx preset files are specified in the nx package.\n     *\n     * @default \"nx/presets/npm.json\"\n     */\n    readonly extends?: string;\n\n    /**\n     * Tells Nx what prefix to use when generating library imports.\n     */\n    readonly npmScope?: string;\n\n    /**\n     * Named inputs\n     * @see https://nx.dev/reference/nx-json#inputs-&-namedinputs\n     */\n    readonly namedInputs?: INamedInputs;\n\n    /**\n     * Default options for `nx affected`\n     */\n    readonly affected?: INxAffectedConfig;\n\n    /**\n     * Dependencies between different target names across all projects\n     *\n     * @see https://nx.dev/reference/nx-json#target-defaults\n     */\n    readonly targetDefaults?: ITargetDefaults;\n\n    /**\n     * Where new apps + libs should be placed\n     */\n    readonly workspaceLayout?: IWorkspaceLayout;\n\n    /**\n     * Available Task Runners\n     */\n    readonly tasksRunnerOptions?: Obj<any>;\n\n    /**\n     * Plugins for extending the project graph\n     */\n    readonly plugins?: string[];\n\n    /**\n     * Configuration for Nx Plugins\n     */\n    readonly pluginsConfig?: Obj<any>;\n\n    /**\n     * Default project. When project isn't provided, the default project\n     * will be used. Convenient for small workspaces with one main application.\n     */\n    readonly defaultProject?: string;\n  }\n\n  /**\n   * NX workspace configurations.\n   *\n   * @see https://nx.dev/configuration/packagejson\n   */\n  export interface WorkspaceConfig {\n    /**\n     * List of patterns to include in the .nxignore file.\n     *\n     * @see https://nx.dev/configuration/packagejson#nxignore\n     */\n    readonly nxIgnore?: string[];\n\n    /**\n     * Defines the list of targets/operations that are cached by Nx\n     *\n     * @default [\"build\", \"test\"]\n     * @see https://nx.dev/reference/nx-json#tasks-runner-options\n     */\n    readonly cacheableOperations?: string[];\n\n    readonly defaultBuildOutputs?: string[];\n\n    /**\n     * Read only access token if enabling nx cloud.\n     */\n    readonly nxCloudReadOnlyAccessToken?: string;\n\n    /**\n     * Use non-native hasher for nx tasks.\n     *\n     * Sets `NX_NON_NATIVE_HASHER=true` environment variable on nx based tasks.\n     * @see https://github.com/nrwl/nx/pull/15071\n     */\n    readonly nonNativeHasher?: boolean;\n\n    // nxJson?: INxJson;\n  }\n\n  /**\n   * @see https://github.com/nrwl/nx/blob/master/packages/nx/schemas/project-schema.json\n   */\n  export interface ProjectConfig {\n    /** Name of project */\n    readonly name?: string;\n    /** Project root dir path relative to workspace */\n    readonly root?: string;\n\n    /**\n     * Named inputs\n     * @see https://nx.dev/reference/nx-json#inputs-&-namedinputs\n     */\n    readonly namedInputs?: INamedInputs;\n\n    /**\n     * Targets configuration\n     * @see https://nx.dev/reference/project-configuration\n     */\n    readonly targets?: ProjectTargets;\n\n    /**\n     * Project tag annotations\n     *\n     * @see https://nx.dev/reference/project-configuration#tags\n     */\n    readonly tags?: string[];\n\n    /**\n     * Implicit dependencies\n     *\n     * @see https://nx.dev/reference/project-configuration#implicitdependencies\n     */\n    readonly implicitDependencies?: string[];\n\n    /**\n     * Explicit list of scripts for Nx to include.\n     * @see https://nx.dev/reference/project-configuration#ignoring-package.json-scripts\n     */\n    readonly includedScripts?: string[];\n  }\n\n  /**\n   *\n   * @see https://nx.dev/packages/nx/documents/run-many#options\n   */\n  export interface RunManyOptions {\n    /** Task to run for affected projects */\n    readonly target: string;\n    /** This is the configuration to use when performing tasks on projects */\n    readonly configuration?: string;\n    /** Exclude certain projects from being processed */\n    readonly exclude?: string;\n    /**\n     * Do not stop command execution after the first failed task.\n     */\n    readonly noBail?: boolean;\n    /**\n     * Defines how Nx emits outputs tasks logs\n     * @default \"stream\"\n     */\n    readonly outputStyle?:\n      | \"dynamic\"\n      | \"static\"\n      | \"stream\"\n      | \"stream-without-prefixes\";\n    /**\n     * Max number of parallel processes\n     * @default 3\n     */\n    readonly parallel?: number;\n    /** Project to run as list project names and/or patterns. */\n    readonly projects?: string[];\n    /** This is the name of the tasks runner configuration in nx.json */\n    readonly runner?: string;\n    /** Rerun the tasks even when the results are available in the cache. */\n    readonly skipCache?: boolean;\n    /** Ignore cycles in the task graph */\n    readonly ignoreCycles?: boolean;\n    /** Prints additional information about the commands (e.g. stack traces). */\n    readonly verbose?: boolean;\n  }\n}\n"]}