-
Notifications
You must be signed in to change notification settings - Fork 122
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
docs: add example Juju version markers #1311
docs: add example Juju version markers #1311
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm very happy to see this, our users ought to be delighted.
If we wanted to be pedantic, I'd go for this syntax:
.. versionadded:: 2.15
Requires Juju 3.5
Listing both this library version and Juju version.
We did previously have some (definitely not complete, and generally using text, not the directive) markers of when functionality was added in ops. We removed that and adjusted the CHANGES file just a few months ago. I do agree that it's both providing the most information and looks nice: The main reason the ops version markers were removed (rather than extended) was to avoid people looking through to find a specific version of ops to use rather than just always using the latest version. I think a secondary one was that over time this does get quite noisy because almost everything ends up with a little tag. We also considered versioned API docs but decided that it would be best to only do that for major versions (ie. we should have both 2.{latest} and 3.{latest} versions if/when there's an ops 3). If we do use this format, then it becomes less consistent to not have the markers on ops features that aren't also new Juju features (so almost everything ends up with a version label). |
docs build failed, it seems? |
|
Yeah, that's this:
|
…as available in 2.9, the current oldest supported version.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Love it, thanks! A few comments, mainly wondering if we should remove the notes about Juju 4.0, which won't be shipped for many months yet.
… earlier than that. Remove the tag - there's already a suggestion to go read the docs for details on the differences.
@@ -334,3 +330,85 @@ def _compute_navigation_tree(context): | |||
('py:class', 'ops.testing.CharmType'), | |||
('py:obj', 'ops.testing.CharmType'), | |||
] | |||
|
|||
|
|||
# This is very strongly based on |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess this approach is recommended at https://github.com/picnixz/sphinx/blob/8c6d234e961eaf945567755863d377fa27dc6f22/doc/development/tutorials/examples/todo.py#L41
Adds the version features were added in Juju to the API reference docs (other than ops.testing).
No version tags are added for anything older than 3.0 - meaning that if there's no version tag, then it was available in the oldest supported Juju version.
Unfortunately, the built-in Sphinx
versionadded
directive does not support customising the text, so while otherwise suitable, it results in "Added in version 3.0" (seems like it's referring to ops 3.0) or "Added in version Juju 3.0". Instead, a new pair of custom directives are added,jujuversion
andjujuremoved
. These are very heavily based onversionadded
andversionremoved
but have custom text (and we could customise them further, e.g. linking to revision notes) if we wanted to in future). In order to avoid having to also add custom CSS, they use the same classes as theversionadded
andversionremoved
directives.The features being removed in Juju 4.0 also have
jujuremoved
tags added.I also ran
ruff format
over custom_conf.py, which is why there are some unrelated formatting changes.Fixes #1305