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

Figure out how to incorporate Fedora's (and openSUSE's) lib64 patches on Python 3.7/3.8 #110

Closed
hroncok opened this issue Jan 21, 2022 · 7 comments

Comments

@hroncok
Copy link
Contributor

hroncok commented Jan 21, 2022

See pylint-dev/pylint#5704 and pypa/setuptools#2896 (comment)

Apparently, I have completely forgotten that on Python < 3.9, we do patch distutils in one more way: We replace /usr/lib with /usr/lib64 on 64bit architectures.

See our patches:

I am opening this issue to track this problem. I don't expect you to fix it, I plan to have a look, but not today.

@hroncok
Copy link
Contributor Author

hroncok commented Jan 24, 2022

Looking at the current implementation of pypa/distutils, it seems we only need to set sys.platlibdir to "lib64" and it should work as expected :)

hroncok added a commit to hroncok/cpython that referenced this issue Jan 24, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
@hroncok
Copy link
Contributor Author

hroncok commented Jan 24, 2022

Work in progress PR for python3.8: https://src.fedoraproject.org/rpms/python3.8/pull-request/54

@jaraco
Copy link
Member

jaraco commented Jan 24, 2022

I'll confess, I'm slightly uneasy with altering a value in sys, but when I look at the schemes, {platlibdir} resolves directly from sys.platlibdir, so I agree with the conclusion. I wonder what effect changing that value will have on other environments, such as venv or virtualenv.

@hroncok
Copy link
Contributor Author

hroncok commented Jan 24, 2022

Yeah, my idea is to set it, and try to see what it breaks.

hroncok added a commit to hroncok/cpython that referenced this issue Feb 3, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
@hroncok
Copy link
Contributor Author

hroncok commented Feb 17, 2022

Nothing broke for me, @encukou or @jnsnow. Let's share this with the crowds. Fedora updates:

The updates will soon be installable from the updates-testing repo.

bonzini pushed a commit to qemu/qemu that referenced this issue Feb 24, 2022
Setuptools v60 and later include a bundled version of distutils, a
deprecated standard library scheduled for removal in future versions of
Python. Setuptools v60 is only possible to install for Python 3.7 and later.

Python has a distutils.sysconfig.get_python_lib() function that returns
'/usr/lib/pythonX.Y' on posix systems. RPM-based systems actually use
'/usr/lib64/pythonX.Y' instead, so Fedora patches stdlib distutils for
Python 3.7 and Python 3.8 to return the correct value.

Python 3.9 and later introduce a sys.platlibdir property, which returns
the correct value on RPM-based systems.

The change to a distutils package not provided by Fedora on Python 3.7
and 3.8 causes a regression in distutils.sysconfig.get_python_lib() that
ultimately causes false positives to be emitted by pylint, because it
can no longer find the system source libraries.

Many Python tools are fairly aggressive about updating setuptools
packages, and so even though this package is a fair bit newer than
Python 3.7/3.8, it's not entirely unreasonable for a given user to have
such a modern package with a fairly old Python interpreter.

Updates to Python 3.7 and Python 3.8 are being produced for Fedora which
will fix the problem on up-to-date systems. Until then, we can force the
loading of platform-provided distutils when running the pylint
test. This is the least-invasive yet most comprehensive fix.

References:
 pypa/setuptools#2896
 pylint-dev/pylint#5704
 pypa/distutils#110

Signed-off-by: John Snow <[email protected]>
Message-id: [email protected]
Signed-off-by: John Snow <[email protected]>
@jaraco
Copy link
Member

jaraco commented Feb 26, 2022

That's great. Does that mean this issue is done? Optimistically closing, but feel free to report back if not.

@jaraco jaraco closed this as completed Feb 26, 2022
@hroncok
Copy link
Contributor Author

hroncok commented Feb 26, 2022

Yes, it is hopefully resolved for Fedora at least.

liweiwei90 pushed a commit to plctlab/plct-qemu that referenced this issue Feb 27, 2022
Setuptools v60 and later include a bundled version of distutils, a
deprecated standard library scheduled for removal in future versions of
Python. Setuptools v60 is only possible to install for Python 3.7 and later.

Python has a distutils.sysconfig.get_python_lib() function that returns
'/usr/lib/pythonX.Y' on posix systems. RPM-based systems actually use
'/usr/lib64/pythonX.Y' instead, so Fedora patches stdlib distutils for
Python 3.7 and Python 3.8 to return the correct value.

Python 3.9 and later introduce a sys.platlibdir property, which returns
the correct value on RPM-based systems.

The change to a distutils package not provided by Fedora on Python 3.7
and 3.8 causes a regression in distutils.sysconfig.get_python_lib() that
ultimately causes false positives to be emitted by pylint, because it
can no longer find the system source libraries.

Many Python tools are fairly aggressive about updating setuptools
packages, and so even though this package is a fair bit newer than
Python 3.7/3.8, it's not entirely unreasonable for a given user to have
such a modern package with a fairly old Python interpreter.

Updates to Python 3.7 and Python 3.8 are being produced for Fedora which
will fix the problem on up-to-date systems. Until then, we can force the
loading of platform-provided distutils when running the pylint
test. This is the least-invasive yet most comprehensive fix.

References:
 pypa/setuptools#2896
 pylint-dev/pylint#5704
 pypa/distutils#110

Signed-off-by: John Snow <[email protected]>
Message-id: [email protected]
Signed-off-by: John Snow <[email protected]>
newfriday pushed a commit to newfriday/qemu that referenced this issue Feb 28, 2022
Setuptools v60 and later include a bundled version of distutils, a
deprecated standard library scheduled for removal in future versions of
Python. Setuptools v60 is only possible to install for Python 3.7 and later.

Python has a distutils.sysconfig.get_python_lib() function that returns
'/usr/lib/pythonX.Y' on posix systems. RPM-based systems actually use
'/usr/lib64/pythonX.Y' instead, so Fedora patches stdlib distutils for
Python 3.7 and Python 3.8 to return the correct value.

Python 3.9 and later introduce a sys.platlibdir property, which returns
the correct value on RPM-based systems.

The change to a distutils package not provided by Fedora on Python 3.7
and 3.8 causes a regression in distutils.sysconfig.get_python_lib() that
ultimately causes false positives to be emitted by pylint, because it
can no longer find the system source libraries.

Many Python tools are fairly aggressive about updating setuptools
packages, and so even though this package is a fair bit newer than
Python 3.7/3.8, it's not entirely unreasonable for a given user to have
such a modern package with a fairly old Python interpreter.

Updates to Python 3.7 and Python 3.8 are being produced for Fedora which
will fix the problem on up-to-date systems. Until then, we can force the
loading of platform-provided distutils when running the pylint
test. This is the least-invasive yet most comprehensive fix.

References:
 pypa/setuptools#2896
 pylint-dev/pylint#5704
 pypa/distutils#110

Signed-off-by: John Snow <[email protected]>
Message-id: [email protected]
Signed-off-by: John Snow <[email protected]>
vlsunil pushed a commit to ventana-micro-systems/RISC-V-qemu that referenced this issue Mar 4, 2022
Setuptools v60 and later include a bundled version of distutils, a
deprecated standard library scheduled for removal in future versions of
Python. Setuptools v60 is only possible to install for Python 3.7 and later.

Python has a distutils.sysconfig.get_python_lib() function that returns
'/usr/lib/pythonX.Y' on posix systems. RPM-based systems actually use
'/usr/lib64/pythonX.Y' instead, so Fedora patches stdlib distutils for
Python 3.7 and Python 3.8 to return the correct value.

Python 3.9 and later introduce a sys.platlibdir property, which returns
the correct value on RPM-based systems.

The change to a distutils package not provided by Fedora on Python 3.7
and 3.8 causes a regression in distutils.sysconfig.get_python_lib() that
ultimately causes false positives to be emitted by pylint, because it
can no longer find the system source libraries.

Many Python tools are fairly aggressive about updating setuptools
packages, and so even though this package is a fair bit newer than
Python 3.7/3.8, it's not entirely unreasonable for a given user to have
such a modern package with a fairly old Python interpreter.

Updates to Python 3.7 and Python 3.8 are being produced for Fedora which
will fix the problem on up-to-date systems. Until then, we can force the
loading of platform-provided distutils when running the pylint
test. This is the least-invasive yet most comprehensive fix.

References:
 pypa/setuptools#2896
 pylint-dev/pylint#5704
 pypa/distutils#110

Signed-off-by: John Snow <[email protected]>
Message-id: [email protected]
Signed-off-by: John Snow <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Mar 17, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Mar 17, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hroncok added a commit to fedora-python/cpython that referenced this issue Sep 7, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hroncok added a commit to fedora-python/cpython that referenced this issue Sep 7, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hroncok added a commit to fedora-python/cpython that referenced this issue Oct 12, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hroncok added a commit to fedora-python/cpython that referenced this issue Oct 12, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Dec 7, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Dec 7, 2022
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Jun 8, 2023
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Jun 8, 2023
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Aug 28, 2023
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Mar 20, 2024
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
hrnciar pushed a commit to fedora-python/cpython that referenced this issue Sep 9, 2024
… /usr/lib/

Only used when "%{_lib}" == "lib64".

Also sets sys.platlibdir to "lib64" for pypa/distutils#110

Co-authored-by: David Malcolm <[email protected]>
Co-authored-by: Thomas Spura <[email protected]>
Co-authored-by: Slavek Kabrda <[email protected]>
Co-authored-by: Matej Stuchlik <[email protected]>
Co-authored-by: Tomas Orsava <[email protected]>
Co-authored-by: Charalampos Stratakis <[email protected]>
Co-authored-by: Petr Viktorin <[email protected]>
Co-authored-by: Miro Hrončok <[email protected]>
Co-authored-by: Iryna Shcherbina <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants