Skip to content
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

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

matthewhughes934
Copy link
Contributor

@matthewhughes934 matthewhughes934 commented Aug 6, 2024

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 pips
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: #12881

Comment on lines 31 to 34
copyright = copyright
project = project
version = version
release = release
Copy link
Contributor Author

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_dir = os.path.dirname(os.path.dirname(__file__))
sys.path.insert(0, docs_dir)

from common_conf import copyright, project, release, version # noqa: E402
Copy link
Member

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.

Copy link
Contributor Author

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?

Copy link
Member

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?

Suggested change
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.

Copy link
Contributor Author

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

Copy link
Member

@ichard26 ichard26 left a 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_dir = os.path.dirname(os.path.dirname(__file__))
sys.path.insert(0, docs_dir)

from common_conf import copyright, project, release, version # noqa: E402
Copy link
Member

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?

Suggested change
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.

@matthewhughes934
Copy link
Contributor Author

You need to install the HTML dependencies in the docs-live nox session, otherwise it will break.

Thanks, I completely missed that one, fixed a08f157

@matthewhughes934 matthewhughes934 marked this pull request as ready for review August 10, 2024 11:01
Copy link
Member

@ichard26 ichard26 left a 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.

@matthewhughes934
Copy link
Contributor Author

Actually, it looks like adding a __init__.py to only the man directory is a valid workaround.

ah, good idea, trying this: 20cbe13

@@ -31,6 +31,7 @@ repos:
rev: v1.10.0
hooks:
- id: mypy
# exclude due to errors from duplicate conf.py under docs
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
# exclude due to errors from duplicate conf.py under docs

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🤦 dab08d1

@matthewhughes934 matthewhughes934 force-pushed the split-up-docs-building branch 2 times, most recently from e599386 to ac9e441 Compare August 15, 2024 19:06
@ichard26 ichard26 added this to the 24.3 milestone Aug 16, 2024
@ichard26 ichard26 requested a review from pradyunsg August 23, 2024 04:18
@sbidoul
Copy link
Member

sbidoul commented Oct 26, 2024

Sorry I have not had time to review nor test this. Postponing to 25.0.

@sbidoul sbidoul modified the milestones: 24.3, 25.0 Oct 26, 2024
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
@ichard26 ichard26 added the type: docs Documentation related label Dec 26, 2024
@pradyunsg
Copy link
Member

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).

@pradyunsg
Copy link
Member

pradyunsg commented Jan 13, 2025

An init.py was added under docs/man to satisfy mypy

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.

Copy link
Member

@webknjaz webknjaz left a 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.

@ichard26
Copy link
Member

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.

matthewhughes934 added a commit to matthewhughes934/pip that referenced this pull request Jan 15, 2025
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]
@matthewhughes934
Copy link
Contributor Author

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.

After a quick play around: #13168

👍 thanks @webknjaz for sharing

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants