mirror of
https://github.com/astral-sh/uv.git
synced 2025-09-11 13:06:21 +00:00
Omit trailing zeros on Python requirements inferred from versions (#9952)
In a message like ``` ❯ echo "numpy>2" | uv pip compile -p 3.8 - × No solution found when resolving dependencies: ╰─▶ Because the requested Python version (>=3.8.0) does not satisfy Python>=3.10 and the requested Python version (>=3.8.0) does not satisfy Python>=3.9,<3.10, we can conclude that Python>=3.9 is incompatible. And because numpy>=2.0.1,<=2.0.2 depends on Python>=3.9 and only the following versions of numpy are available: numpy<=2.0.2 ``` I'm surprised that `-p 3.8` leads to expressions like `>=3.8.0` (I understand it, of course, but it's not intuitive) and then all the _other_ Python versions in the message omit the trailing zero. This updates the `PythonRequirement` parsing to drop the trailing zeros. It's easier to do there because the version is not yet abstracted.
This commit is contained in:
parent
2288905d46
commit
a78e7468a7
4 changed files with 50 additions and 12 deletions
|
@ -24,8 +24,15 @@ impl PythonRequirement {
|
|||
/// [`PythonVersion`].
|
||||
pub fn from_python_version(interpreter: &Interpreter, python_version: &PythonVersion) -> Self {
|
||||
let exact = interpreter.python_full_version().version.clone();
|
||||
let installed = interpreter.python_full_version().version.only_release();
|
||||
let target = python_version.python_full_version().only_release();
|
||||
let installed = interpreter
|
||||
.python_full_version()
|
||||
.version
|
||||
.only_release()
|
||||
.without_trailing_zeros();
|
||||
let target = python_version
|
||||
.python_full_version()
|
||||
.only_release()
|
||||
.without_trailing_zeros();
|
||||
Self {
|
||||
exact,
|
||||
installed: RequiresPython::greater_than_equal_version(&installed),
|
||||
|
@ -45,8 +52,16 @@ impl PythonRequirement {
|
|||
|
||||
/// Create a [`PythonRequirement`] to resolve against an [`Interpreter`].
|
||||
pub fn from_interpreter(interpreter: &Interpreter) -> Self {
|
||||
let exact = interpreter.python_full_version().version.clone();
|
||||
let installed = interpreter.python_full_version().version.only_release();
|
||||
let exact = interpreter
|
||||
.python_full_version()
|
||||
.version
|
||||
.clone()
|
||||
.without_trailing_zeros();
|
||||
let installed = interpreter
|
||||
.python_full_version()
|
||||
.version
|
||||
.only_release()
|
||||
.without_trailing_zeros();
|
||||
Self {
|
||||
exact,
|
||||
installed: RequiresPython::greater_than_equal_version(&installed),
|
||||
|
@ -65,8 +80,16 @@ impl PythonRequirement {
|
|||
marker_env: &MarkerEnvironment,
|
||||
requires_python: RequiresPython,
|
||||
) -> Self {
|
||||
let exact = marker_env.python_full_version().version.clone();
|
||||
let installed = marker_env.python_full_version().version.only_release();
|
||||
let exact = marker_env
|
||||
.python_full_version()
|
||||
.version
|
||||
.clone()
|
||||
.without_trailing_zeros();
|
||||
let installed = marker_env
|
||||
.python_full_version()
|
||||
.version
|
||||
.only_release()
|
||||
.without_trailing_zeros();
|
||||
Self {
|
||||
exact,
|
||||
installed: RequiresPython::greater_than_equal_version(&installed),
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue