https://git.schokokeks.org/derivepassphrase.git/tree/47322731c63f9323de73c468671f1ab77f21ee7e Recent commits to derivepassphrase.git (47322731c63f9323de73c468671f1ab77f21ee7e) 2025-02-09T20:47:17+01:00 tag:gitlist.org,2012:commit/47322731c63f9323de73c468671f1ab77f21ee7e Add message IDs (and missing entries) to the manpage diagnostics listings 2025-02-09T20:47:17+01:00 Marco Ricci software@the13thletter.info <pre>Using the new quality control scripts, add message IDs to all diagnostic messages described in the manpages, and add the entries missing from the manpages as well. &lt;/pre&gt; tag:gitlist.org,2012:commit/7ad6f085929dbe15d25b9e1885948fdfc752c1ee Add quality control scripts 2025-02-09T20:47:17+01:00 Marco Ricci software@the13thletter.info <pre>Add a quality control script `qc_auto.py` that calls the linter, the formatter, the type checker, the test suite and the documentation builder, depending on what branch we are on. It is intended to be usable as a pre-commit hook. Add another quality control script `man_diagnostics.py` that checks that the diagnostics documented in the manpages are complete, and match the enum values within `derivepassphrase`. It relies on annotations (comments) in the manpages to map description texts to the respective enum values (the mapping is not one-to-one). It also does a (rudimentary) check that every warning and error message is mentioned somewhere in the source tree (besides the messages module that defines those messages). &lt;/pre&gt; tag:gitlist.org,2012:commit/4aa3f0c0ecf1adc4e3907c7db1ecd6602a100b58 Prepare `bump-my-version` for this project 2025-02-08T19:58:45+01:00 Marco Ricci software@the13thletter.info <pre>Prepare and configure the use of `bump-my-version` to automate keeping version numbers synchronized everywhere. From a cursory search, this appears to be the most mature and actively developed tool of this kind with support for `pyproject.toml` and multiple files with file-specific replacements. Some minor warts remain (non-recursive globbing, duplication of the version number, incorrect calculation of the next release due to missing true support for pre-release segments), but they can be worked around, for now. &lt;/pre&gt; tag:gitlist.org,2012:commit/dacf79e57cd521ca9489148bda95fc0a53229ca5 Store the version only in pyproject.toml 2025-02-08T17:24:28+01:00 Marco Ricci software@the13thletter.info <pre>Establish pyproject.toml functionally as the single source of truth for the version number, so users can rely on `importlib.metadata.version` to query the version programmatically [1, 2]. Storing the version number in the packaging metadata makes it directly accessible to most build tools statically, instead of dynamically, which in theory would make certain kinds of operations (reinstall, querying the metadata from a git checkout) much more tractable [3]. And frankly, the only reason the version attribute previously was dynamic was incomplete tooling support. [4, 5] We still retain the `__version__` attribute -- we need the version number for the command-line interface and machinery, and querying it via the installed packages registry is unnecessarily heavyweight -- but only on the top-level package. Same goes for the `__author__` attribute. In future commits, the `__version__` attribute (and version markers in other files such as the manpages) will be auto-generated by our build system, commit hooks, or the like. In general, what we still need is a system to update all mentions of a version number across the software package [6]. Further reading: 1. Python Packaging Authority: [Single-sourcing the Project Version](https://packaging.python.org/en/latest/discussions/single-source-version/). 2. Hynek Schlawek: [Python Packaging Metadata](https://hynek.me/articles/packaging-metadata/). 3. Armin Ronacher: [Constraints are Good: Python's Metadata Dilemma](https://lucumr.pocoo.org/2024/11/26/python-packaging-metadata/). 4. Barry Warsaw: [`hatch version` should be able to handle static version numbers](https://github.com/pypa/hatch/issues/1419). 5. Henry Schreiner: [Support PEP 621 version?](https://github.com/callowayproject/bump-my-version/issues/66) 6. Alex Gaynor: [Scaling Software Development](https://alexgaynor.net/2020/feb/18/scaling-software-development/). "As the scale of a codebase increases, any properties of it which are not programmatically enforced will tend to regress." &lt;/pre&gt; tag:gitlist.org,2012:commit/9b5805eb652e97ee4b63f6afbcf9563aba3311f0 Merge topic branch 'notes-handling' into master 2025-02-07T19:19:19+01:00 Marco Ricci software@the13thletter.info <pre>* t/notes-handling: Document recent changes to notes handling in the changelog Optionally support printing vault service notes before the passphrase Document the modern editor interface Reintroduce a "modern" editor interface à la git-commit or git-rebase Warn the user when `derivepassphrase vault --notes` is ineffective Use a vault(1)-compatible naive notes editing system Use hypothesis for notes handling tests Adapt notes printing test to arbitrary notes Clean up notes testing functions Use a better test for no-op editing notes Partially align notes printing and editing behavior with vault(1) Assert that notes should be printed (via xfailing test) GitHub: Closes #18, closes #19. &lt;/pre&gt; tag:gitlist.org,2012:commit/f81c616548e53fe088636bf9eb6fbaf7873c8c25 Document recent changes to notes handling in the changelog 2025-02-07T19:09:54+01:00 Marco Ricci software@the13thletter.info <pre>&lt;/pre&gt; tag:gitlist.org,2012:commit/b05668d5614d47158c8f8f0ef5145775d5ee40d8 Merge topic branch 'readable-json-dump' into master 2025-02-07T18:17:59+01:00 Marco Ricci software@the13thletter.info <pre>* t/readable-json-dump: Document the change in JSON formatting GitHub: Closes #20. &lt;/pre&gt; tag:gitlist.org,2012:commit/9c8e7ecd02fd53473ea6d09504cd07555e417fb6 Document the change in JSON formatting 2025-02-07T18:00:55+01:00 Marco Ricci software@the13thletter.info <pre>Although, having since also written up the motivation for this change in the issue tracker, I'm somewhat less convinced of how sensible this change is (in parts) in the long run. &lt;/pre&gt; tag:gitlist.org,2012:commit/c6a84c41a8c866b8f0467b5772a62515e7fcf3b9 Optionally support printing vault service notes before the passphrase 2025-02-07T16:01:14+01:00 Marco Ricci software@the13thletter.info <pre>When deriving a passphrase, if the service has any notes, vault(1) prints the notes after the passphrase. However, akin to source code comments before the code in question, service notes may actually be better placed above the derived passphrase instead, for some types of notes. Support such placement via a new command-line option `--print-notes-before`; the default, vault(1)-compatible behavior can be explicitly selected via `--print-notes-after`. &lt;/pre&gt; tag:gitlist.org,2012:commit/18e1bf52dbb2b0ea4e3c1eeb9c400429b1bbe756 Document the modern editor interface 2025-02-07T15:19:22+01:00 Marco Ricci software@the13thletter.info <pre>Update the manpages to include the corrected and extended handling of the `--notes` config option. That is, document the `--modern-editor-interface` and `--vault-legacy-editor-interface` options, and the new warning messages about `--notes` requiring `--config` and that a backup copy of the notes have been made. Some minor adjustments to the vault(1) legacy editor interface warning messages were made to ease inclusion in the manpage while making the intent clear. Additionally, derivepassphrase with the legacy interface correctly fills in the old notes contents if any, instead of unconditionally filling in the placeholder text. &lt;/pre&gt;