{"diffoscope-json-version": 1, "source1": "/srv/reproducible-results/rbuild-debian/r-b-build.oN4393hk/b1/python-cyclopts_3.4.1-1_arm64.changes", "source2": "/srv/reproducible-results/rbuild-debian/r-b-build.oN4393hk/b2/python-cyclopts_3.4.1-1_arm64.changes", "unified_diff": null, "details": [{"source1": "Files", "source2": "Files", "unified_diff": "@@ -1,3 +1,3 @@\n \n- 6000d71fbfe3a0ffea2ffdfc7ed8b02b 261272 doc optional python-cyclopts-doc_3.4.1-1_all.deb\n+ 888e6669bb6ec11a992bd8831576a3b2 261260 doc optional python-cyclopts-doc_3.4.1-1_all.deb\n 72a003b4570b636dae1cf3e34edd6e99 51144 python optional python3-cyclopts_3.4.1-1_all.deb\n"}, {"source1": "python-cyclopts-doc_3.4.1-1_all.deb", "source2": "python-cyclopts-doc_3.4.1-1_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-02-01 20:43:06.000000 debian-binary\n -rw-r--r-- 0 0 0 4828 2025-02-01 20:43:06.000000 control.tar.xz\n--rw-r--r-- 0 0 0 256252 2025-02-01 20:43:06.000000 data.tar.xz\n+-rw-r--r-- 0 0 0 256240 2025-02-01 20:43:06.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": "@@ -2223,22 +2223,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 0xffff9c3fbd80>)]

\n+

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

\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 0xffff9c3fbd80>)]

\n+

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

\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@@ -2251,22 +2251,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 0xffff9c3fbd80>)]

\n+

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

\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 0xffff9c3fbd80>)]

\n+

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

\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@@ -2279,22 +2279,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 0xffff9c3fbd80>)]

\n+

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

\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 0xffff9c3fbd80>)]

\n+

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

\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@@ -2416,15 +2416,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 0xffff9c3fbce0>)]

\n+

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

\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": "@@ -1527,59 +1527,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 0xffff96f67d80>)]\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 0xffff96f67d80>)]\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 0xffff96f67d80>)]\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 0xffff96f67d80>)]\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 0xffff96f67d80>)]\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 0xffff96f67d80>)]\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@@ -1649,15 +1649,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+ 0xffff96f67ce0>)]\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"}]}]}]}]}]}