-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
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
Increase default python version to 3.8 or higher #9623
Comments
Thanks for opening this issue. By default, we are using I strongly recommend you to use
Can you expand more on this? I'm not sure to understand why you cannot specify this in the config file. |
Thank you for your detailed answer.
Where can it be set? You probably mean in
Our project As far as I understand, if I want to introduce the I would be very happy to have suggestions on moving the build to python 3.8, 3.9, or 3.10. |
If I'm understanding correctly, you could use https://github.com/readthedocs/sphinx-multiproject for your use case. I'm not 100% sure it fits, tho. We use it for our own repository and it has been working fine. |
Related to this topic, as Sphinx is deprecating Python 3.7 in version 6, and we are installing "latest Sphinx by default" we should do something about it before start breaking the builds. Maybe this is a good moment to start talking about deprecating I'm trying to think about making the less breaking change possibles instead of multiple breaking iterations. I think it would be good to talk about this and make a plan. cc @ericholscher |
I think pip should be able to select the latest compatible version (as long as we don't explicitly request the incompatible version) |
Thank you @humitos for pointing out to |
That will depend on how you set up them. You have to import the same repository multiple times; one per documentation project. Then you can configure them as subprojects on Read the Docs or not. That's up to you. |
This is true. However, by keeping |
I also have this issue. I have several projects that build on Python 3.9+ only, although most still support Python 3.7+. I'd like to avoid the churn across each project of (a) pinning to a later version of Python now and (b) at some point in the future (probably when things start breaking again) pin to an even later version of Python. The current status quo is for readthedocs to have an arbitrary version of Python with questionable stability. That is, Python 3.7 was a recent release at one point but is a stale version today. Better would be for RTD to reset the expectation. Instead of letting the "current" version of Python become stale until it's unusable and then bump it several versions, regularly and predictably update the Python version. I'd recommend to update to the latest stable Python at 3-6 months after its release. With this expectation in place, projects could still pin to a specific, older version of Python if their project requires, but the default behavior of RTD would be to support stable, recent versions of Python. This design would allow me (and I'm guessing hundreds of other users) to rely on the default Python version in RTD and avoid having to declare a specific version at all. RTD should aim for the default settings to work best for new projects created today, no to provide support first for old projects. |
A new project with |
You can use: build:
tools:
python: "3" which will point to the latest stable release: readthedocs.org/readthedocs/settings/base.py Lines 609 to 610 in 2ba8fb2
|
Yeah, |
I'd like to point out that while this recommendation is currently the best recommendation, it will eventually become stale too. It would be nice if:
That way, users that specify nothing will be at risk of things changing, but they need not repeatedly monitor/chase the latest config to stay up to date, and they wouldn't need to include many lines of boilerplate across each project. Projects that want stability or need to retain compatibility can pin to older versions, but the default isn't to pin to some arbitrary revision. This approach would match with the behavior that tools like |
Related: #8861 |
This is not going to be supported anymore. Read the Docs build system will start requiring a
Now, we support multiple configuration files on the same repository. Read the documentation for this new feature at https://docs.readthedocs.io/en/stable/guides/setup/monorepo.html I think this issue can be closed now since there is not going to be "default Python version" anymore. However, feel free to comment and re-open if you consider. |
@humitos, thank you for making multiple configuration files available by default. We currently use sphinx-multiproject, but might switch to default implementation. |
@PrimozGodec I would appreciate your feedback on that feature once you try it 🙏🏼 |
Details
It is not an issue with a specific project but a change request.
When the project does include the
.readthedocs.yaml
file, documentation is built in Python 3.7 by default. Since many projects already dropped support for Python 3.7 (NumPy, pandas, ...), I think it is time to set the default to 3.8 or higher. Recently I tried to limit the panda's version to >=1.4, and thus documentation build failed since it was built with python 3.7.You would ask why I do not specify the Python version in
.readthecos.ymal
. Since my documentation build has multiple subprojects and.readthedocs.yaml
does not support that, I cannot.Expected Result
I wish that readthecos would build documentation on Python 3.8 or 3.9 by default.
The text was updated successfully, but these errors were encountered: