PEP 739: add version specification to schema_version (#4112)

This commit is contained in:
Filipe Laíns 🇵🇸 2024-11-06 17:11:55 +00:00 committed by GitHub
parent 5c7b771511
commit 2a18b29751
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 25 additions and 10 deletions

View File

@ -74,7 +74,7 @@ below, which is rendered in an human-readable format here.
* - ``$schema`` * - ``$schema``
- https://json-schema.org/draft/2020-12/schema - https://json-schema.org/draft/2020-12/schema
* - ``$id`` * - ``$id``
- https://github.com/python/peps/blob/main/peps/pep-0739/python-build-info-v1.schema.json - https://github.com/python/peps/blob/main/peps/pep-0739/python-build-info-v1.0.schema.json
* - Title * - Title
- Static description file for the build details of Python - Static description file for the build details of Python
installations installations
@ -90,13 +90,28 @@ below, which is rendered in an human-readable format here.
:widths: 25 75 :widths: 25 75
* - Type * - Type
- ``string`` (constant — ``1``) - ``string`` (constant — ``1.0``)
* - Description * - Description
- Schema version. - Schema version.
This is a constant value and MUST be ``1``, when using the This is a string following the format ``<MAJOR>.<MINOR>``, where
schema described here. Future iterations of this schema MUST ``<MAJOR>`` and ``<MINOR>`` are unpaded numbers and represent
update this value. the **major** and **minor** components of the version. Versions
may be arithmetic compared by intrepreting the version string as
a decimal number.
For this specification version, this value is constant and MUST
be ``1.0``.
Future versions of this schema MUST use a higher version number.
Future versions of this schema MUST NOT use the same **major**
version component as other schema version unless its
specification is deemed backwards-compatible with them — it
can't change, or extend, any parts of the current specification
in such a way as the semantics of the interpreted data differ,
or that data valid under the new specification is invalid under
the older specification, with the exception of additional
properties (errors caused by ``additionalProperties``).
* - Required * - Required
- **True** - **True**
@ -698,7 +713,7 @@ Example
JSON Schema JSON Schema
=========== ===========
.. literalinclude:: pep-0739/python-build-info-v1.schema.json .. literalinclude:: pep-0739/python-build-info-v1.0.schema.json
:language: json :language: json
:linenos: :linenos:

View File

@ -1,5 +1,5 @@
{ {
"schema_version": "1", "schema_version": "1.0",
"base_prefix": "/usr", "base_prefix": "/usr",
"platform": "linux-x86_64", "platform": "linux-x86_64",
"language": { "language": {

View File

@ -1,6 +1,6 @@
{ {
"$schema": "https://json-schema.org/draft/2020-12/schema", "$schema": "https://json-schema.org/draft/2020-12/schema",
"$id": "https://github.com/python/peps/blob/main/peps/pep-0739/python-build-info-v1.schema.json", "$id": "https://github.com/python/peps/blob/main/peps/pep-0739/python-build-info-v1.0.schema.json",
"type": "object", "type": "object",
"title": "Static description file for the build details of Python installations", "title": "Static description file for the build details of Python installations",
"required": [ "required": [
@ -13,8 +13,8 @@
"properties": { "properties": {
"schema_version": { "schema_version": {
"type": "string", "type": "string",
"description": "Schema version.\n\nThis is a constant value and MUST be ``1``, when using the schema described here. Future iterations of this schema MUST update this value.", "description": "Schema version.\n\nThis is a string following the format ``<MAJOR>.<MINOR>``, where ``<MAJOR>`` and ``<MINOR>`` are unpaded numbers and represent the **major** and **minor** components of the version. Versions may be arithmetic compared by intrepreting the version string as a decimal number.\n\nFor this specification version, this value is constant and MUST be ``1.0``.\n\nFuture versions of this schema MUST use a higher version number. Future versions of this schema MUST NOT use the same **major** version component as other schema version unless its specification is deemed backwards-compatible with them — it can't change, or extend, any parts of the current specification in such a way as the semantics of the interpreted data differ, or that data valid under the new specification is invalid under the older specification, with the exception of additional properties (errors caused by ``additionalProperties``).",
"const": "1" "const": "1.0"
}, },
"base_prefix": { "base_prefix": {
"type": "string", "type": "string",