projen-modules 0.0.39 → 0.1.1

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.
Files changed (41) hide show
  1. package/.jsii +7196 -168
  2. package/API.md +2709 -2438
  3. package/README.md +10 -3
  4. package/lib/circleci.d.ts +1 -1
  5. package/lib/circleci.js +1 -1
  6. package/lib/components/github/codeowners.js +17 -0
  7. package/lib/components/github/pull-request-template.js +17 -0
  8. package/lib/components/index.d.ts +2 -0
  9. package/lib/components/index.js +21 -0
  10. package/lib/components/readme/elements/index.d.ts +1 -0
  11. package/lib/components/readme/elements/index.js +18 -0
  12. package/lib/components/readme/elements/section.d.ts +9 -0
  13. package/lib/components/readme/elements/section.js +19 -0
  14. package/lib/components/readme/index.d.ts +8 -0
  15. package/lib/components/readme/index.js +24 -0
  16. package/lib/index.d.ts +2 -3
  17. package/lib/index.js +3 -4
  18. package/lib/projects/index.d.ts +3 -0
  19. package/lib/projects/index.js +20 -0
  20. package/lib/projects/jsii/index.d.ts +14 -0
  21. package/lib/projects/jsii/index.js +58 -0
  22. package/lib/projects/jsii/jsii-project-options.d.ts +1106 -0
  23. package/lib/projects/jsii/jsii-project-options.js +3 -0
  24. package/lib/{npm → projects/npm}/index.d.ts +2 -7
  25. package/lib/projects/npm/index.js +63 -0
  26. package/lib/projects/npm/npm-package-options.d.ts +1000 -0
  27. package/lib/projects/npm/npm-package-options.js +3 -0
  28. package/lib/projects/python/index.d.ts +12 -0
  29. package/lib/projects/python/index.js +58 -0
  30. package/lib/projects/python/python-package-options.d.ts +391 -0
  31. package/lib/projects/python/python-package-options.js +3 -0
  32. package/package.json +4 -3
  33. package/lib/github/codeowners.js +0 -17
  34. package/lib/github/pull-request-template.js +0 -17
  35. package/lib/jsii/index.d.ts +0 -17
  36. package/lib/jsii/index.js +0 -47
  37. package/lib/npm/index.js +0 -52
  38. package/lib/python/index.d.ts +0 -29
  39. package/lib/python/index.js +0 -47
  40. /package/lib/{github → components/github}/codeowners.d.ts +0 -0
  41. /package/lib/{github → components/github}/pull-request-template.d.ts +0 -0
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"npm-package-options.js","sourceRoot":"","sources":["../../../src/projects/npm/npm-package-options.ts"],"names":[],"mappings":"","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\".\nimport type { github, GitOptions, GroupRunnerOptions, IgnoreFileOptions, javascript, LoggerOptions, Project, ProjectType, ProjenrcJsonOptions, ReleasableCommits, release, RenovatebotOptions, typescript } from 'projen';\n\n/**\n * NpmPackageOptions\n */\nexport interface NpmPackageOptions {\n  /**\n   * TypeScript version to use.\n   * NOTE: Typescript is not semantically versioned and should remain on the\n   * same minor, so we recommend using a `~` dependency (e.g. `~1.2.3`).\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly typescriptVersion?: string;\n  /**\n   * Options for ts-jest.\n   * @stability experimental\n   */\n  readonly tsJestOptions?: typescript.TsJestOptions;\n  /**\n   * The name of the development tsconfig.json file.\n   * @default \"tsconfig.dev.json\"\n   * @stability experimental\n   */\n  readonly tsconfigDevFile?: string;\n  /**\n   * Custom tsconfig options for the development tsconfig.json file (used for testing).\n   * @default - use the production tsconfig options\n   * @stability experimental\n   */\n  readonly tsconfigDev?: javascript.TypescriptConfigOptions;\n  /**\n   * Custom TSConfig.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly tsconfig?: javascript.TypescriptConfigOptions;\n  /**\n   * Jest tests directory. Tests files should be named `xxx.test.ts`.\n   * If this directory is under `srcdir` (e.g. `src/test`, `src/__tests__`),\n   * then tests are going to be compiled into `lib/` and executed as javascript.\n   * If the test directory is outside of `src`, then we configure jest to\n   * compile the code in-memory.\n   * @default \"test\"\n   * @stability experimental\n   */\n  readonly testdir?: string;\n  /**\n   * Typescript sources directory.\n   * @default \"src\"\n   * @stability experimental\n   */\n  readonly srcdir?: string;\n  /**\n   * Generate one-time sample in `src/` and `test/` if there are no files there.\n   * @default true\n   * @stability experimental\n   */\n  readonly sampleCode?: boolean;\n  /**\n   * Options for .projenrc.ts.\n   * @stability experimental\n   */\n  readonly projenrcTsOptions?: typescript.ProjenrcOptions;\n  /**\n   * Use TypeScript for your projenrc file (`.projenrc.ts`).\n   * @default false\n   * @stability experimental\n   * @pjnew true\n   */\n  readonly projenrcTs?: boolean;\n  /**\n   * Typescript  artifacts output directory.\n   * @default \"lib\"\n   * @stability experimental\n   */\n  readonly libdir?: string;\n  /**\n   * Eslint options.\n   * @default - opinionated default options\n   * @stability experimental\n   */\n  readonly eslintOptions?: javascript.EslintOptions;\n  /**\n   * Setup eslint.\n   * @default true\n   * @stability experimental\n   */\n  readonly eslint?: boolean;\n  /**\n   * The .d.ts file that includes the type declarations for this module.\n   * @default - .d.ts file derived from the project's entrypoint (usually lib/index.d.ts)\n   * @stability experimental\n   */\n  readonly entrypointTypes?: string;\n  /**\n   * Docs directory.\n   * @default \"docs\"\n   * @stability experimental\n   */\n  readonly docsDirectory?: string;\n  /**\n   * Docgen by Typedoc.\n   * @default false\n   * @stability experimental\n   */\n  readonly docgen?: boolean;\n  /**\n   * Do not generate a `tsconfig.dev.json` file.\n   * @default false\n   * @stability experimental\n   */\n  readonly disableTsconfigDev?: boolean;\n  /**\n   * Do not generate a `tsconfig.json` file (used by jsii projects since tsconfig.json is generated by the jsii compiler).\n   * @default false\n   * @stability experimental\n   */\n  readonly disableTsconfig?: boolean;\n  /**\n   * Enable Node.js package cache in GitHub workflows.\n   * @default false\n   * @stability experimental\n   */\n  readonly workflowPackageCache?: boolean;\n  /**\n   * The node version used in GitHub Actions workflows.\n   * Always use this option if your GitHub Actions workflows require a specific to run.\n   * @default - `minNodeVersion` if set, otherwise `lts/*`.\n   * @stability experimental\n   */\n  readonly workflowNodeVersion?: string;\n  /**\n   * The git identity to use in workflows.\n   * @default - GitHub Actions\n   * @stability experimental\n   */\n  readonly workflowGitIdentity?: github.GitIdentity;\n  /**\n   * Workflow steps to use in order to bootstrap this repo.\n   * @default \"yarn install --frozen-lockfile && yarn projen\"\n   * @stability experimental\n   */\n  readonly workflowBootstrapSteps?: Array<github.workflows.JobStep>;\n  /**\n   * DEPRECATED: renamed to `release`.\n   * @default - true if not a subproject\n   * @deprecated see `release`.\n   * @stability deprecated\n   */\n  readonly releaseWorkflow?: boolean;\n  /**\n   * Automatically release to npm when new versions are introduced.\n   * @default false\n   * @stability experimental\n   */\n  readonly releaseToNpm?: boolean;\n  /**\n   * Add release management to this project.\n   * @default - true (false for subprojects)\n   * @stability experimental\n   */\n  readonly release?: boolean;\n  /**\n   * The contents of the pull request template.\n   * @default - default content\n   * @stability experimental\n   */\n  readonly pullRequestTemplateContents?: Array<string>;\n  /**\n   * Include a GitHub pull request template.\n   * @default true\n   * @stability experimental\n   */\n  readonly pullRequestTemplate?: boolean;\n  /**\n   * Version of projen to install.\n   * @default - Defaults to the latest version.\n   * @stability experimental\n   */\n  readonly projenVersion?: string;\n  /**\n   * Options for .projenrc.js.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcJsOptions?: javascript.ProjenrcOptions;\n  /**\n   * Generate (once) .projenrc.js (in JavaScript). Set to `false` in order to disable .projenrc.js generation.\n   * @default - true if projenrcJson is false\n   * @stability experimental\n   */\n  readonly projenrcJs?: boolean;\n  /**\n   * Indicates of \"projen\" should be installed as a devDependency.\n   * @default - true if not a subproject\n   * @stability experimental\n   */\n  readonly projenDevDependency?: boolean;\n  /**\n   * Prettier options.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly prettierOptions?: javascript.PrettierOptions;\n  /**\n   * Setup prettier.\n   * @default false\n   * @stability experimental\n   */\n  readonly prettier?: boolean;\n  /**\n   * Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`).\n   * @default true\n   * @stability experimental\n   */\n  readonly package?: boolean;\n  /**\n   * Configuration options for .npmignore file.\n   * @stability experimental\n   */\n  readonly npmIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Defines an .npmignore file. Normally this is only needed for libraries that are packaged as tarballs.\n   * @default true\n   * @stability experimental\n   */\n  readonly npmignoreEnabled?: boolean;\n  /**\n   * Additional entries to .npmignore.\n   * @deprecated - use `project.addPackageIgnore`\n   * @stability deprecated\n   */\n  readonly npmignore?: Array<string>;\n  /**\n   * Automatically update files modified during builds to pull-request branches.\n   * This means\n   * that any files synthesized by projen or e.g. test snapshots will always be up-to-date\n   * before a PR is merged.\n   *\n   * Implies that PR builds do not have anti-tamper checks.\n   * @default true\n   * @deprecated - Use `buildWorkflowOptions.mutableBuild`\n   * @stability deprecated\n   */\n  readonly mutableBuild?: boolean;\n  /**\n   * Jest options.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly jestOptions?: javascript.JestOptions;\n  /**\n   * Setup jest unit tests.\n   * @default true\n   * @stability experimental\n   */\n  readonly jest?: boolean;\n  /**\n   * Additional entries to .gitignore.\n   * @stability experimental\n   */\n  readonly gitignore?: Array<string>;\n  /**\n   * Options for `UpgradeDependencies`.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly depsUpgradeOptions?: javascript.UpgradeDependenciesOptions;\n  /**\n   * Use tasks and github workflows to handle dependency upgrades.\n   * Cannot be used in conjunction with `dependabot`.\n   * @default true\n   * @stability experimental\n   */\n  readonly depsUpgrade?: boolean;\n  /**\n   * Options for dependabot.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly dependabotOptions?: github.DependabotOptions;\n  /**\n   * Use dependabot to handle dependency upgrades.\n   * Cannot be used in conjunction with `depsUpgrade`.\n   * @default false\n   * @stability experimental\n   */\n  readonly dependabot?: boolean;\n  /**\n   * The copyright years to put in the LICENSE file.\n   * @default - current year\n   * @stability experimental\n   */\n  readonly copyrightPeriod?: string;\n  /**\n   * License copyright owner.\n   * @default - defaults to the value of authorName or \"\" if `authorName` is undefined.\n   * @stability experimental\n   */\n  readonly copyrightOwner?: string;\n  /**\n   * Define the secret name for a specified https://codecov.io/ token A secret is required to send coverage for private repositories.\n   * @default - if this option is not specified, only public repositories are supported\n   * @stability experimental\n   */\n  readonly codeCovTokenSecret?: string;\n  /**\n   * Define a GitHub workflow step for sending code coverage metrics to https://codecov.io/ Uses codecov/codecov-action@v4 A secret is required for private repos. Configured with `@codeCovTokenSecret`.\n   * @default false\n   * @stability experimental\n   */\n  readonly codeCov?: boolean;\n  /**\n   * Configure which licenses should be deemed acceptable for use by dependencies.\n   * This setting will cause the build to fail, if any prohibited or not allowed licenses ares encountered.\n   * @default - no license checks are run during the build and all licenses will be accepted\n   * @stability experimental\n   */\n  readonly checkLicenses?: javascript.LicenseCheckerOptions;\n  /**\n   * Options for `Bundler`.\n   * @stability experimental\n   */\n  readonly bundlerOptions?: javascript.BundlerOptions;\n  /**\n   * Build workflow triggers.\n   * @default \"{ pullRequest: {}, workflowDispatch: {} }\"\n   * @deprecated - Use `buildWorkflowOptions.workflowTriggers`\n   * @stability deprecated\n   */\n  readonly buildWorkflowTriggers?: github.workflows.Triggers;\n  /**\n   * Options for PR build workflow.\n   * @stability experimental\n   */\n  readonly buildWorkflowOptions?: javascript.BuildWorkflowOptions;\n  /**\n   * Define a GitHub workflow for building PRs.\n   * @default - true if not a subproject\n   * @stability experimental\n   */\n  readonly buildWorkflow?: boolean;\n  /**\n   * Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued).\n   * Throw if set to true but `autoApproveOptions` are not defined.\n   * @default - true\n   * @stability experimental\n   */\n  readonly autoApproveUpgrades?: boolean;\n  /**\n   * A directory which will contain build artifacts.\n   * @default \"dist\"\n   * @stability experimental\n   */\n  readonly artifactsDirectory?: string;\n  /**\n   * The name of the main release branch.\n   * @default \"main\"\n   * @stability experimental\n   */\n  readonly defaultReleaseBranch?: string;\n  /**\n   * Github Runner Group selection options.\n   * @stability experimental\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOnGroup?: GroupRunnerOptions;\n  /**\n   * Github Runner selection labels.\n   * @default [\"ubuntu-latest\"]\n   * @stability experimental\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOn?: Array<string>;\n  /**\n   * Container image to use for GitHub workflows.\n   * @default - default image\n   * @stability experimental\n   */\n  readonly workflowContainerImage?: string;\n  /**\n   * Custom configuration used when creating changelog with commit-and-tag-version package.\n   * Given values either append to default configuration or overwrite values in it.\n   * @default - standard configuration applicable for GitHub repositories\n   * @stability experimental\n   */\n  readonly versionrcOptions?: Record<string, any>;\n  /**\n   * A set of workflow steps to execute in order to setup the workflow container.\n   * @stability experimental\n   */\n  readonly releaseWorkflowSetupSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The name of the default release workflow.\n   * @default \"release\"\n   * @stability experimental\n   */\n  readonly releaseWorkflowName?: string;\n  /**\n   * The release trigger to use.\n   * @default - Continuous releases (`ReleaseTrigger.continuous()`)\n   * @stability experimental\n   */\n  readonly releaseTrigger?: release.ReleaseTrigger;\n  /**\n   * Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers.\n   * Note: this prefix is used to detect the latest tagged version\n   * when bumping, so if you change this on a project with an existing version\n   * history, you may need to manually tag your latest release\n   * with the new prefix.\n   * @default \"v\"\n   * @stability experimental\n   */\n  readonly releaseTagPrefix?: string;\n  /**\n   * CRON schedule to trigger new releases.\n   * @default - no scheduled releases\n   * @deprecated Use `releaseTrigger: ReleaseTrigger.scheduled()` instead\n   * @stability deprecated\n   */\n  readonly releaseSchedule?: string;\n  /**\n   * The label to apply to issues indicating publish failures.\n   * Only applies if `releaseFailureIssue` is true.\n   * @default \"failed-release\"\n   * @stability experimental\n   */\n  readonly releaseFailureIssueLabel?: string;\n  /**\n   * Create a github issue on every failed publishing task.\n   * @default false\n   * @stability experimental\n   */\n  readonly releaseFailureIssue?: boolean;\n  /**\n   * Automatically release new versions every commit to one of branches in `releaseBranches`.\n   * @default true\n   * @deprecated Use `releaseTrigger: ReleaseTrigger.continuous()` instead\n   * @stability deprecated\n   */\n  readonly releaseEveryCommit?: boolean;\n  /**\n   * Defines additional release branches.\n   * A workflow will be created for each\n   * release branch which will publish releases from commits in this branch.\n   * Each release branch _must_ be assigned a major version number which is used\n   * to enforce that versions published from that branch always use that major\n   * version. If multiple branches are used, the `majorVersion` field must also\n   * be provided for the default branch.\n   * @default - no additional branches are used for release. you can use\n`addBranch()` to add additional branches.\n   * @stability experimental\n   */\n  readonly releaseBranches?: Record<string, release.BranchOptions>;\n  /**\n   * Find commits that should be considered releasable Used to decide if a release is required.\n   * @default ReleasableCommits.everyCommit()\n   * @stability experimental\n   */\n  readonly releasableCommits?: ReleasableCommits;\n  /**\n   * Define publishing tasks that can be executed manually as well as workflows.\n   * Normally, publishing only happens within automated workflows. Enable this\n   * in order to create a publishing task for each publishing activity.\n   * @default false\n   * @stability experimental\n   */\n  readonly publishTasks?: boolean;\n  /**\n   * Instead of actually publishing to package managers, just print the publishing command.\n   * @default false\n   * @stability experimental\n   */\n  readonly publishDryRun?: boolean;\n  /**\n   * Bump versions from the default branch as pre-releases (e.g. \"beta\", \"alpha\", \"pre\").\n   * @default - normal semantic versions\n   * @stability experimental\n   */\n  readonly prerelease?: string;\n  /**\n   * Steps to execute after build as part of the release workflow.\n   * @default []\n   * @stability experimental\n   */\n  readonly postBuildSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The npmDistTag to use when publishing from the default branch.\n   * To set the npm dist-tag for release branches, set the `npmDistTag` property\n   * for each branch.\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly npmDistTag?: string;\n  /**\n   * Minimal Major version to release.\n   * This can be useful to set to 1, as breaking changes before the 1.x major\n   * release are not incrementing the major version number.\n   *\n   * Can not be set together with `majorVersion`.\n   * @default - No minimum version is being enforced\n   * @stability experimental\n   */\n  readonly minMajorVersion?: number;\n  /**\n   * Major version to release from the default branch.\n   * If this is specified, we bump the latest version of this major version line.\n   * If not specified, we bump the global latest version.\n   * @default - Major version is not enforced.\n   * @stability experimental\n   */\n  readonly majorVersion?: number;\n  /**\n   * Version requirement of `publib` which is used to publish modules to npm.\n   * @default \"latest\"\n   * @stability experimental\n   */\n  readonly jsiiReleaseVersion?: string;\n  /**\n   * Options for Yarn Berry.\n   * @default - Yarn Berry v4 with all default options\n   * @stability experimental\n   */\n  readonly yarnBerryOptions?: javascript.YarnBerryOptions;\n  /**\n   * Package's Stability.\n   * @stability experimental\n   */\n  readonly stability?: string;\n  /**\n   * npm scripts to include.\n   * If a script has the same name as a standard script,\n   * the standard script will be overwritten.\n   * Also adds the script as a task.\n   * @default {}\n   * @deprecated use `project.addTask()` or `package.setScript()`\n   * @stability deprecated\n   */\n  readonly scripts?: Record<string, string>;\n  /**\n   * Options for privately hosted scoped packages.\n   * @default - fetch all scoped packages from the public npm registry\n   * @stability experimental\n   */\n  readonly scopedPackagesOptions?: Array<javascript.ScopedPackagesOptions>;\n  /**\n   * If the package.json for your package is not in the root directory (for example if it is part of a monorepo), you can specify the directory in which it lives.\n   * @stability experimental\n   */\n  readonly repositoryDirectory?: string;\n  /**\n   * The repository is the location where the actual code for your package lives.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-repository\n   * @stability experimental\n   */\n  readonly repository?: string;\n  /**\n   * The version of PNPM to use if using PNPM as a package manager.\n   * @default \"7\"\n   * @stability experimental\n   */\n  readonly pnpmVersion?: string;\n  /**\n   * Peer dependencies for this module.\n   * Dependencies listed here are required to\n   * be installed (and satisfied) by the _consumer_ of this library. Using peer\n   * dependencies allows you to ensure that only a single module of a certain\n   * library exists in the `node_modules` tree of your consumers.\n   *\n   * Note that prior to npm@7, peer dependencies are _not_ automatically\n   * installed, which means that adding peer dependencies to a library will be a\n   * breaking change for your customers.\n   *\n   * Unless `peerDependencyOptions.pinnedDevDependency` is disabled (it is\n   * enabled by default), projen will automatically add a dev dependency with a\n   * pinned version for each peer dependency. This will ensure that you build &\n   * test your module against the lowest peer version required.\n   * @default []\n   * @stability experimental\n   */\n  readonly peerDeps?: Array<string>;\n  /**\n   * Options for `peerDeps`.\n   * @stability experimental\n   */\n  readonly peerDependencyOptions?: javascript.PeerDependencyOptions;\n  /**\n   * The \"name\" in package.json.\n   * @default - defaults to project name\n   * @stability experimental\n   * @featured true\n   */\n  readonly packageName?: string;\n  /**\n   * The Node Package Manager used to execute scripts.\n   * @default NodePackageManager.YARN_CLASSIC\n   * @stability experimental\n   */\n  readonly packageManager?: javascript.NodePackageManager;\n  /**\n   * GitHub secret which contains the NPM token to use when publishing packages.\n   * @default \"NPM_TOKEN\"\n   * @stability experimental\n   */\n  readonly npmTokenSecret?: string;\n  /**\n   * The base URL of the npm package registry.\n   * Must be a URL (e.g. start with \"https://\" or \"http://\")\n   * @default \"https://registry.npmjs.org\"\n   * @stability experimental\n   */\n  readonly npmRegistryUrl?: string;\n  /**\n   * The host name of the npm registry to publish to.\n   * Cannot be set together with `npmRegistryUrl`.\n   * @deprecated use `npmRegistryUrl` instead\n   * @stability deprecated\n   */\n  readonly npmRegistry?: string;\n  /**\n   * Should provenance statements be generated when the package is published.\n   * A supported package manager is required to publish a package with npm provenance statements and\n   * you will need to use a supported CI/CD provider.\n   *\n   * Note that the projen `Release` and `Publisher` components are using `publib` to publish packages,\n   * which is using npm internally and supports provenance statements independently of the package manager used.\n   * @default - true for public packages, false otherwise\n   * @stability experimental\n   */\n  readonly npmProvenance?: boolean;\n  /**\n   * Access level of the npm package.\n   * @default - for scoped packages (e.g. `foo@bar`), the default is\n`NpmAccess.RESTRICTED`, for non-scoped packages, the default is\n`NpmAccess.PUBLIC`.\n   * @stability experimental\n   */\n  readonly npmAccess?: javascript.NpmAccess;\n  /**\n   * The minimum node version required by this package to function. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any older versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option, even if your package is incompatible with EOL versions of node.\n   * Consider this option only if your package depends on a specific feature, that is not available in other LTS versions.\n   * Setting this option has very high impact on the consumers of your package,\n   * as package managers will actively prevent usage with node versions you have marked as incompatible.\n   *\n   * To change the node version of your CI/CD workflows, use `workflowNodeVersion`.\n   * @default - no minimum version is enforced\n   * @stability experimental\n   */\n  readonly minNodeVersion?: string;\n  /**\n   * The maximum node version supported by this package. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any newer versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option.\n   * Consider this option only if your package is known to not function with newer versions of node.\n   * @default - no maximum version is enforced\n   * @stability experimental\n   */\n  readonly maxNodeVersion?: string;\n  /**\n   * Indicates if a license should be added.\n   * @default true\n   * @stability experimental\n   */\n  readonly licensed?: boolean;\n  /**\n   * License's SPDX identifier.\n   * See https://github.com/projen/projen/tree/main/license-text for a list of supported licenses.\n   * Use the `licensed` option if you want to no license to be specified.\n   * @default \"Apache-2.0\"\n   * @stability experimental\n   */\n  readonly license?: string;\n  /**\n   * Keywords to include in `package.json`.\n   * @stability experimental\n   */\n  readonly keywords?: Array<string>;\n  /**\n   * Package's Homepage / Website.\n   * @stability experimental\n   */\n  readonly homepage?: string;\n  /**\n   * Module entrypoint (`main` in `package.json`).\n   * Set to an empty string to not include `main` in your package.json\n   * @default \"lib/index.js\"\n   * @stability experimental\n   */\n  readonly entrypoint?: string;\n  /**\n   * Build dependencies for this module.\n   * These dependencies will only be\n   * available in your build environment but will not be fetched when this\n   * module is consumed.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability experimental\n   * @featured true\n   */\n  readonly devDeps?: Array<string>;\n  /**\n   * The description is just a string that helps people understand the purpose of the package.\n   * It can be used when searching for packages in a package manager as well.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-description\n   * @stability experimental\n   * @featured true\n   */\n  readonly description?: string;\n  /**\n   * Runtime dependencies of this module.\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability experimental\n   * @featured true\n   */\n  readonly deps?: Array<string>;\n  /**\n   * Options for npm packages using AWS CodeArtifact.\n   * This is required if publishing packages to, or installing scoped packages from AWS CodeArtifact\n   * @default - undefined\n   * @stability experimental\n   */\n  readonly codeArtifactOptions?: javascript.CodeArtifactOptions;\n  /**\n   * List of dependencies to bundle into this module.\n   * These modules will be\n   * added both to the `dependencies` section and `bundledDependencies` section of\n   * your `package.json`.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @stability experimental\n   */\n  readonly bundledDeps?: Array<string>;\n  /**\n   * The url to your project's issue tracker.\n   * @stability experimental\n   */\n  readonly bugsUrl?: string;\n  /**\n   * The email address to which issues should be reported.\n   * @stability experimental\n   */\n  readonly bugsEmail?: string;\n  /**\n   * Binary programs vended with your module.\n   * You can use this option to add/customize how binaries are represented in\n   * your `package.json`, but unless `autoDetectBin` is `false`, every\n   * executable file under `bin` will automatically be added to this section.\n   * @stability experimental\n   */\n  readonly bin?: Record<string, string>;\n  /**\n   * Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section.\n   * @default true\n   * @stability experimental\n   */\n  readonly autoDetectBin?: boolean;\n  /**\n   * Author's URL / Website.\n   * @stability experimental\n   */\n  readonly authorUrl?: string;\n  /**\n   * Is the author an organization.\n   * @stability experimental\n   */\n  readonly authorOrganization?: boolean;\n  /**\n   * Author's name.\n   * @stability experimental\n   */\n  readonly authorName?: string;\n  /**\n   * Author's e-mail.\n   * @stability experimental\n   */\n  readonly authorEmail?: string;\n  /**\n   * Allow the project to include `peerDependencies` and `bundledDependencies`.\n   * This is normally only allowed for libraries. For apps, there's no meaning\n   * for specifying these.\n   * @default true\n   * @stability experimental\n   */\n  readonly allowLibraryDependencies?: boolean;\n  /**\n   * Enable VSCode integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability experimental\n   */\n  readonly vscode?: boolean;\n  /**\n   * Auto-close stale issues and pull requests.\n   * To disable set `stale` to `false`.\n   * @default - see defaults in `StaleOptions`\n   * @stability experimental\n   */\n  readonly staleOptions?: github.StaleOptions;\n  /**\n   * Auto-close of stale issues and pull request.\n   * See `staleOptions` for options.\n   * @default false\n   * @stability experimental\n   */\n  readonly stale?: boolean;\n  /**\n   * The name of a secret which includes a GitHub Personal Access Token to be used by projen workflows.\n   * This token needs to have the `repo`, `workflows`\n   * and `packages` scope.\n   * @default \"PROJEN_GITHUB_TOKEN\"\n   * @deprecated use `projenCredentials`\n   * @stability deprecated\n   */\n  readonly projenTokenSecret?: string;\n  /**\n   * Choose a method of providing GitHub API access for projen workflows.\n   * @default - use a personal access token named PROJEN_GITHUB_TOKEN\n   * @stability experimental\n   */\n  readonly projenCredentials?: github.GithubCredentials;\n  /**\n   * Which type of project this is (library/app).\n   * @default ProjectType.UNKNOWN\n   * @deprecated no longer supported at the base project level\n   * @stability deprecated\n   */\n  readonly projectType?: ProjectType;\n  /**\n   * Options for mergify.\n   * @default - default options\n   * @deprecated use `githubOptions.mergifyOptions` instead\n   * @stability deprecated\n   */\n  readonly mergifyOptions?: github.MergifyOptions;\n  /**\n   * Whether mergify should be enabled on this repository or not.\n   * @default true\n   * @deprecated use `githubOptions.mergify` instead\n   * @stability deprecated\n   */\n  readonly mergify?: boolean;\n  /**\n   * Add a Gitpod development environment.\n   * @default false\n   * @stability experimental\n   */\n  readonly gitpod?: boolean;\n  /**\n   * Options for GitHub integration.\n   * @default - see GitHubOptions\n   * @stability experimental\n   */\n  readonly githubOptions?: github.GitHubOptions;\n  /**\n   * Enable GitHub integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability experimental\n   */\n  readonly github?: boolean;\n  /**\n   * Add a VSCode development environment (used for GitHub Codespaces).\n   * @default false\n   * @stability experimental\n   */\n  readonly devContainer?: boolean;\n  /**\n   * Add a `clobber` task which resets the repo to origin.\n   * @default - true, but false for subprojects\n   * @stability experimental\n   */\n  readonly clobber?: boolean;\n  /**\n   * Configure options for automatic merging on GitHub.\n   * Has no effect if\n   * `github.mergify` or `autoMerge` is set to false.\n   * @default - see defaults in `AutoMergeOptions`\n   * @stability experimental\n   */\n  readonly autoMergeOptions?: github.AutoMergeOptions;\n  /**\n   * Enable automatic merging on GitHub.\n   * Has no effect if `github.mergify`\n   * is set to false.\n   * @default true\n   * @stability experimental\n   */\n  readonly autoMerge?: boolean;\n  /**\n   * Enable and configure the 'auto approve' workflow.\n   * @default - auto approve is disabled\n   * @stability experimental\n   */\n  readonly autoApproveOptions?: github.AutoApproveOptions;\n  /**\n   * Options for renovatebot.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly renovatebotOptions?: RenovatebotOptions;\n  /**\n   * Use renovatebot to handle dependency upgrades.\n   * @default false\n   * @stability experimental\n   */\n  readonly renovatebot?: boolean;\n  /**\n   * Options for .projenrc.json.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcJsonOptions?: ProjenrcJsonOptions;\n  /**\n   * Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation.\n   * @default false\n   * @stability experimental\n   */\n  readonly projenrcJson?: boolean;\n  /**\n   * The shell command to use in order to run the projen CLI.\n   * Can be used to customize in special environments.\n   * @default \"npx projen\"\n   * @stability experimental\n   */\n  readonly projenCommand?: string;\n  /**\n   * The parent project, if this project is part of a bigger project.\n   * @stability experimental\n   */\n  readonly parent?: Project;\n  /**\n   * The root directory of the project.\n   * Relative to this directory, all files are synthesized.\n   *\n   * If this project has a parent, this directory is relative to the parent\n   * directory and it cannot be the same as the parent or any of it's other\n   * subprojects.\n   * @default \".\"\n   * @stability experimental\n   */\n  readonly outdir?: string;\n  /**\n   * Configure logging options such as verbosity.\n   * @default {}\n   * @stability experimental\n   */\n  readonly logging?: LoggerOptions;\n  /**\n   * Configuration options for git.\n   * @stability experimental\n   */\n  readonly gitOptions?: GitOptions;\n  /**\n   * Configuration options for .gitignore file.\n   * @stability experimental\n   */\n  readonly gitIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Whether to commit the managed files by default.\n   * @default true\n   * @stability experimental\n   */\n  readonly commitGenerated?: boolean;\n  /**\n   * This is the name of your project.\n   * @default $BASEDIR\n   * @stability experimental\n   * @featured true\n   */\n  readonly name: string;\n  /**\n   * List of teams used to generate the CODEOWNERS file\n   */\n  readonly codeOwners: Array<string>;\n}\n"]}
@@ -0,0 +1,12 @@
1
+ import { PythonProject } from 'projen/lib/python';
2
+ import { PythonPackageOptions } from './python-package-options';
3
+ /**
4
+ * A Python package
5
+ *
6
+ *
7
+ * @pjid python-package
8
+ */
9
+ export declare class PythonPackage extends PythonProject {
10
+ constructor(options: PythonPackageOptions);
11
+ }
12
+ export * from './python-package-options';
@@ -0,0 +1,58 @@
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
+ var _a;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.PythonPackage = void 0;
19
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
20
+ const python_1 = require("projen/lib/python");
21
+ const codeowners_1 = require("../../components/github/codeowners");
22
+ const pull_request_template_1 = require("../../components/github/pull-request-template");
23
+ const readme_1 = require("../../components/readme");
24
+ const merge_options_1 = require("../../utils/merge-options");
25
+ function getOptions(options) {
26
+ const { name } = options;
27
+ const defaults = {
28
+ name,
29
+ pullRequestTemplate: true,
30
+ pullRequestTemplateContents: pull_request_template_1.DEFAULT_PULL_REQUEST_TEMPLATE,
31
+ };
32
+ return (0, merge_options_1.mergeOptions)(defaults, options);
33
+ }
34
+ /**
35
+ * A Python package
36
+ *
37
+ *
38
+ * @pjid python-package
39
+ */
40
+ class PythonPackage extends python_1.PythonProject {
41
+ constructor(options) {
42
+ const mergedOptions = getOptions(options);
43
+ super({
44
+ ...mergedOptions,
45
+ });
46
+ new codeowners_1.CodeOwners(this, mergedOptions.codeOwners);
47
+ if (mergedOptions.pullRequestTemplate ?? true) {
48
+ this.github?.addPullRequestTemplate(...(mergedOptions.pullRequestTemplateContents ?? []));
49
+ }
50
+ const readme = new readme_1.Readme(this);
51
+ readme.addSection('Getting Started', '```sh\nyarn install\nnpx projen build\n```');
52
+ }
53
+ }
54
+ exports.PythonPackage = PythonPackage;
55
+ _a = JSII_RTTI_SYMBOL_1;
56
+ PythonPackage[_a] = { fqn: "projen-modules.PythonPackage", version: "0.1.1" };
57
+ __exportStar(require("./python-package-options"), exports);
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcHJvamVjdHMvcHl0aG9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw4Q0FBa0Q7QUFFbEQsbUVBQWdFO0FBQ2hFLHlGQUE4RjtBQUM5RixvREFBaUQ7QUFDakQsNkRBQXlEO0FBRXpELFNBQVMsVUFBVSxDQUFDLE9BQTZCO0lBQy9DLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxPQUFPLENBQUM7SUFFekIsTUFBTSxRQUFRLEdBQUc7UUFDZixJQUFJO1FBQ0osbUJBQW1CLEVBQUUsSUFBSTtRQUN6QiwyQkFBMkIsRUFBRSxxREFBNkI7S0FDbkIsQ0FBQztJQUUxQyxPQUFPLElBQUEsNEJBQVksRUFBQyxRQUFRLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDekMsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsTUFBYSxhQUFjLFNBQVEsc0JBQWE7SUFDOUMsWUFBWSxPQUE2QjtRQUN2QyxNQUFNLGFBQWEsR0FBRyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFMUMsS0FBSyxDQUFDO1lBQ0osR0FBRyxhQUFhO1NBQ2pCLENBQUMsQ0FBQztRQUVILElBQUksdUJBQVUsQ0FBQyxJQUFJLEVBQUUsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQy9DLElBQUksYUFBYSxDQUFDLG1CQUFtQixJQUFJLElBQUksRUFBRSxDQUFDO1lBQzlDLElBQUksQ0FBQyxNQUFNLEVBQUUsc0JBQXNCLENBQ2pDLEdBQUcsQ0FBQyxhQUFhLENBQUMsMkJBQTJCLElBQUksRUFBRSxDQUFDLENBQ3JELENBQUM7UUFDSixDQUFDO1FBQ0QsTUFBTSxNQUFNLEdBQUcsSUFBSSxlQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDaEMsTUFBTSxDQUFDLFVBQVUsQ0FDZixpQkFBaUIsRUFDakIsNENBQTRDLENBQzdDLENBQUM7SUFDSixDQUFDOztBQW5CSCxzQ0FvQkM7OztBQUVELDJEQUF5QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFB5dGhvblByb2plY3QgfSBmcm9tICdwcm9qZW4vbGliL3B5dGhvbic7XG5pbXBvcnQgeyBQeXRob25QYWNrYWdlT3B0aW9ucyB9IGZyb20gJy4vcHl0aG9uLXBhY2thZ2Utb3B0aW9ucyc7XG5pbXBvcnQgeyBDb2RlT3duZXJzIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9naXRodWIvY29kZW93bmVycyc7XG5pbXBvcnQgeyBERUZBVUxUX1BVTExfUkVRVUVTVF9URU1QTEFURSB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvZ2l0aHViL3B1bGwtcmVxdWVzdC10ZW1wbGF0ZSc7XG5pbXBvcnQgeyBSZWFkbWUgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL3JlYWRtZSc7XG5pbXBvcnQgeyBtZXJnZU9wdGlvbnMgfSBmcm9tICcuLi8uLi91dGlscy9tZXJnZS1vcHRpb25zJztcblxuZnVuY3Rpb24gZ2V0T3B0aW9ucyhvcHRpb25zOiBQeXRob25QYWNrYWdlT3B0aW9ucykge1xuICBjb25zdCB7IG5hbWUgfSA9IG9wdGlvbnM7XG5cbiAgY29uc3QgZGVmYXVsdHMgPSB7XG4gICAgbmFtZSxcbiAgICBwdWxsUmVxdWVzdFRlbXBsYXRlOiB0cnVlLFxuICAgIHB1bGxSZXF1ZXN0VGVtcGxhdGVDb250ZW50czogREVGQVVMVF9QVUxMX1JFUVVFU1RfVEVNUExBVEUsXG4gIH0gc2F0aXNmaWVzIFBhcnRpYWw8UHl0aG9uUGFja2FnZU9wdGlvbnM+O1xuXG4gIHJldHVybiBtZXJnZU9wdGlvbnMoZGVmYXVsdHMsIG9wdGlvbnMpO1xufVxuXG4vKipcbiAqIEEgUHl0aG9uIHBhY2thZ2VcbiAqXG4gKlxuICogQHBqaWQgcHl0aG9uLXBhY2thZ2VcbiAqL1xuZXhwb3J0IGNsYXNzIFB5dGhvblBhY2thZ2UgZXh0ZW5kcyBQeXRob25Qcm9qZWN0IHtcbiAgY29uc3RydWN0b3Iob3B0aW9uczogUHl0aG9uUGFja2FnZU9wdGlvbnMpIHtcbiAgICBjb25zdCBtZXJnZWRPcHRpb25zID0gZ2V0T3B0aW9ucyhvcHRpb25zKTtcblxuICAgIHN1cGVyKHtcbiAgICAgIC4uLm1lcmdlZE9wdGlvbnMsXG4gICAgfSk7XG5cbiAgICBuZXcgQ29kZU93bmVycyh0aGlzLCBtZXJnZWRPcHRpb25zLmNvZGVPd25lcnMpO1xuICAgIGlmIChtZXJnZWRPcHRpb25zLnB1bGxSZXF1ZXN0VGVtcGxhdGUgPz8gdHJ1ZSkge1xuICAgICAgdGhpcy5naXRodWI/LmFkZFB1bGxSZXF1ZXN0VGVtcGxhdGUoXG4gICAgICAgIC4uLihtZXJnZWRPcHRpb25zLnB1bGxSZXF1ZXN0VGVtcGxhdGVDb250ZW50cyA/PyBbXSksXG4gICAgICApO1xuICAgIH1cbiAgICBjb25zdCByZWFkbWUgPSBuZXcgUmVhZG1lKHRoaXMpO1xuICAgIHJlYWRtZS5hZGRTZWN0aW9uKFxuICAgICAgJ0dldHRpbmcgU3RhcnRlZCcsXG4gICAgICAnYGBgc2hcXG55YXJuIGluc3RhbGxcXG5ucHggcHJvamVuIGJ1aWxkXFxuYGBgJyxcbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCAqIGZyb20gJy4vcHl0aG9uLXBhY2thZ2Utb3B0aW9ucyc7XG4iXX0=
@@ -0,0 +1,391 @@
1
+ import type { github, GitOptions, IgnoreFileOptions, javascript, LoggerOptions, Project, ProjectType, ProjenrcJsonOptions, python, RenovatebotOptions, typescript } from 'projen';
2
+ /**
3
+ * PythonPackageOptions
4
+ */
5
+ export interface PythonPackageOptions {
6
+ /**
7
+ * Venv options.
8
+ * @default - defaults
9
+ * @stability experimental
10
+ */
11
+ readonly venvOptions?: python.VenvOptions;
12
+ /**
13
+ * Use venv to manage a virtual environment for installing dependencies inside.
14
+ * @default - true, unless poetry is true, then false
15
+ * @stability experimental
16
+ * @featured true
17
+ */
18
+ readonly venv?: boolean;
19
+ /**
20
+ * Use setuptools with a setup.py script for packaging and publishing.
21
+ * @default - true, unless poetry is true, then false
22
+ * @stability experimental
23
+ * @featured true
24
+ */
25
+ readonly setuptools?: boolean;
26
+ /**
27
+ * Include sample code and test if the relevant directories don't exist.
28
+ * @default true
29
+ * @stability experimental
30
+ */
31
+ readonly sample?: boolean;
32
+ /**
33
+ * pytest options.
34
+ * @default - defaults
35
+ * @stability experimental
36
+ */
37
+ readonly pytestOptions?: python.PytestOptions;
38
+ /**
39
+ * Include pytest tests.
40
+ * @default true
41
+ * @stability experimental
42
+ * @featured true
43
+ */
44
+ readonly pytest?: boolean;
45
+ /**
46
+ * Options related to projenrc in TypeScript.
47
+ * @default - default options
48
+ * @stability experimental
49
+ */
50
+ readonly projenrcTsOptions?: typescript.ProjenrcTsOptions;
51
+ /**
52
+ * Use projenrc in TypeScript.
53
+ * This will create a tsconfig file (default: `tsconfig.projen.json`)
54
+ * and use `ts-node` in the default task to parse the project source files.
55
+ * @default false
56
+ * @stability experimental
57
+ */
58
+ readonly projenrcTs?: boolean;
59
+ /**
60
+ * Options related to projenrc in python.
61
+ * @default - default options
62
+ * @stability experimental
63
+ */
64
+ readonly projenrcPythonOptions?: python.ProjenrcOptions;
65
+ /**
66
+ * Use projenrc in Python.
67
+ * This will install `projen` as a Python dependency and add a `synth`
68
+ * task which will run `.projenrc.py`.
69
+ * @default true
70
+ * @stability experimental
71
+ */
72
+ readonly projenrcPython?: boolean;
73
+ /**
74
+ * Options related to projenrc in JavaScript.
75
+ * @default - default options
76
+ * @stability experimental
77
+ */
78
+ readonly projenrcJsOptions?: javascript.ProjenrcOptions;
79
+ /**
80
+ * Use projenrc in javascript.
81
+ * This will install `projen` as a JavaScript dependency and add a `synth`
82
+ * task which will run `.projenrc.js`.
83
+ * @default false
84
+ * @stability experimental
85
+ */
86
+ readonly projenrcJs?: boolean;
87
+ /**
88
+ * Use poetry to manage your project dependencies, virtual environment, and (optional) packaging/publishing.
89
+ * This feature is incompatible with pip, setuptools, or venv.
90
+ * If you set this option to `true`, then pip, setuptools, and venv must be set to `false`.
91
+ * @default false
92
+ * @stability experimental
93
+ * @featured true
94
+ */
95
+ readonly poetry?: boolean;
96
+ /**
97
+ * Use pip with a requirements.txt file to track project dependencies.
98
+ * @default - true, unless poetry is true, then false
99
+ * @stability experimental
100
+ * @featured true
101
+ */
102
+ readonly pip?: boolean;
103
+ /**
104
+ * List of dev dependencies for this project.
105
+ * Dependencies use the format: `<module>@<semver>`
106
+ *
107
+ * Additional dependencies can be added via `project.addDevDependency()`.
108
+ * @default []
109
+ * @stability experimental
110
+ * @featured true
111
+ */
112
+ readonly devDeps?: Array<string>;
113
+ /**
114
+ * List of runtime dependencies for this project.
115
+ * Dependencies use the format: `<module>@<semver>`
116
+ *
117
+ * Additional dependencies can be added via `project.addDependency()`.
118
+ * @default []
119
+ * @stability experimental
120
+ * @featured true
121
+ */
122
+ readonly deps?: Array<string>;
123
+ /**
124
+ * Name of the python package as used in imports and filenames.
125
+ * Must only consist of alphanumeric characters and underscores.
126
+ * @default $PYTHON_MODULE_NAME
127
+ * @stability experimental
128
+ */
129
+ readonly moduleName: string;
130
+ /**
131
+ * Path to the python executable to use.
132
+ * @default "python"
133
+ * @stability experimental
134
+ */
135
+ readonly pythonExec?: string;
136
+ /**
137
+ * Additional fields to pass in the setup() function if using setuptools.
138
+ * @stability experimental
139
+ */
140
+ readonly setupConfig?: Record<string, any>;
141
+ /**
142
+ * Additional options to set for poetry if using poetry.
143
+ * @stability experimental
144
+ */
145
+ readonly poetryOptions?: python.PoetryPyprojectOptionsWithoutDeps;
146
+ /**
147
+ * Package name.
148
+ * @stability experimental
149
+ */
150
+ readonly packageName?: string;
151
+ /**
152
+ * License of this package as an SPDX identifier.
153
+ * @stability experimental
154
+ */
155
+ readonly license?: string;
156
+ /**
157
+ * A URL to the website of the project.
158
+ * @stability experimental
159
+ */
160
+ readonly homepage?: string;
161
+ /**
162
+ * A short description of the package.
163
+ * @stability experimental
164
+ * @featured true
165
+ */
166
+ readonly description?: string;
167
+ /**
168
+ * A list of PyPI trove classifiers that describe the project.
169
+ * @stability experimental
170
+ */
171
+ readonly classifiers?: Array<string>;
172
+ /**
173
+ * Version of the package.
174
+ * @default "0.1.0"
175
+ * @stability experimental
176
+ * @featured true
177
+ */
178
+ readonly version: string;
179
+ /**
180
+ * Author's name.
181
+ * @default $GIT_USER_NAME
182
+ * @stability experimental
183
+ */
184
+ readonly authorName: string;
185
+ /**
186
+ * Author's e-mail.
187
+ * @default $GIT_USER_EMAIL
188
+ * @stability experimental
189
+ */
190
+ readonly authorEmail: string;
191
+ /**
192
+ * Enable VSCode integration.
193
+ * Enabled by default for root projects. Disabled for non-root projects.
194
+ * @default true
195
+ * @stability experimental
196
+ */
197
+ readonly vscode?: boolean;
198
+ /**
199
+ * Auto-close stale issues and pull requests.
200
+ * To disable set `stale` to `false`.
201
+ * @default - see defaults in `StaleOptions`
202
+ * @stability experimental
203
+ */
204
+ readonly staleOptions?: github.StaleOptions;
205
+ /**
206
+ * Auto-close of stale issues and pull request.
207
+ * See `staleOptions` for options.
208
+ * @default false
209
+ * @stability experimental
210
+ */
211
+ readonly stale?: boolean;
212
+ /**
213
+ * The name of a secret which includes a GitHub Personal Access Token to be used by projen workflows.
214
+ * This token needs to have the `repo`, `workflows`
215
+ * and `packages` scope.
216
+ * @default "PROJEN_GITHUB_TOKEN"
217
+ * @deprecated use `projenCredentials`
218
+ * @stability deprecated
219
+ */
220
+ readonly projenTokenSecret?: string;
221
+ /**
222
+ * Choose a method of providing GitHub API access for projen workflows.
223
+ * @default - use a personal access token named PROJEN_GITHUB_TOKEN
224
+ * @stability experimental
225
+ */
226
+ readonly projenCredentials?: github.GithubCredentials;
227
+ /**
228
+ * Which type of project this is (library/app).
229
+ * @default ProjectType.UNKNOWN
230
+ * @deprecated no longer supported at the base project level
231
+ * @stability deprecated
232
+ */
233
+ readonly projectType?: ProjectType;
234
+ /**
235
+ * Options for mergify.
236
+ * @default - default options
237
+ * @deprecated use `githubOptions.mergifyOptions` instead
238
+ * @stability deprecated
239
+ */
240
+ readonly mergifyOptions?: github.MergifyOptions;
241
+ /**
242
+ * Whether mergify should be enabled on this repository or not.
243
+ * @default true
244
+ * @deprecated use `githubOptions.mergify` instead
245
+ * @stability deprecated
246
+ */
247
+ readonly mergify?: boolean;
248
+ /**
249
+ * Add a Gitpod development environment.
250
+ * @default false
251
+ * @stability experimental
252
+ */
253
+ readonly gitpod?: boolean;
254
+ /**
255
+ * Options for GitHub integration.
256
+ * @default - see GitHubOptions
257
+ * @stability experimental
258
+ */
259
+ readonly githubOptions?: github.GitHubOptions;
260
+ /**
261
+ * Enable GitHub integration.
262
+ * Enabled by default for root projects. Disabled for non-root projects.
263
+ * @default true
264
+ * @stability experimental
265
+ */
266
+ readonly github?: boolean;
267
+ /**
268
+ * Add a VSCode development environment (used for GitHub Codespaces).
269
+ * @default false
270
+ * @stability experimental
271
+ */
272
+ readonly devContainer?: boolean;
273
+ /**
274
+ * Add a `clobber` task which resets the repo to origin.
275
+ * @default - true, but false for subprojects
276
+ * @stability experimental
277
+ */
278
+ readonly clobber?: boolean;
279
+ /**
280
+ * Configure options for automatic merging on GitHub.
281
+ * Has no effect if
282
+ * `github.mergify` or `autoMerge` is set to false.
283
+ * @default - see defaults in `AutoMergeOptions`
284
+ * @stability experimental
285
+ */
286
+ readonly autoMergeOptions?: github.AutoMergeOptions;
287
+ /**
288
+ * Enable automatic merging on GitHub.
289
+ * Has no effect if `github.mergify`
290
+ * is set to false.
291
+ * @default true
292
+ * @stability experimental
293
+ */
294
+ readonly autoMerge?: boolean;
295
+ /**
296
+ * Enable and configure the 'auto approve' workflow.
297
+ * @default - auto approve is disabled
298
+ * @stability experimental
299
+ */
300
+ readonly autoApproveOptions?: github.AutoApproveOptions;
301
+ /**
302
+ * Options for renovatebot.
303
+ * @default - default options
304
+ * @stability experimental
305
+ */
306
+ readonly renovatebotOptions?: RenovatebotOptions;
307
+ /**
308
+ * Use renovatebot to handle dependency upgrades.
309
+ * @default false
310
+ * @stability experimental
311
+ */
312
+ readonly renovatebot?: boolean;
313
+ /**
314
+ * Options for .projenrc.json.
315
+ * @default - default options
316
+ * @stability experimental
317
+ */
318
+ readonly projenrcJsonOptions?: ProjenrcJsonOptions;
319
+ /**
320
+ * Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation.
321
+ * @default false
322
+ * @stability experimental
323
+ */
324
+ readonly projenrcJson?: boolean;
325
+ /**
326
+ * The shell command to use in order to run the projen CLI.
327
+ * Can be used to customize in special environments.
328
+ * @default "npx projen"
329
+ * @stability experimental
330
+ */
331
+ readonly projenCommand?: string;
332
+ /**
333
+ * The parent project, if this project is part of a bigger project.
334
+ * @stability experimental
335
+ */
336
+ readonly parent?: Project;
337
+ /**
338
+ * The root directory of the project.
339
+ * Relative to this directory, all files are synthesized.
340
+ *
341
+ * If this project has a parent, this directory is relative to the parent
342
+ * directory and it cannot be the same as the parent or any of it's other
343
+ * subprojects.
344
+ * @default "."
345
+ * @stability experimental
346
+ */
347
+ readonly outdir?: string;
348
+ /**
349
+ * Configure logging options such as verbosity.
350
+ * @default {}
351
+ * @stability experimental
352
+ */
353
+ readonly logging?: LoggerOptions;
354
+ /**
355
+ * Configuration options for git.
356
+ * @stability experimental
357
+ */
358
+ readonly gitOptions?: GitOptions;
359
+ /**
360
+ * Configuration options for .gitignore file.
361
+ * @stability experimental
362
+ */
363
+ readonly gitIgnoreOptions?: IgnoreFileOptions;
364
+ /**
365
+ * Whether to commit the managed files by default.
366
+ * @default true
367
+ * @stability experimental
368
+ */
369
+ readonly commitGenerated?: boolean;
370
+ /**
371
+ * This is the name of your project.
372
+ * @default $BASEDIR
373
+ * @stability experimental
374
+ * @featured true
375
+ */
376
+ readonly name: string;
377
+ /**
378
+ * List of teams used to generate the CODEOWNERS file
379
+ */
380
+ readonly codeOwners: Array<string>;
381
+ /**
382
+ * Include a GitHub pull request template.
383
+ * @default true
384
+ */
385
+ readonly pullRequestTemplate?: boolean;
386
+ /**
387
+ * The contents of the pull request template.
388
+ * @default default content
389
+ */
390
+ readonly pullRequestTemplateContents?: Array<string>;
391
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"python-package-options.js","sourceRoot":"","sources":["../../../src/projects/python/python-package-options.ts"],"names":[],"mappings":"","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\".\nimport type { github, GitOptions, IgnoreFileOptions, javascript, LoggerOptions, Project, ProjectType, ProjenrcJsonOptions, python, RenovatebotOptions, typescript } from 'projen';\n\n/**\n * PythonPackageOptions\n */\nexport interface PythonPackageOptions {\n  /**\n   * Venv options.\n   * @default - defaults\n   * @stability experimental\n   */\n  readonly venvOptions?: python.VenvOptions;\n  /**\n   * Use venv to manage a virtual environment for installing dependencies inside.\n   * @default - true, unless poetry is true, then false\n   * @stability experimental\n   * @featured true\n   */\n  readonly venv?: boolean;\n  /**\n   * Use setuptools with a setup.py script for packaging and publishing.\n   * @default - true, unless poetry is true, then false\n   * @stability experimental\n   * @featured true\n   */\n  readonly setuptools?: boolean;\n  /**\n   * Include sample code and test if the relevant directories don't exist.\n   * @default true\n   * @stability experimental\n   */\n  readonly sample?: boolean;\n  /**\n   * pytest options.\n   * @default - defaults\n   * @stability experimental\n   */\n  readonly pytestOptions?: python.PytestOptions;\n  /**\n   * Include pytest tests.\n   * @default true\n   * @stability experimental\n   * @featured true\n   */\n  readonly pytest?: boolean;\n  /**\n   * Options related to projenrc in TypeScript.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcTsOptions?: typescript.ProjenrcTsOptions;\n  /**\n   * Use projenrc in TypeScript.\n   * This will create a tsconfig file (default: `tsconfig.projen.json`)\n   * and use `ts-node` in the default task to parse the project source files.\n   * @default false\n   * @stability experimental\n   */\n  readonly projenrcTs?: boolean;\n  /**\n   * Options related to projenrc in python.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcPythonOptions?: python.ProjenrcOptions;\n  /**\n   * Use projenrc in Python.\n   * This will install `projen` as a Python dependency and add a `synth`\n   * task which will run `.projenrc.py`.\n   * @default true\n   * @stability experimental\n   */\n  readonly projenrcPython?: boolean;\n  /**\n   * Options related to projenrc in JavaScript.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcJsOptions?: javascript.ProjenrcOptions;\n  /**\n   * Use projenrc in javascript.\n   * This will install `projen` as a JavaScript dependency and add a `synth`\n   * task which will run `.projenrc.js`.\n   * @default false\n   * @stability experimental\n   */\n  readonly projenrcJs?: boolean;\n  /**\n   * Use poetry to manage your project dependencies, virtual environment, and (optional) packaging/publishing.\n   * This feature is incompatible with pip, setuptools, or venv.\n   * If you set this option to `true`, then pip, setuptools, and venv must be set to `false`.\n   * @default false\n   * @stability experimental\n   * @featured true\n   */\n  readonly poetry?: boolean;\n  /**\n   * Use pip with a requirements.txt file to track project dependencies.\n   * @default - true, unless poetry is true, then false\n   * @stability experimental\n   * @featured true\n   */\n  readonly pip?: boolean;\n  /**\n   * List of dev dependencies for this project.\n   * Dependencies use the format: `<module>@<semver>`\n   *\n   * Additional dependencies can be added via `project.addDevDependency()`.\n   * @default []\n   * @stability experimental\n   * @featured true\n   */\n  readonly devDeps?: Array<string>;\n  /**\n   * List of runtime dependencies for this project.\n   * Dependencies use the format: `<module>@<semver>`\n   *\n   * Additional dependencies can be added via `project.addDependency()`.\n   * @default []\n   * @stability experimental\n   * @featured true\n   */\n  readonly deps?: Array<string>;\n  /**\n   * Name of the python package as used in imports and filenames.\n   * Must only consist of alphanumeric characters and underscores.\n   * @default $PYTHON_MODULE_NAME\n   * @stability experimental\n   */\n  readonly moduleName: string;\n  /**\n   * Path to the python executable to use.\n   * @default \"python\"\n   * @stability experimental\n   */\n  readonly pythonExec?: string;\n  /**\n   * Additional fields to pass in the setup() function if using setuptools.\n   * @stability experimental\n   */\n  readonly setupConfig?: Record<string, any>;\n  /**\n   * Additional options to set for poetry if using poetry.\n   * @stability experimental\n   */\n  readonly poetryOptions?: python.PoetryPyprojectOptionsWithoutDeps;\n  /**\n   * Package name.\n   * @stability experimental\n   */\n  readonly packageName?: string;\n  /**\n   * License of this package as an SPDX identifier.\n   * @stability experimental\n   */\n  readonly license?: string;\n  /**\n   * A URL to the website of the project.\n   * @stability experimental\n   */\n  readonly homepage?: string;\n  /**\n   * A short description of the package.\n   * @stability experimental\n   * @featured true\n   */\n  readonly description?: string;\n  /**\n   * A list of PyPI trove classifiers that describe the project.\n   * @stability experimental\n   */\n  readonly classifiers?: Array<string>;\n  /**\n   * Version of the package.\n   * @default \"0.1.0\"\n   * @stability experimental\n   * @featured true\n   */\n  readonly version: string;\n  /**\n   * Author's name.\n   * @default $GIT_USER_NAME\n   * @stability experimental\n   */\n  readonly authorName: string;\n  /**\n   * Author's e-mail.\n   * @default $GIT_USER_EMAIL\n   * @stability experimental\n   */\n  readonly authorEmail: string;\n  /**\n   * Enable VSCode integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability experimental\n   */\n  readonly vscode?: boolean;\n  /**\n   * Auto-close stale issues and pull requests.\n   * To disable set `stale` to `false`.\n   * @default - see defaults in `StaleOptions`\n   * @stability experimental\n   */\n  readonly staleOptions?: github.StaleOptions;\n  /**\n   * Auto-close of stale issues and pull request.\n   * See `staleOptions` for options.\n   * @default false\n   * @stability experimental\n   */\n  readonly stale?: boolean;\n  /**\n   * The name of a secret which includes a GitHub Personal Access Token to be used by projen workflows.\n   * This token needs to have the `repo`, `workflows`\n   * and `packages` scope.\n   * @default \"PROJEN_GITHUB_TOKEN\"\n   * @deprecated use `projenCredentials`\n   * @stability deprecated\n   */\n  readonly projenTokenSecret?: string;\n  /**\n   * Choose a method of providing GitHub API access for projen workflows.\n   * @default - use a personal access token named PROJEN_GITHUB_TOKEN\n   * @stability experimental\n   */\n  readonly projenCredentials?: github.GithubCredentials;\n  /**\n   * Which type of project this is (library/app).\n   * @default ProjectType.UNKNOWN\n   * @deprecated no longer supported at the base project level\n   * @stability deprecated\n   */\n  readonly projectType?: ProjectType;\n  /**\n   * Options for mergify.\n   * @default - default options\n   * @deprecated use `githubOptions.mergifyOptions` instead\n   * @stability deprecated\n   */\n  readonly mergifyOptions?: github.MergifyOptions;\n  /**\n   * Whether mergify should be enabled on this repository or not.\n   * @default true\n   * @deprecated use `githubOptions.mergify` instead\n   * @stability deprecated\n   */\n  readonly mergify?: boolean;\n  /**\n   * Add a Gitpod development environment.\n   * @default false\n   * @stability experimental\n   */\n  readonly gitpod?: boolean;\n  /**\n   * Options for GitHub integration.\n   * @default - see GitHubOptions\n   * @stability experimental\n   */\n  readonly githubOptions?: github.GitHubOptions;\n  /**\n   * Enable GitHub integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability experimental\n   */\n  readonly github?: boolean;\n  /**\n   * Add a VSCode development environment (used for GitHub Codespaces).\n   * @default false\n   * @stability experimental\n   */\n  readonly devContainer?: boolean;\n  /**\n   * Add a `clobber` task which resets the repo to origin.\n   * @default - true, but false for subprojects\n   * @stability experimental\n   */\n  readonly clobber?: boolean;\n  /**\n   * Configure options for automatic merging on GitHub.\n   * Has no effect if\n   * `github.mergify` or `autoMerge` is set to false.\n   * @default - see defaults in `AutoMergeOptions`\n   * @stability experimental\n   */\n  readonly autoMergeOptions?: github.AutoMergeOptions;\n  /**\n   * Enable automatic merging on GitHub.\n   * Has no effect if `github.mergify`\n   * is set to false.\n   * @default true\n   * @stability experimental\n   */\n  readonly autoMerge?: boolean;\n  /**\n   * Enable and configure the 'auto approve' workflow.\n   * @default - auto approve is disabled\n   * @stability experimental\n   */\n  readonly autoApproveOptions?: github.AutoApproveOptions;\n  /**\n   * Options for renovatebot.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly renovatebotOptions?: RenovatebotOptions;\n  /**\n   * Use renovatebot to handle dependency upgrades.\n   * @default false\n   * @stability experimental\n   */\n  readonly renovatebot?: boolean;\n  /**\n   * Options for .projenrc.json.\n   * @default - default options\n   * @stability experimental\n   */\n  readonly projenrcJsonOptions?: ProjenrcJsonOptions;\n  /**\n   * Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation.\n   * @default false\n   * @stability experimental\n   */\n  readonly projenrcJson?: boolean;\n  /**\n   * The shell command to use in order to run the projen CLI.\n   * Can be used to customize in special environments.\n   * @default \"npx projen\"\n   * @stability experimental\n   */\n  readonly projenCommand?: string;\n  /**\n   * The parent project, if this project is part of a bigger project.\n   * @stability experimental\n   */\n  readonly parent?: Project;\n  /**\n   * The root directory of the project.\n   * Relative to this directory, all files are synthesized.\n   *\n   * If this project has a parent, this directory is relative to the parent\n   * directory and it cannot be the same as the parent or any of it's other\n   * subprojects.\n   * @default \".\"\n   * @stability experimental\n   */\n  readonly outdir?: string;\n  /**\n   * Configure logging options such as verbosity.\n   * @default {}\n   * @stability experimental\n   */\n  readonly logging?: LoggerOptions;\n  /**\n   * Configuration options for git.\n   * @stability experimental\n   */\n  readonly gitOptions?: GitOptions;\n  /**\n   * Configuration options for .gitignore file.\n   * @stability experimental\n   */\n  readonly gitIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Whether to commit the managed files by default.\n   * @default true\n   * @stability experimental\n   */\n  readonly commitGenerated?: boolean;\n  /**\n   * This is the name of your project.\n   * @default $BASEDIR\n   * @stability experimental\n   * @featured true\n   */\n  readonly name: string;\n  /**\n   * List of teams used to generate the CODEOWNERS file\n   */\n  readonly codeOwners: Array<string>;\n  /**\n   * Include a GitHub pull request template.\n   * @default true\n   */\n  readonly pullRequestTemplate?: boolean;\n  /**\n   * The contents of the pull request template.\n   * @default default content\n   */\n  readonly pullRequestTemplateContents?: Array<string>;\n}\n"]}
package/package.json CHANGED
@@ -35,6 +35,7 @@
35
35
  "organization": false
36
36
  },
37
37
  "devDependencies": {
38
+ "@mrgrain/jsii-struct-builder": "^0.7.43",
38
39
  "@types/jest": "^29.5.14",
39
40
  "@types/node": "^18",
40
41
  "@typescript-eslint/eslint-plugin": "^7",
@@ -51,21 +52,21 @@
51
52
  "jsii-docgen": "^10.5.0",
52
53
  "jsii-pacmak": "^1.104.0",
53
54
  "jsii-rosetta": "~5.4.0",
54
- "projen": "0.88.6",
55
+ "projen": "0.90.0",
55
56
  "ts-jest": "^29.2.5",
56
57
  "ts-node": "^10.9.2",
57
58
  "typescript": "^5.6.3"
58
59
  },
59
60
  "peerDependencies": {
60
61
  "constructs": "10.4.2",
61
- "projen": "0.88.6"
62
+ "projen": "0.90.0"
62
63
  },
63
64
  "main": "lib/index.js",
64
65
  "license": "Apache-2.0",
65
66
  "publishConfig": {
66
67
  "access": "public"
67
68
  },
68
- "version": "0.0.39",
69
+ "version": "0.1.1",
69
70
  "jest": {
70
71
  "coverageProvider": "v8",
71
72
  "testMatch": [
@@ -1,17 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CodeOwners = void 0;
4
- const projen_1 = require("projen");
5
- const javascript_1 = require("projen/lib/javascript");
6
- class CodeOwners {
7
- constructor(project, codeOwners) {
8
- if (project instanceof javascript_1.NodeProject) {
9
- project.npmignore?.addPatterns('CODEOWNERS');
10
- }
11
- new projen_1.TextFile(project, 'CODEOWNERS', {
12
- lines: codeOwners.map((owner) => `* @unibuddy/${owner}`),
13
- });
14
- }
15
- }
16
- exports.CodeOwners = CodeOwners;
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZW93bmVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9naXRodWIvY29kZW93bmVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSxtQ0FBa0M7QUFDbEMsc0RBQW9EO0FBRXBELE1BQWEsVUFBVTtJQUNyQixZQUFZLE9BQW1CLEVBQUUsVUFBeUI7UUFDeEQsSUFBSSxPQUFPLFlBQVksd0JBQVcsRUFBRSxDQUFDO1lBQ25DLE9BQU8sQ0FBQyxTQUFTLEVBQUUsV0FBVyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQy9DLENBQUM7UUFFRCxJQUFJLGlCQUFRLENBQUMsT0FBTyxFQUFFLFlBQVksRUFBRTtZQUNsQyxLQUFLLEVBQUUsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsZUFBZSxLQUFLLEVBQUUsQ0FBQztTQUN6RCxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFWRCxnQ0FVQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IFRleHRGaWxlIH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IE5vZGVQcm9qZWN0IH0gZnJvbSAncHJvamVuL2xpYi9qYXZhc2NyaXB0JztcblxuZXhwb3J0IGNsYXNzIENvZGVPd25lcnMge1xuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBJQ29uc3RydWN0LCBjb2RlT3duZXJzOiBBcnJheTxzdHJpbmc+KSB7XG4gICAgaWYgKHByb2plY3QgaW5zdGFuY2VvZiBOb2RlUHJvamVjdCkge1xuICAgICAgcHJvamVjdC5ucG1pZ25vcmU/LmFkZFBhdHRlcm5zKCdDT0RFT1dORVJTJyk7XG4gICAgfVxuXG4gICAgbmV3IFRleHRGaWxlKHByb2plY3QsICdDT0RFT1dORVJTJywge1xuICAgICAgbGluZXM6IGNvZGVPd25lcnMubWFwKChvd25lcikgPT4gYCogQHVuaWJ1ZGR5LyR7b3duZXJ9YCksXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==