mirror of
				https://github.com/astral-sh/uv.git
				synced 2025-11-03 21:23:54 +00:00 
			
		
		
		
	## Summary This PR deprecates the `--isolated` flag. The treatment varies across the APIs: - For non-preview APIs, we warn but treat it as equivalent to `--no-config`. - For preview APIs, we warn and ignore it, with two exceptions... - For `tool run` and `run` specifically, we don't even warn, because we can't differentiate the command-specific `--isolated` from the global `--isolated`.
		
			
				
	
	
		
			128 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			128 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable file
		
	
	
	
	
# /// script
 | 
						|
# requires-python = ">=3.12"
 | 
						|
# dependencies = [
 | 
						|
#   "chevron-blue < 1",
 | 
						|
# ]
 | 
						|
# ///
 | 
						|
"""
 | 
						|
Generate static Rust code from Python version download metadata.
 | 
						|
 | 
						|
Generates the `downloads.inc` file from the `downloads.inc.mustache` template.
 | 
						|
 | 
						|
Usage:
 | 
						|
 | 
						|
    uv run -- crates/uv-python/template-download-metadata.py
 | 
						|
"""
 | 
						|
 | 
						|
import argparse
 | 
						|
import json
 | 
						|
import logging
 | 
						|
import subprocess
 | 
						|
import sys
 | 
						|
from pathlib import Path
 | 
						|
from typing import Any
 | 
						|
 | 
						|
import chevron_blue
 | 
						|
 | 
						|
CRATE_ROOT = Path(__file__).parent
 | 
						|
WORKSPACE_ROOT = CRATE_ROOT.parent.parent
 | 
						|
VERSION_METADATA = CRATE_ROOT / "download-metadata.json"
 | 
						|
TEMPLATE = CRATE_ROOT / "src" / "downloads.inc.mustache"
 | 
						|
TARGET = TEMPLATE.with_suffix("")
 | 
						|
 | 
						|
 | 
						|
def prepare_name(name: str) -> str:
 | 
						|
    match name:
 | 
						|
        case "cpython":
 | 
						|
            return "CPython"
 | 
						|
        case "pypy":
 | 
						|
            return "PyPy"
 | 
						|
        case _:
 | 
						|
            raise ValueError(f"Unknown implementation name: {name}")
 | 
						|
 | 
						|
 | 
						|
def prepare_libc(libc: str) -> str | None:
 | 
						|
    if libc == "none":
 | 
						|
        return None
 | 
						|
    else:
 | 
						|
        return libc.title()
 | 
						|
 | 
						|
 | 
						|
def prepare_arch(arch: str) -> str:
 | 
						|
    match arch:
 | 
						|
        # Special constructors
 | 
						|
        case "i686":
 | 
						|
            return "X86_32(target_lexicon::X86_32Architecture::I686)"
 | 
						|
        case "aarch64":
 | 
						|
            return "Aarch64(target_lexicon::Aarch64Architecture::Aarch64)"
 | 
						|
        case "armv7":
 | 
						|
            return "Arm(target_lexicon::ArmArchitecture::Armv7)"
 | 
						|
        case _:
 | 
						|
            return arch.capitalize()
 | 
						|
 | 
						|
 | 
						|
def prepare_value(value: dict) -> dict:
 | 
						|
    value["os"] = value["os"].title()
 | 
						|
    value["arch"] = prepare_arch(value["arch"])
 | 
						|
    value["name"] = prepare_name(value["name"])
 | 
						|
    value["libc"] = prepare_libc(value["libc"])
 | 
						|
    return value
 | 
						|
 | 
						|
 | 
						|
def main() -> None:
 | 
						|
    debug = logging.getLogger().getEffectiveLevel() <= logging.DEBUG
 | 
						|
 | 
						|
    data: dict[str, Any] = {}
 | 
						|
    data["generated_with"] = Path(__file__).relative_to(WORKSPACE_ROOT).as_posix()
 | 
						|
    data["generated_from"] = TEMPLATE.relative_to(WORKSPACE_ROOT).as_posix()
 | 
						|
    data["versions"] = [
 | 
						|
        {"key": key, "value": prepare_value(value)}
 | 
						|
        for key, value in json.loads(VERSION_METADATA.read_text()).items()
 | 
						|
    ]
 | 
						|
 | 
						|
    # Render the template
 | 
						|
    logging.info(f"Rendering `{TEMPLATE.name}`...")
 | 
						|
    output = chevron_blue.render(
 | 
						|
        template=TEMPLATE.read_text(), data=data, no_escape=True, warn=debug
 | 
						|
    )
 | 
						|
 | 
						|
    # Update the file
 | 
						|
    logging.info(f"Updating `{TARGET}`...")
 | 
						|
    TARGET.write_text(output)
 | 
						|
    subprocess.check_call(
 | 
						|
        ["rustfmt", str(TARGET)],
 | 
						|
        stderr=subprocess.STDOUT,
 | 
						|
        stdout=sys.stderr if debug else subprocess.DEVNULL,
 | 
						|
    )
 | 
						|
 | 
						|
    logging.info("Done!")
 | 
						|
 | 
						|
 | 
						|
if __name__ == "__main__":
 | 
						|
    parser = argparse.ArgumentParser(
 | 
						|
        description="Generates Rust code for Python version metadata.",
 | 
						|
    )
 | 
						|
    parser.add_argument(
 | 
						|
        "-v",
 | 
						|
        "--verbose",
 | 
						|
        action="store_true",
 | 
						|
        help="Enable debug logging",
 | 
						|
    )
 | 
						|
    parser.add_argument(
 | 
						|
        "-q",
 | 
						|
        "--quiet",
 | 
						|
        action="store_true",
 | 
						|
        help="Disable logging",
 | 
						|
    )
 | 
						|
 | 
						|
    args = parser.parse_args()
 | 
						|
    if args.quiet:
 | 
						|
        log_level = logging.CRITICAL
 | 
						|
    elif args.verbose:
 | 
						|
        log_level = logging.DEBUG
 | 
						|
    else:
 | 
						|
        log_level = logging.INFO
 | 
						|
 | 
						|
    logging.basicConfig(level=log_level, format="%(message)s")
 | 
						|
 | 
						|
    main()
 |