{"diffoscope-json-version": 1, "source1": "/srv/reproducible-results/rbuild-debian/r-b-build.SuZpnGYf/b1/python-cyclopts_3.1.2-2_arm64.changes", "source2": "/srv/reproducible-results/rbuild-debian/r-b-build.SuZpnGYf/b2/python-cyclopts_3.1.2-2_arm64.changes", "unified_diff": null, "details": [{"source1": "Files", "source2": "Files", "unified_diff": "@@ -1,3 +1,3 @@\n \n- bb9223e82a1e3945a29c7aafb1a69c67 247848 doc optional python-cyclopts-doc_3.1.2-2_all.deb\n+ f5f559d344314a2a01c9dc0188feb51e 247864 doc optional python-cyclopts-doc_3.1.2-2_all.deb\n 2417b3a97be773cf11d661abdee43a86 48056 python optional python3-cyclopts_3.1.2-2_all.deb\n"}, {"source1": "python-cyclopts-doc_3.1.2-2_all.deb", "source2": "python-cyclopts-doc_3.1.2-2_all.deb", "unified_diff": null, "details": [{"source1": "file list", "source2": "file list", "unified_diff": "@@ -1,3 +1,3 @@\n -rw-r--r-- 0 0 0 4 2025-01-19 20:16:24.000000 debian-binary\n -rw-r--r-- 0 0 0 4624 2025-01-19 20:16:24.000000 control.tar.xz\n--rw-r--r-- 0 0 0 243032 2025-01-19 20:16:24.000000 data.tar.xz\n+-rw-r--r-- 0 0 0 243048 2025-01-19 20:16:24.000000 data.tar.xz\n"}, {"source1": "control.tar.xz", "source2": "control.tar.xz", "unified_diff": null, "details": [{"source1": "control.tar", "source2": "control.tar", "unified_diff": null, "details": [{"source1": "./md5sums", "source2": "./md5sums", "unified_diff": null, "details": [{"source1": "./md5sums", "source2": "./md5sums", "comments": ["Files differ"], "unified_diff": null}]}]}]}, {"source1": "data.tar.xz", "source2": "data.tar.xz", "unified_diff": null, "details": [{"source1": "data.tar", "source2": "data.tar", "unified_diff": null, "details": [{"source1": "./usr/share/doc/python-cyclopts-doc/html/api.html", "source2": "./usr/share/doc/python-cyclopts-doc/html/api.html", "unified_diff": "@@ -2127,22 +2127,22 @@\n

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=True, dir_okay=True),))]

\n \n \n
\n
\n cyclopts.types.ResolvedPath\uf0c1
\n

A Path file or directory. resolve() is invoked prior to returning the path.

\n-

alias of Annotated[Path, Parameter(converter=<function _path_resolve_converter at 0xffff842177e0>)]

\n+

alias of Annotated[Path, Parameter(converter=<function _path_resolve_converter at 0xffff808677e0>)]

\n
\n \n
\n
\n cyclopts.types.ResolvedExistingPath\uf0c1
\n

A Path file or directory that must exist. resolve() is invoked prior to returning the path.

\n-

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=True, dir_okay=True),)), Parameter(converter=<function _path_resolve_converter at 0xffff842177e0>)]

\n+

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=True, dir_okay=True),)), Parameter(converter=<function _path_resolve_converter at 0xffff808677e0>)]

\n
\n \n
\n
\n cyclopts.types.Directory\uf0c1
\n

A Path that must be a directory (or not exist).

\n

alias of Annotated[Path, Parameter(validator=(Path(exists=False, file_okay=False, dir_okay=True),))]

\n@@ -2155,22 +2155,22 @@\n

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=False, dir_okay=True),))]

\n
\n \n
\n
\n cyclopts.types.ResolvedDirectory\uf0c1
\n

A Path directory. resolve() is invoked prior to returning the path.

\n-

alias of Annotated[Path, Parameter(validator=(Path(exists=False, file_okay=False, dir_okay=True),)), Parameter(converter=<function _path_resolve_converter at 0xffff842177e0>)]

\n+

alias of Annotated[Path, Parameter(validator=(Path(exists=False, file_okay=False, dir_okay=True),)), Parameter(converter=<function _path_resolve_converter at 0xffff808677e0>)]

\n
\n \n
\n
\n cyclopts.types.ResolvedExistingDirectory\uf0c1
\n

A Path directory that must exist. resolve() is invoked prior to returning the path.

\n-

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=False, dir_okay=True),)), Parameter(converter=<function _path_resolve_converter at 0xffff842177e0>)]

\n+

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=False, dir_okay=True),)), Parameter(converter=<function _path_resolve_converter at 0xffff808677e0>)]

\n
\n \n
\n
\n cyclopts.types.File\uf0c1
\n

A File that must be a file (or not exist).

\n

alias of Annotated[Path, Parameter(validator=(Path(exists=False, file_okay=True, dir_okay=False),))]

\n@@ -2183,22 +2183,22 @@\n

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=True, dir_okay=False),))]

\n
\n \n
\n
\n cyclopts.types.ResolvedFile\uf0c1
\n

A Path file. resolve() is invoked prior to returning the path.

\n-

alias of Annotated[Path, Parameter(validator=(Path(exists=False, file_okay=True, dir_okay=False),)), Parameter(converter=<function _path_resolve_converter at 0xffff842177e0>)]

\n+

alias of Annotated[Path, Parameter(validator=(Path(exists=False, file_okay=True, dir_okay=False),)), Parameter(converter=<function _path_resolve_converter at 0xffff808677e0>)]

\n
\n \n
\n
\n cyclopts.types.ResolvedExistingFile\uf0c1
\n

A Path file that must exist. resolve() is invoked prior to returning the path.

\n-

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=True, dir_okay=False),)), Parameter(converter=<function _path_resolve_converter at 0xffff842177e0>)]

\n+

alias of Annotated[Path, Parameter(validator=(Path(exists=True, file_okay=True, dir_okay=False),)), Parameter(converter=<function _path_resolve_converter at 0xffff808677e0>)]

\n
\n \n \n
\n

Number\uf0c1

\n

Annotated types for checking common int/float value constraints.\n All of these types will also work on sequence of numbers (e.g. tuple[int, int] or list[float]).

\n@@ -2320,15 +2320,15 @@\n app()\n \n \n
$ my-script '{"foo": 1, "bar": 2}'\n {'foo': 1, 'bar': 2}\n 
\n
\n-

alias of Annotated[Any, Parameter(converter=<function _json_converter at 0xffff8296a020>)]

\n+

alias of Annotated[Any, Parameter(converter=<function _json_converter at 0xffff7efbe020>)]

\n \n \n
\n \n
\n

Config\uf0c1

\n

Cyclopts has builtin configuration classes to be used with App.config for loading user-defined defaults in many common scenarios.\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -1448,59 +1448,59 @@\n A Path file or directory that m\bmu\bus\bst\bt exist.\n alias of Annotated[Path, Parameter(validator=(Path(exists=True,\n file_okay=True, dir_okay=True),))]\n cyclopts.types.ResolvedPath_\b\uf0c1\n A Path file or directory. resolve() is invoked prior to returning the\n path.\n alias of Annotated[Path, Parameter(converter=)]\n+ _path_resolve_converter at 0xffff808677e0>)]\n cyclopts.types.ResolvedExistingPath_\b\uf0c1\n A Path file or directory that m\bmu\bus\bst\bt exist. resolve() is invoked prior to\n returning the path.\n alias of Annotated[Path, Parameter(validator=(Path(exists=True,\n file_okay=True, dir_okay=True),)), Parameter(converter=)]\n+ _path_resolve_converter at 0xffff808677e0>)]\n cyclopts.types.Directory_\b\uf0c1\n A Path that m\bmu\bus\bst\bt be a directory (or not exist).\n alias of Annotated[Path, Parameter(validator=(Path(exists=False,\n file_okay=False, dir_okay=True),))]\n cyclopts.types.ExistingDirectory_\b\uf0c1\n A Path directory that m\bmu\bus\bst\bt exist.\n alias of Annotated[Path, Parameter(validator=(Path(exists=True,\n file_okay=False, dir_okay=True),))]\n cyclopts.types.ResolvedDirectory_\b\uf0c1\n A Path directory. resolve() is invoked prior to returning the path.\n alias of Annotated[Path, Parameter(validator=(Path(exists=False,\n file_okay=False, dir_okay=True),)), Parameter(converter=)]\n+ _path_resolve_converter at 0xffff808677e0>)]\n cyclopts.types.ResolvedExistingDirectory_\b\uf0c1\n A Path directory that m\bmu\bus\bst\bt exist. resolve() is invoked prior to returning\n the path.\n alias of Annotated[Path, Parameter(validator=(Path(exists=True,\n file_okay=False, dir_okay=True),)), Parameter(converter=)]\n+ _path_resolve_converter at 0xffff808677e0>)]\n cyclopts.types.File_\b\uf0c1\n A File that m\bmu\bus\bst\bt be a file (or not exist).\n alias of Annotated[Path, Parameter(validator=(Path(exists=False,\n file_okay=True, dir_okay=False),))]\n cyclopts.types.ExistingFile_\b\uf0c1\n A Path file that m\bmu\bus\bst\bt exist.\n alias of Annotated[Path, Parameter(validator=(Path(exists=True,\n file_okay=True, dir_okay=False),))]\n cyclopts.types.ResolvedFile_\b\uf0c1\n A Path file. resolve() is invoked prior to returning the path.\n alias of Annotated[Path, Parameter(validator=(Path(exists=False,\n file_okay=True, dir_okay=False),)), Parameter(converter=)]\n+ _path_resolve_converter at 0xffff808677e0>)]\n cyclopts.types.ResolvedExistingFile_\b\uf0c1\n A Path file that m\bmu\bus\bst\bt exist. resolve() is invoked prior to returning the\n path.\n alias of Annotated[Path, Parameter(validator=(Path(exists=True,\n file_okay=True, dir_okay=False),)), Parameter(converter=)]\n+ _path_resolve_converter at 0xffff808677e0>)]\n *\b**\b**\b**\b* N\bNu\bum\bmb\bbe\ber\br_\b?\b\uf0c1 *\b**\b**\b**\b*\n Annotated types for checking common int/float value constraints. All of these\n types will also work on sequence of numbers (e.g. tuple[int, int] or list\n [float]).\n cyclopts.types.PositiveFloat_\b\uf0c1\n A float that m\bmu\bus\bst\bt be >0.\n alias of Annotated[float, Parameter(validator=(Number(lt=None, lte=None,\n@@ -1570,15 +1570,15 @@\n def main(json: types.Json):\n print(json)\n \n app()\n $ my-script '{\"foo\": 1, \"bar\": 2}'\n {'foo': 1, 'bar': 2}\n alias of Annotated[Any, Parameter(converter=)]\n+ 0xffff7efbe020>)]\n *\b**\b**\b**\b**\b* C\bCo\bon\bnf\bfi\big\bg_\b?\b\uf0c1 *\b**\b**\b**\b**\b*\n Cyclopts has builtin configuration classes to be used with _\bA_\bp_\bp_\b._\bc_\bo_\bn_\bf_\bi_\bg for\n loading user-defined defaults in many common scenarios. All Cyclopts builtins\n index into the configuration file with the following rules:\n 1. Apply root_keys (if provided) to enter the project's configuration\n namespace.\n 2. Apply the command name(s) to enter the current command's configuration\n"}]}]}]}]}]}