-
Notifications
You must be signed in to change notification settings - Fork 3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add separate conf.py
for the different docs types
#12900
base: main
Are you sure you want to change the base?
Add separate conf.py
for the different docs types
#12900
Conversation
docs/html/conf.py
Outdated
copyright = copyright | ||
project = project | ||
version = version | ||
release = release |
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.
Alternatively: add these to __all__
in docs/common_conf.py
and import *
from there, but I preferred being explicit
docs/html/conf.py
Outdated
docs_dir = os.path.dirname(os.path.dirname(__file__)) | ||
sys.path.insert(0, docs_dir) | ||
|
||
from common_conf import copyright, project, release, version # noqa: E402 |
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.
You can use __all__
to signify the values are re-exported.
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.
You can use
__all__
to signify the values are re-exported.
Are you suggesting add them to __all__
in this file, instead of the assignments below? Or add these to __all__
in common_conf
and just import *
here?
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.
Why not simply ignore the Ruff rule?
from common_conf import copyright, project, release, version # noqa: E402 | |
from common_conf import copyright, project, release, version # noqa: E402, F401 |
Are you suggesting add them to
__all__
in this file, instead of the assignments below?
Names declared in __all__
become part of the module's interface and thus Ruff won't delete unused imports that populate those names. AFAIU, this is what @uranusjr was suggesting. I think this is even less obvious to a reader.
Alternatively we could do from common_config import version as version
for each configuration option to declare them as re-exports.
from common_conf import copyright as copyright # noqa: E402
from common_conf import project as project # noqa: E402
from common_conf import release as release # noqa: E402
from common_conf import version as version # noqa: E402
But this seems verbose IMO.
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.
Why not simply ignore the Ruff rule?
No reason not to, see c04ff52
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.
You need to install the HTML dependencies in the docs-live nox session, otherwise it will break.
I don't like excluding the configuration files from mypy, but I also can't think of anything better...
docs/html/conf.py
Outdated
docs_dir = os.path.dirname(os.path.dirname(__file__)) | ||
sys.path.insert(0, docs_dir) | ||
|
||
from common_conf import copyright, project, release, version # noqa: E402 |
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.
Why not simply ignore the Ruff rule?
from common_conf import copyright, project, release, version # noqa: E402 | |
from common_conf import copyright, project, release, version # noqa: E402, F401 |
Are you suggesting add them to
__all__
in this file, instead of the assignments below?
Names declared in __all__
become part of the module's interface and thus Ruff won't delete unused imports that populate those names. AFAIU, this is what @uranusjr was suggesting. I think this is even less obvious to a reader.
Alternatively we could do from common_config import version as version
for each configuration option to declare them as re-exports.
from common_conf import copyright as copyright # noqa: E402
from common_conf import project as project # noqa: E402
from common_conf import release as release # noqa: E402
from common_conf import version as version # noqa: E402
But this seems verbose IMO.
Thanks, I completely missed that one, fixed a08f157 |
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.
Actually, it looks like adding a __init__.py
to only the man
directory is a valid workaround.
ah, good idea, trying this: 20cbe13 |
.pre-commit-config.yaml
Outdated
@@ -31,6 +31,7 @@ repos: | |||
rev: v1.10.0 | |||
hooks: | |||
- id: mypy | |||
# exclude due to errors from duplicate conf.py under docs |
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.
# exclude due to errors from duplicate conf.py under docs |
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.
🤦 dab08d1
e599386
to
ac9e441
Compare
Sorry I have not had time to review nor test this. Postponing to 25.0. |
The goal here is to allow building the `man` pages without all the additional requirements needed for the `html` docs, so that e.g. developers packaging `pip` can also package the man pages with minimal dependencies. Specifically, this should have no impact on the build output of `nox -s docs`, but does allow: sphinx-build \ -c docs/man \ -d docs/build/doctrees/man \ -b man \ docs/man \ docs/build/man to run with only `sphinx` dependency (in addition to `pip`s dependencies). While doing this I also used long-opts to `sphinx-build` in the `noxfile` since I found this more understandable at a glance An `__init__.py` was added under `docs/man` to satisfy `mypy`. If this wasn't added it would error: docs/man/conf.py: error: Duplicate module named "conf" (also at "docs/html/conf.py") docs/man/conf.py: note: See https://mypy.readthedocs.io/en/stable/running_mypy.html#mapping-file-paths-to-modules for more info docs/man/conf.py: note: Common resolutions include: a) using `--exclude` to avoid checking one of them, b) adding `__init__.py` somewhere, c) using `--explicit-package-bases` or adjusting MYPYPATH Found 1 error in 1 file (errors prevented further checking) Adding an extra `__init__.py` under `docs/html` would result in a separate error since then the `html` module is local (and not the stdlib one) resulting in a error from `sphinx-build`: Extension error: Could not import extension sphinx.builders.linkcheck (exception: No module named 'html.parser') Issue: pypa#12881
ac9e441
to
326638d
Compare
My 2 cents: I'd prefer that we add a docs/man/requirements.txt file with the smaller subset of requirements and leave the docs/requirements.txt file as-is. The man pages are the special case for pip's documentation that are realistically only used by redistributors (we don't publish the man pages anywhere). |
I'd prefer we exclude this file from type checking entirely, rather than having a stray file in a directory that isn't meant to be imported. |
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.
FWIW, I think this could remain the same module governed by Sphinx tags. This would add a way of triggering one path or the other via -t
w/o having to maintain an additional layout of files in the repo.
Here's an example of having a few conditionals, for example: https://github.com/ansible/awx-plugins/blob/c8cff62/docs/conf.py#L46-L51.
Some conditionals could also be put inside a setup()
function or extensions (declaring deps on other extensions conditionally; example: https://github.com/ansible/awx-plugins/blob/c8cff62/docs/_ext/spelling_stub_ext.py#L52).
Such a solution would be more native to Sphinx as a platform and would be less invasive. And I'm speaking from experience, having to go through merging a bunch of slightly different conf.py
's in a much larger docs project in the past: ansible/ansible-documentation#431.
I haven't looked at Sphinx tags closely, but @matthewhughes934 if you have time, I'd be interested in what this patch would look like using tags. I'd file a separate PR so we can compare easily. Thank you! They seem neat. |
The goal is to allow a build of just the `man` pages with a minimal set of dependencies, like: sphinx-build \ --tag man \ -c docs/html \ -d docs/build/doctrees/man \ -b man \ docs/man \ docs/build/man This is for the sake of people distributing `pip` who want to build the man pages (but not the HTML ones) along side the application. This is an alternative to the approach proposed in[1] and similarly addresses[2] Link: pypa#12900 [1] Link: pypa#12881 [2]
After a quick play around: #13168 👍 thanks @webknjaz for sharing |
The goal here is to allow building the
man
pages without all theadditional requirements needed for the
html
docs, so that e.g.developers packaging
pip
can also package the man pages with minimaldependencies.
Specifically, this should have no impact on the build output of
nox -s docs
, but does allow:to run with only
sphinx
dependency (in addition topip
sdependencies). While doing this I also used long-opts to
sphinx-build
in the
noxfile
since I found this more understandable at a glanceAn
__init__.py
was added underdocs/man
to satisfymypy
. If thiswasn't added it would error:
Adding an extra
__init__.py
underdocs/html
would result in aseparate error since then the
html
module is local (and not the stdlibone) resulting in a error from
sphinx-build
:Issue: #12881