projen
Version:
CDK for software projects
187 lines • 44.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.PyprojectTomlProjectDynamic = void 0;
exports.toJson_PyprojectToml = toJson_PyprojectToml;
exports.toJson_PyprojectTomlProject = toJson_PyprojectTomlProject;
exports.toJson_PyprojectTomlDependencyGroups = toJson_PyprojectTomlDependencyGroups;
exports.toJson_BuildSystem = toJson_BuildSystem;
exports.toJson_PyprojectTomlTool = toJson_PyprojectTomlTool;
exports.toJson_ProjectAuthor = toJson_ProjectAuthor;
/**
* Converts an object of type 'PyprojectToml' to JSON representation.
* @internal
*/
/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */
function toJson_PyprojectToml(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
'project': toJson_PyprojectTomlProject(obj.project),
'dependency-groups': toJson_PyprojectTomlDependencyGroups(obj.dependencyGroups),
'build-system': toJson_BuildSystem(obj.buildSystem),
'tool': toJson_PyprojectTomlTool(obj.tool),
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});
}
/**
* Converts an object of type 'PyprojectTomlProject' to JSON representation.
* @internal
*/
/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */
function toJson_PyprojectTomlProject(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
'name': obj.name,
'version': obj.version,
'description': obj.description,
'readme': obj.readme,
'requires-python': obj.requiresPython,
'license': obj.license,
'license-files': obj.licenseFiles?.map(y => y),
'authors': obj.authors?.map(y => toJson_ProjectAuthor(y)),
'maintainers': obj.maintainers?.map(y => toJson_ProjectAuthor(y)),
'keywords': obj.keywords?.map(y => y),
'classifiers': obj.classifiers?.map(y => y),
'urls': ((obj.urls) === undefined) ? undefined : (Object.entries(obj.urls).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {})),
'scripts': ((obj.scripts) === undefined) ? undefined : (Object.entries(obj.scripts).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {})),
'gui-scripts': ((obj.guiScripts) === undefined) ? undefined : (Object.entries(obj.guiScripts).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {})),
'entry-points': obj.entryPoints,
'dependencies': obj.dependencies?.map(y => y),
'optional-dependencies': obj.optionalDependencies,
'import-names': obj.importNames?.map(y => y),
'import-namespaces': obj.importNamespaces?.map(y => y),
'dynamic': obj.dynamic?.map(y => y),
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});
}
/**
* Converts an object of type 'PyprojectTomlDependencyGroups' to JSON representation.
* @internal
*/
/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */
function toJson_PyprojectTomlDependencyGroups(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
'dev': obj.dev?.map(y => y),
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});
}
/**
* Converts an object of type 'BuildSystem' to JSON representation.
* @internal
*/
/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */
function toJson_BuildSystem(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
'requires': obj.requires?.map(y => y),
'build-backend': obj.buildBackend,
'backend-path': obj.backendPath?.map(y => y),
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});
}
/**
* Converts an object of type 'PyprojectTomlTool' to JSON representation.
* @internal
*/
/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */
function toJson_PyprojectTomlTool(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
'black': obj.black,
'cibuildwheel': obj.cibuildwheel,
'mypy': obj.mypy,
'ruff': obj.ruff,
'ty': obj.ty,
'hatch': obj.hatch,
'maturin': obj.maturin,
'scikit-build': obj.scikitBuild,
'setuptools': obj.setuptools,
'setuptools_scm': obj.setuptoolsScm,
'poe': obj.poe,
'poetry': obj.poetry,
'pdm': obj.pdm,
'pyright': obj.pyright,
'pytest': obj.pytest,
'repo-review': obj.repoReview,
'taskipy': obj.taskipy,
'tombi': obj.tombi,
'tox': obj.tox,
'uv': obj.uv,
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});
}
/**
* Converts an object of type 'ProjectAuthor' to JSON representation.
* @internal
*/
/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */
function toJson_ProjectAuthor(obj) {
if (obj === undefined) {
return undefined;
}
const result = {
'name': obj.name,
'email': obj.email,
};
// filter undefined values
return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});
}
/* eslint-enable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */
/**
* @schema PyprojectTomlProjectDynamic
*/
var PyprojectTomlProjectDynamic;
(function (PyprojectTomlProjectDynamic) {
/** version */
PyprojectTomlProjectDynamic["VERSION"] = "version";
/** description */
PyprojectTomlProjectDynamic["DESCRIPTION"] = "description";
/** readme */
PyprojectTomlProjectDynamic["README"] = "readme";
/** requires-python */
PyprojectTomlProjectDynamic["REQUIRES_HYPHEN_PYTHON"] = "requires-python";
/** license */
PyprojectTomlProjectDynamic["LICENSE"] = "license";
/** license-files */
PyprojectTomlProjectDynamic["LICENSE_HYPHEN_FILES"] = "license-files";
/** authors */
PyprojectTomlProjectDynamic["AUTHORS"] = "authors";
/** maintainers */
PyprojectTomlProjectDynamic["MAINTAINERS"] = "maintainers";
/** keywords */
PyprojectTomlProjectDynamic["KEYWORDS"] = "keywords";
/** classifiers */
PyprojectTomlProjectDynamic["CLASSIFIERS"] = "classifiers";
/** urls */
PyprojectTomlProjectDynamic["URLS"] = "urls";
/** scripts */
PyprojectTomlProjectDynamic["SCRIPTS"] = "scripts";
/** gui-scripts */
PyprojectTomlProjectDynamic["GUI_HYPHEN_SCRIPTS"] = "gui-scripts";
/** entry-points */
PyprojectTomlProjectDynamic["ENTRY_HYPHEN_POINTS"] = "entry-points";
/** dependencies */
PyprojectTomlProjectDynamic["DEPENDENCIES"] = "dependencies";
/** optional-dependencies */
PyprojectTomlProjectDynamic["OPTIONAL_HYPHEN_DEPENDENCIES"] = "optional-dependencies";
/** import-names */
PyprojectTomlProjectDynamic["IMPORT_HYPHEN_NAMES"] = "import-names";
/** import-namespaces */
PyprojectTomlProjectDynamic["IMPORT_HYPHEN_NAMESPACES"] = "import-namespaces";
})(PyprojectTomlProjectDynamic || (exports.PyprojectTomlProjectDynamic = PyprojectTomlProjectDynamic = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pyproject-toml.js","sourceRoot":"","sources":["../../src/python/pyproject-toml.ts"],"names":[],"mappings":"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","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.ts and run \"node ./projen.js\".\n/**\n * @schema PyprojectToml\n */\nexport interface PyprojectToml {\n  /**\n   * There are two kinds of metadata: _static_ and _dynamic_.\n   * - Static metadata is listed in the `[project]` table directly and cannot be specified or changed by a tool.\n   * - Dynamic metadata key names are listed inside the `dynamic` key and represents metadata that a tool will later provide.\n   *\n   * @schema PyprojectToml#project\n   */\n  readonly project?: PyprojectTomlProject;\n\n  /**\n   * Named groups of dependencies, similar to `requirements.txt` files, which launchers, IDEs, and other tools can find and identify by name. Each item in `[dependency-groups]` is defined as mapping of group name to list of [dependency specifiers](https://packaging.python.org/en/latest/specifications/dependency-specifiers/).\n   *\n   * @schema PyprojectToml#dependency-groups\n   */\n  readonly dependencyGroups?: PyprojectTomlDependencyGroups;\n\n  /**\n   * @schema PyprojectToml#build-system\n   */\n  readonly buildSystem?: BuildSystem;\n\n  /**\n   * Every tool that is used by the project can have users specify configuration data as long as they use a sub-table within `[tool]`. Generally a project can use the subtable `tool.$NAME` if, and only if, they own the entry for `$NAME` in the Cheeseshop/PyPI.\n   *\n   * @schema PyprojectToml#tool\n   */\n  readonly tool?: PyprojectTomlTool;\n}\n\n/**\n * Converts an object of type 'PyprojectToml' to JSON representation.\n * @internal\n */\n/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\nexport function toJson_PyprojectToml(obj: PyprojectToml | undefined): Record<string, any> | undefined {\n  if (obj === undefined) { return undefined; }\n  const result = {\n    'project': toJson_PyprojectTomlProject(obj.project),\n    'dependency-groups': toJson_PyprojectTomlDependencyGroups(obj.dependencyGroups),\n    'build-system': toJson_BuildSystem(obj.buildSystem),\n    'tool': toJson_PyprojectTomlTool(obj.tool),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});\n}\n/* eslint-enable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\n\n/**\n * There are two kinds of metadata: _static_ and _dynamic_.\n * - Static metadata is listed in the `[project]` table directly and cannot be specified or changed by a tool.\n * - Dynamic metadata key names are listed inside the `dynamic` key and represents metadata that a tool will later provide.\n *\n * @schema PyprojectTomlProject\n */\nexport interface PyprojectTomlProject {\n  /**\n   * Valid name consists only of ASCII letters and numbers, period, underscore and hyphen. It must start and end with a letter or number.\n   *\n   * @schema PyprojectTomlProject#name\n   */\n  readonly name: string;\n\n  /**\n   * Version of the project, as defined in the [Version specifier specification](https://packaging.python.org/en/latest/specifications/version-specifiers/), and preferably [already normalized](https://packaging.python.org/en/latest/specifications/version-specifiers/#normalization).\n   *\n   * @schema PyprojectTomlProject#version\n   */\n  readonly version?: string;\n\n  /**\n   * Summary description of the project in one line. Tools may not accept multiple lines.\n   *\n   * @schema PyprojectTomlProject#description\n   */\n  readonly description?: string;\n\n  /**\n   * Value can be a relative path to text / markdown (`.md` suffix) / reStructuredText (`.rst` suffix) readme file, or a table with either:\n   * - `file` key containing path of aforementioned readme file, or\n   * - `text` key containing the full readme text embedded inside `pyproject.toml`.\n   *\n   * @schema PyprojectTomlProject#readme\n   */\n  readonly readme?: any;\n\n  /**\n   * Specifies the Python version(s) that the distribution is compatible with. Must be in the format specified in [Version specifiers](https://packaging.python.org/en/latest/specifications/version-specifiers/).\n   *\n   * @schema PyprojectTomlProject#requires-python\n   */\n  readonly requiresPython?: string;\n\n  /**\n   * For now it is a table with either:\n   * - `file` key specifying a relative path to a license file, or\n   * - `text` key containing full license content\n   *\n   * Newer tool may accept a single [SPDX license expression](https://spdx.github.io/spdx-spec/v2.2.2/SPDX-license-expressions/) string instead of a table.\n   *\n   * @schema PyprojectTomlProject#license\n   */\n  readonly license?: any;\n\n  /**\n   * Relative paths or globs to paths of license files. Can be an empty list.\n   *\n   * @schema PyprojectTomlProject#license-files\n   */\n  readonly licenseFiles?: string[];\n\n  /**\n   * People or organizations considered as 'authors' of the project. Each author is a table with `name` key, `email` key, or both.\n   *\n   * @schema PyprojectTomlProject#authors\n   */\n  readonly authors?: ProjectAuthor[];\n\n  /**\n   * People or organizations considered as 'maintainers' of the project. Each maintainer is a table with `name` key, `email` key, or both.\n   *\n   * @schema PyprojectTomlProject#maintainers\n   */\n  readonly maintainers?: ProjectAuthor[];\n\n  /**\n   * List of keywords or tags that describe the project. They could be used by search engines to categorize the project.\n   *\n   * @schema PyprojectTomlProject#keywords\n   */\n  readonly keywords?: string[];\n\n  /**\n   * List of [Trove classifiers](https://pypi.org/classifiers/) that describe the project. PyPI use the classifiers to categorize projects.\n   *\n   * @schema PyprojectTomlProject#classifiers\n   */\n  readonly classifiers?: string[];\n\n  /**\n   * Table consisting one or multiple `label: URL` pairs. Common indexes like PyPI uses [well-known Project URLs](https://packaging.python.org/en/latest/specifications/well-known-project-urls/#well-known-labels) when presenting project pages.\n   *\n   * @schema PyprojectTomlProject#urls\n   */\n  readonly urls?: { [key: string]: string };\n\n  /**\n   * Table of [entry points](https://packaging.python.org/en/latest/specifications/entry-points/) that allows package installers to create a command-line wrapper for. Each key is the name of the script to be created, and each value is the function or object to all, in form of either `importable.module` or `importable.module:object.attr`. Windows platform treats `console_scripts` specially in that they are wrapped in a console executable, so they are attached to a console and can use `sys.stdin`, `sys.stdout` and `sys.stderr` for I/O.\n   *\n   * @schema PyprojectTomlProject#scripts\n   */\n  readonly scripts?: { [key: string]: string };\n\n  /**\n   * Table of [entry points](https://packaging.python.org/en/latest/specifications/entry-points/) that allows package installers to create a GUI wrapper for. Each key is the name of the script to be created, and each value is the function or object to all, in form of either `importable.module` or `importable.module:object.attr`. Windows platform treats `gui_scripts` specially in that they are wrapped in a GUI executable, so they can be started without a console, but cannot use standard streams unless application code redirects them.\n   *\n   * @schema PyprojectTomlProject#gui-scripts\n   */\n  readonly guiScripts?: { [key: string]: string };\n\n  /**\n   * Extra [entry point groups](https://packaging.python.org/en/latest/specifications/entry-points/) that allow applications to load plugins. For example, Pygments (a syntax highlighting tool) can use additional styles from separately installed packages through `[project.entry-points.\"pygments.styles\"]`. Each key is the name of the entry-point group, and each value is a table of entry points.\n   *\n   * @schema PyprojectTomlProject#entry-points\n   */\n  readonly entryPoints?: any;\n\n  /**\n   * An array of [dependency specifier](https://packaging.python.org/en/latest/specifications/dependency-specifiers/) strings, each representing a mandatory dependent package of the project.\n   *\n   * @schema PyprojectTomlProject#dependencies\n   */\n  readonly dependencies?: string[];\n\n  /**\n   * Each entry is a key/value pair, with the key specifying [extra feature name](https://packaging.python.org/en/latest/specifications/core-metadata/#provides-extra-multiple-use) (such as `socks` in `requests[socks]`), and value is an array of [dependency specifier](https://packaging.python.org/en/latest/specifications/dependency-specifiers/) strings.\n   *\n   * @schema PyprojectTomlProject#optional-dependencies\n   */\n  readonly optionalDependencies?: any;\n\n  /**\n   * An array of strings specifying the import names that the project exclusively provides when installed.\n   *\n   * @schema PyprojectTomlProject#import-names\n   */\n  readonly importNames?: string[];\n\n  /**\n   * An array of strings specifying the import names that the project provides when installed, but not exclusively.\n   *\n   * @schema PyprojectTomlProject#import-namespaces\n   */\n  readonly importNamespaces?: string[];\n\n  /**\n   * Specifies which keys are intentionally unspecified under `[project]` table so build backend can/will provide such metadata dynamically. Each key must be listed only once. It is an error to both list a key in `dynamic` and use the key directly in `[project]`.\n   * One of the most common usage is `version`, which allows build backend to retrieve project version from source code or version control system instead of hardcoding it in `pyproject.toml`.\n   *\n   * @schema PyprojectTomlProject#dynamic\n   */\n  readonly dynamic?: PyprojectTomlProjectDynamic[];\n}\n\n/**\n * Converts an object of type 'PyprojectTomlProject' to JSON representation.\n * @internal\n */\n/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\nexport function toJson_PyprojectTomlProject(obj: PyprojectTomlProject | undefined): Record<string, any> | undefined {\n  if (obj === undefined) { return undefined; }\n  const result = {\n    'name': obj.name,\n    'version': obj.version,\n    'description': obj.description,\n    'readme': obj.readme,\n    'requires-python': obj.requiresPython,\n    'license': obj.license,\n    'license-files': obj.licenseFiles?.map(y => y),\n    'authors': obj.authors?.map(y => toJson_ProjectAuthor(y)),\n    'maintainers': obj.maintainers?.map(y => toJson_ProjectAuthor(y)),\n    'keywords': obj.keywords?.map(y => y),\n    'classifiers': obj.classifiers?.map(y => y),\n    'urls': ((obj.urls) === undefined) ? undefined : (Object.entries(obj.urls).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {})),\n    'scripts': ((obj.scripts) === undefined) ? undefined : (Object.entries(obj.scripts).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {})),\n    'gui-scripts': ((obj.guiScripts) === undefined) ? undefined : (Object.entries(obj.guiScripts).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {})),\n    'entry-points': obj.entryPoints,\n    'dependencies': obj.dependencies?.map(y => y),\n    'optional-dependencies': obj.optionalDependencies,\n    'import-names': obj.importNames?.map(y => y),\n    'import-namespaces': obj.importNamespaces?.map(y => y),\n    'dynamic': obj.dynamic?.map(y => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});\n}\n/* eslint-enable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\n\n/**\n * Named groups of dependencies, similar to `requirements.txt` files, which launchers, IDEs, and other tools can find and identify by name. Each item in `[dependency-groups]` is defined as mapping of group name to list of [dependency specifiers](https://packaging.python.org/en/latest/specifications/dependency-specifiers/).\n *\n * @schema PyprojectTomlDependencyGroups\n */\nexport interface PyprojectTomlDependencyGroups {\n  /**\n   * @schema PyprojectTomlDependencyGroups#dev\n   */\n  readonly dev?: any[];\n}\n\n/**\n * Converts an object of type 'PyprojectTomlDependencyGroups' to JSON representation.\n * @internal\n */\n/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\nexport function toJson_PyprojectTomlDependencyGroups(obj: PyprojectTomlDependencyGroups | undefined): Record<string, any> | undefined {\n  if (obj === undefined) { return undefined; }\n  const result = {\n    'dev': obj.dev?.map(y => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});\n}\n/* eslint-enable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\n\n/**\n * Declares any Python level dependencies that must be installed in order to run the project’s build system successfully.\n *\n * @schema BuildSystem\n */\nexport interface BuildSystem {\n  /**\n   * List of strings following the version specifier specification, representing dependencies required to execute the build system.\n   *\n   * @schema BuildSystem#requires\n   */\n  readonly requires: string[];\n\n  /**\n   * String is formatted following the same `module:object` syntax as a `setuptools` entry point. It’s also legal to leave out the `:object` part.\n   *\n   * @schema BuildSystem#build-backend\n   */\n  readonly buildBackend?: string;\n\n  /**\n   * list of directories to prepend to `sys.path` when loading the build backend, relative to project root\n   *\n   * @schema BuildSystem#backend-path\n   */\n  readonly backendPath?: string[];\n}\n\n/**\n * Converts an object of type 'BuildSystem' to JSON representation.\n * @internal\n */\n/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\nexport function toJson_BuildSystem(obj: BuildSystem | undefined): Record<string, any> | undefined {\n  if (obj === undefined) { return undefined; }\n  const result = {\n    'requires': obj.requires?.map(y => y),\n    'build-backend': obj.buildBackend,\n    'backend-path': obj.backendPath?.map(y => y),\n  };\n  // filter undefined values\n  return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});\n}\n/* eslint-enable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\n\n/**\n * Every tool that is used by the project can have users specify configuration data as long as they use a sub-table within `[tool]`. Generally a project can use the subtable `tool.$NAME` if, and only if, they own the entry for `$NAME` in the Cheeseshop/PyPI.\n *\n * @schema PyprojectTomlTool\n */\nexport interface PyprojectTomlTool {\n  /**\n   * The uncompromising Python code formatter.\n   *\n   * @schema PyprojectTomlTool#black\n   */\n  readonly black?: any;\n\n  /**\n   * Build Python wheels for all platforms.\n   *\n   * @schema PyprojectTomlTool#cibuildwheel\n   */\n  readonly cibuildwheel?: any;\n\n  /**\n   * Optional static typing for Python.\n   *\n   * @schema PyprojectTomlTool#mypy\n   */\n  readonly mypy?: any;\n\n  /**\n   * An extremely fast Python linter and formatter, written in Rust.\n   *\n   * @schema PyprojectTomlTool#ruff\n   */\n  readonly ruff?: any;\n\n  /**\n   * An extremely fast Python type checker, written in Rust.\n   *\n   * @schema PyprojectTomlTool#ty\n   */\n  readonly ty?: any;\n\n  /**\n   * Modern, extensible Python project management.\n   *\n   * @schema PyprojectTomlTool#hatch\n   */\n  readonly hatch?: any;\n\n  /**\n   * Build and publish crates with pyo3, cffi and uniffi bindings as well as rust binaries as python packages\n   *\n   * @schema PyprojectTomlTool#maturin\n   */\n  readonly maturin?: any;\n\n  /**\n   * Improved build system generator for Python C/C++/Fortran extensions\n   *\n   * @schema PyprojectTomlTool#scikit-build\n   */\n  readonly scikitBuild?: any;\n\n  /**\n   * Easily download, build, install, upgrade, and uninstall Python packages.\n   *\n   * @schema PyprojectTomlTool#setuptools\n   */\n  readonly setuptools?: any;\n\n  /**\n   * Manage Python package versions using SCM (e.g. Git).\n   *\n   * @schema PyprojectTomlTool#setuptools_scm\n   */\n  readonly setuptoolsScm?: any;\n\n  /**\n   * A task runner that works well with pyproject.toml files.\n   *\n   * @schema PyprojectTomlTool#poe\n   */\n  readonly poe?: any;\n\n  /**\n   * Python dependency management and packaging made easy.\n   *\n   * @schema PyprojectTomlTool#poetry\n   */\n  readonly poetry?: any;\n\n  /**\n   * A modern Python package manager with PEP 621 support.\n   *\n   * @schema PyprojectTomlTool#pdm\n   */\n  readonly pdm?: any;\n\n  /**\n   * Static type checker for Python.\n   *\n   * @schema PyprojectTomlTool#pyright\n   */\n  readonly pyright?: any;\n\n  /**\n   * Standardized automated testing of Python packages\n   *\n   * @schema PyprojectTomlTool#pytest\n   */\n  readonly pytest?: any;\n\n  /**\n   * Review a repository for best practices.\n   *\n   * @schema PyprojectTomlTool#repo-review\n   */\n  readonly repoReview?: any;\n\n  /**\n   * The complementary task runner for python.\n   *\n   * @schema PyprojectTomlTool#taskipy\n   */\n  readonly taskipy?: any;\n\n  /**\n   * Tombi is a toolkit for TOML; providing a formatter/linter and language server\n   *\n   * @schema PyprojectTomlTool#tombi\n   */\n  readonly tombi?: any;\n\n  /**\n   * Standardized automated testing of Python packages\n   *\n   * @schema PyprojectTomlTool#tox\n   */\n  readonly tox?: any;\n\n  /**\n   * An extremely fast Python package installer and resolver, written in Rust.\n   *\n   * @schema PyprojectTomlTool#uv\n   */\n  readonly uv?: any;\n}\n\n/**\n * Converts an object of type 'PyprojectTomlTool' to JSON representation.\n * @internal\n */\n/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\nexport function toJson_PyprojectTomlTool(obj: PyprojectTomlTool | undefined): Record<string, any> | undefined {\n  if (obj === undefined) { return undefined; }\n  const result = {\n    'black': obj.black,\n    'cibuildwheel': obj.cibuildwheel,\n    'mypy': obj.mypy,\n    'ruff': obj.ruff,\n    'ty': obj.ty,\n    'hatch': obj.hatch,\n    'maturin': obj.maturin,\n    'scikit-build': obj.scikitBuild,\n    'setuptools': obj.setuptools,\n    'setuptools_scm': obj.setuptoolsScm,\n    'poe': obj.poe,\n    'poetry': obj.poetry,\n    'pdm': obj.pdm,\n    'pyright': obj.pyright,\n    'pytest': obj.pytest,\n    'repo-review': obj.repoReview,\n    'taskipy': obj.taskipy,\n    'tombi': obj.tombi,\n    'tox': obj.tox,\n    'uv': obj.uv,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});\n}\n/* eslint-enable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\n\n/**\n * @schema projectAuthor\n */\nexport interface ProjectAuthor {\n  /**\n   * @schema projectAuthor#name\n   */\n  readonly name?: string;\n\n  /**\n   * @schema projectAuthor#email\n   */\n  readonly email?: string;\n}\n\n/**\n * Converts an object of type 'ProjectAuthor' to JSON representation.\n * @internal\n */\n/* eslint-disable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\nexport function toJson_ProjectAuthor(obj: ProjectAuthor | undefined): Record<string, any> | undefined {\n  if (obj === undefined) { return undefined; }\n  const result = {\n    'name': obj.name,\n    'email': obj.email,\n  };\n  // filter undefined values\n  return Object.entries(result).reduce((r, i) => (i[1] === undefined) ? r : ({ ...r, [i[0]]: i[1] }), {});\n}\n/* eslint-enable max-len, @stylistic/max-len, quote-props, @stylistic/quote-props */\n\n/**\n * @schema PyprojectTomlProjectDynamic\n */\nexport enum PyprojectTomlProjectDynamic {\n  /** version */\n  VERSION = \"version\",\n  /** description */\n  DESCRIPTION = \"description\",\n  /** readme */\n  README = \"readme\",\n  /** requires-python */\n  REQUIRES_HYPHEN_PYTHON = \"requires-python\",\n  /** license */\n  LICENSE = \"license\",\n  /** license-files */\n  LICENSE_HYPHEN_FILES = \"license-files\",\n  /** authors */\n  AUTHORS = \"authors\",\n  /** maintainers */\n  MAINTAINERS = \"maintainers\",\n  /** keywords */\n  KEYWORDS = \"keywords\",\n  /** classifiers */\n  CLASSIFIERS = \"classifiers\",\n  /** urls */\n  URLS = \"urls\",\n  /** scripts */\n  SCRIPTS = \"scripts\",\n  /** gui-scripts */\n  GUI_HYPHEN_SCRIPTS = \"gui-scripts\",\n  /** entry-points */\n  ENTRY_HYPHEN_POINTS = \"entry-points\",\n  /** dependencies */\n  DEPENDENCIES = \"dependencies\",\n  /** optional-dependencies */\n  OPTIONAL_HYPHEN_DEPENDENCIES = \"optional-dependencies\",\n  /** import-names */\n  IMPORT_HYPHEN_NAMES = \"import-names\",\n  /** import-namespaces */\n  IMPORT_HYPHEN_NAMESPACES = \"import-namespaces\",\n}\n"]}