-
Notifications
You must be signed in to change notification settings - Fork 71
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
Support Homebrew patches #76
Comments
The preferred and expected long-term supported way for any Python environment to customize the install behavior is to provide custom install schemes as solicited here, and this technique is supported on all supported Pythons (3.6+). So if homebrew can patch/extend the install schemes in sysconfig, that would be the best solution for old and new Pythons. If it's going to be more complicated than that, capture any shortcomings here and we can discuss. |
The current mechanism doesn't allow custom install schemes - it requires replacing default install schemes since the selection of schemes is hardcoded: distutils/distutils/command/install.py Line 488 in 92082ee
The mentioned
To us, this appears to be the direction the future of sysconfig is taking. For example, while not final yet, the proposal at python/cpython#25718 would explicitly not allow default install schemes to be overridden. Pip are already onboard and are using it: https://github.com/pypa/pip/blob/bbc7021cde307676a71e7a89e88a6fc20b8e2c26/src/pip/_internal/locations/_sysconfig.py#L70-L71 |
It seems distutils needs to support that get preferred scheme, which presumably could be honored even on old Pythons. I can work on an implementation this weekend. If Homebrew can patch sysconfig to extend the schemes and provide a get preferred scheme function, would that provide foreword and backward compatibility? |
Yes, it seems likely we will backport |
From Homebrew's side we completely override the prefix (
base
var). This is because under our system, the Python install directory and the install directory that should be used for user-installed packages should be separate (or user packages are lost on upgrades).We currently do this via
distutils.cfg
planted in the standard library distutils which will of course not work anymore.Going forward we're looking at the system that will hopefully be introduced in Python 3.11 to add additional install schemes to sysconfig.py:
Notably, the idea is schemes should be added rather than replaced. This is why
sysconfig.get_preferred_scheme(key)
was introduced in Python 3.10. This is also important when dynamic logic may be required. Ideally I reckon distutils should use this when selecting a scheme.While the above will cover Python 3.10+, there'll still be a question about what we do for <= 3.9.
sysconfig._prefix_addition
is almost what we want, though I don't know if calculating a relative path and going up levels (..
) is a good idea.Originally posted by @Bo98 in pypa/setuptools#2896 (comment)
The text was updated successfully, but these errors were encountered: