__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
from __future__ import annotations
from dataclasses import dataclass, field
from pip._vendor.packaging.utils import NormalizedName, canonicalize_name
from pip._internal.exceptions import CommandError
@dataclass(slots=True)
class ReleaseControl:
"""Helper for managing which release types can be installed."""
all_releases: set[str] = field(default_factory=set)
only_final: set[str] = field(default_factory=set)
_order: list[tuple[str, str]] = field(
init=False, default_factory=list, compare=False, repr=False
)
def handle_mutual_excludes(
self, value: str, target: set[str], other: set[str], attr_name: str
) -> None:
"""Parse and apply release control option value.
Processes comma-separated package names or special values `:all:` and `:none:`.
When adding packages to target, they're removed from other to maintain mutual
exclusivity between all_releases and only_final. All operations are tracked in
order so that the original command-line argument sequence can be reconstructed
when passing options to build subprocesses.
"""
if value.startswith("-"):
raise CommandError(
"--all-releases / --only-final option requires 1 argument."
)
new = value.split(",")
while ":all:" in new:
other.clear()
target.clear()
target.add(":all:")
# Track :all: in order
self._order.append((attr_name, ":all:"))
del new[: new.index(":all:") + 1]
# Without a none, we want to discard everything as :all: covers it
if ":none:" not in new:
return
for name in new:
if name == ":none:":
target.clear()
# Track :none: in order
self._order.append((attr_name, ":none:"))
continue
name = canonicalize_name(name)
other.discard(name)
target.add(name)
# Track package-specific setting in order
self._order.append((attr_name, name))
def get_ordered_args(self) -> list[tuple[str, str]]:
"""
Get ordered list of (flag_name, value) tuples for reconstructing CLI args.
Returns:
List of tuples where each tuple is (attribute_name, value).
The attribute_name is either 'all_releases' or 'only_final'.
Example:
[("all_releases", ":all:"), ("only_final", "simple")]
would be reconstructed as:
["--all-releases", ":all:", "--only-final", "simple"]
"""
return self._order[:]
def allows_prereleases(self, canonical_name: NormalizedName) -> bool | None:
"""
Determine if pre-releases are allowed for a package.
Returns:
True: Pre-releases are allowed (package in all_releases)
False: Only final releases allowed (package in only_final)
None: No specific setting, use default behavior
"""
if canonical_name in self.all_releases:
return True
elif canonical_name in self.only_final:
return False
elif ":all:" in self.all_releases:
return True
elif ":all:" in self.only_final:
return False
return None
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| __init__.py | File | 62 B | 0644 |
|
| candidate.py | File | 720 B | 0644 |
|
| direct_url.py | File | 944 B | 0644 |
|
| format_control.py | File | 2.41 KB | 0644 |
|
| index.py | File | 1.01 KB | 0644 |
|
| installation_report.py | File | 2.78 KB | 0644 |
|
| link.py | File | 21.48 KB | 0644 |
|
| release_control.py | File | 3.29 KB | 0644 |
|
| scheme.py | File | 558 B | 0644 |
|
| search_scope.py | File | 4.36 KB | 0644 |
|
| selection_prefs.py | File | 1.47 KB | 0644 |
|
| target_python.py | File | 4.14 KB | 0644 |
|
| wheel.py | File | 2.85 KB | 0644 |
|