mirror of
				https://github.com/astral-sh/uv.git
				synced 2025-10-25 01:17:36 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			250 lines
		
	
	
	
		
			8.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			250 lines
		
	
	
	
		
			8.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Tools
 | |
| 
 | |
| Tools are Python packages that provide command-line interfaces.
 | |
| 
 | |
| !!! note
 | |
| 
 | |
|     See the [tools guide](../guides/tools.md) for an introduction to working with the tools
 | |
|     interface — this document discusses details of tool management.
 | |
| 
 | |
| ## The `uv tool` interface
 | |
| 
 | |
| uv includes a dedicated interface for interacting with tools. Tools can be invoked without
 | |
| installation using `uv tool run`, in which case their dependencies are installed in a temporary
 | |
| virtual environment isolated from the current project.
 | |
| 
 | |
| Because it is very common to run tools without installing them, a `uvx` alias is provided for
 | |
| `uv tool run` — the two commands are exactly equivalent. For brevity, the documentation will mostly
 | |
| refer to `uvx` instead of `uv tool run`.
 | |
| 
 | |
| Tools can also be installed with `uv tool install`, in which case their executables are
 | |
| [available on the `PATH`](#the-path) — an isolated virtual environment is still used, but it is not
 | |
| removed when the command completes.
 | |
| 
 | |
| ## Execution vs installation
 | |
| 
 | |
| In most cases, executing a tool with `uvx` is more appropriate than installing the tool. Installing
 | |
| the tool is useful if you need the tool to be available to other programs on your system, e.g., if
 | |
| some script you do not control requires the tool, or if you are in a Docker image and want to make
 | |
| the tool available to users.
 | |
| 
 | |
| ## Tool environments
 | |
| 
 | |
| When running a tool with `uvx`, a virtual environment is stored in the uv cache directory and is
 | |
| treated as disposable, i.e., if you run `uv cache clean` the environment will be deleted. The
 | |
| environment is only cached to reduce the overhead of repeated invocations. If the environment is
 | |
| removed, a new one will be created automatically.
 | |
| 
 | |
| When installing a tool with `uv tool install`, a virtual environment is created in the uv tools
 | |
| directory. The environment will not be removed unless the tool is uninstalled. If the environment is
 | |
| manually deleted, the tool will fail to run.
 | |
| 
 | |
| ## Tool versions
 | |
| 
 | |
| Unless a specific version is requested, `uv tool install` will install the latest available of the
 | |
| requested tool. `uvx` will use the latest available version of the requested tool _on the first
 | |
| invocation_. After that, `uvx` will use the cached version of the tool unless a different version is
 | |
| requested, the cache is pruned, or the cache is refreshed.
 | |
| 
 | |
| For example, to run a specific version of Ruff:
 | |
| 
 | |
| ```console
 | |
| $ uvx ruff@0.6.0 --version
 | |
| ruff 0.6.0
 | |
| ```
 | |
| 
 | |
| A subsequent invocation of `uvx` will use the latest, not the cached, version.
 | |
| 
 | |
| ```console
 | |
| $ uvx ruff --version
 | |
| ruff 0.6.2
 | |
| ```
 | |
| 
 | |
| But, if a new version of Ruff was released, it would not be used unless the cache was refreshed.
 | |
| 
 | |
| To request the latest version of Ruff and refresh the cache, use the `@latest` suffix:
 | |
| 
 | |
| ```console
 | |
| $ uvx ruff@latest --version
 | |
| 0.6.2
 | |
| ```
 | |
| 
 | |
| Once a tool is installed with `uv tool install`, `uvx` will use the installed version by default.
 | |
| 
 | |
| For example, after installing an older version of Ruff:
 | |
| 
 | |
| ```console
 | |
| $ uv tool install ruff==0.5.0
 | |
| ```
 | |
| 
 | |
| The version of `ruff` and `uvx ruff` is the same:
 | |
| 
 | |
| ```console
 | |
| $ ruff --version
 | |
| ruff 0.5.0
 | |
| $ uvx ruff --version
 | |
| ruff 0.5.0
 | |
| ```
 | |
| 
 | |
| However, you can ignore the installed version by requesting the latest version explicitly, e.g.:
 | |
| 
 | |
| ```console
 | |
| $ uvx ruff@latest --version
 | |
| 0.6.2
 | |
| ```
 | |
| 
 | |
| Or, by using the `--isolated` flag, which will avoid refreshing the cache but ignore the installed
 | |
| version:
 | |
| 
 | |
| ```console
 | |
| $ uvx --isolated ruff --version
 | |
| 0.6.2
 | |
| ```
 | |
| 
 | |
| `uv tool install` will also respect the `{package}@{version}` and `{package}@latest` specifiers, as
 | |
| in:
 | |
| 
 | |
| ```console
 | |
| $ uv tool install ruff@latest
 | |
| $ uv tool install ruff@0.6.0
 | |
| ```
 | |
| 
 | |
| ### Tools directory
 | |
| 
 | |
| By default, the uv tools directory is named `tools` and is in the uv application state directory,
 | |
| e.g., `~/.local/share/uv/tools`. The location may be customized with the `UV_TOOL_DIR` environment
 | |
| variable.
 | |
| 
 | |
| To display the path to the tool installation directory:
 | |
| 
 | |
| ```console
 | |
| $ uv tool dir
 | |
| ```
 | |
| 
 | |
| Tool environments are placed in a directory with the same name as the tool package, e.g.,
 | |
| `.../tools/<name>`.
 | |
| 
 | |
| ### Mutating tool environments
 | |
| 
 | |
| Tool environments are _not_ intended to be mutated directly. It is strongly recommended never to
 | |
| mutate a tool environment manually with a `pip` operation.
 | |
| 
 | |
| Tool environments may be upgraded via `uv tool upgrade`, or re-created entirely via subsequent
 | |
| `uv tool install` operations.
 | |
| 
 | |
| To upgrade all packages in a tool environment
 | |
| 
 | |
| ```console
 | |
| $ uv tool upgrade black
 | |
| ```
 | |
| 
 | |
| To upgrade a single package in a tool environment:
 | |
| 
 | |
| ```console
 | |
| $ uv tool upgrade black --upgrade-package click
 | |
| ```
 | |
| 
 | |
| To reinstall all packages in a tool environment
 | |
| 
 | |
| ```console
 | |
| $ uv tool upgrade black --reinstall
 | |
| ```
 | |
| 
 | |
| To reinstall a single package in a tool environment:
 | |
| 
 | |
| ```console
 | |
| $ uv tool upgrade black --reinstall-package click
 | |
| ```
 | |
| 
 | |
| Tool upgrades will respect the version constraints provided when installing the tool. For example,
 | |
| `uv tool install black >=23,<24` followed by `uv tool upgrade black` will upgrade Black to the
 | |
| latest version in the range `>=23,<24`.
 | |
| 
 | |
| To instead replace the version constraints, reinstall the tool with `uv tool install`:
 | |
| 
 | |
| ```console
 | |
| $ uv tool install black>=24
 | |
| ```
 | |
| 
 | |
| Similarly, tool upgrades will retain the settings provided when installing the tool. For example,
 | |
| `uv tool install black --prerelease allow` followed by `uv tool upgrade black` will retain the
 | |
| `--prerelease allow` setting.
 | |
| 
 | |
| Tool upgrades will reinstall the tool executables, even if they have not changed.
 | |
| 
 | |
| ### Including additional dependencies
 | |
| 
 | |
| Additional packages can be included during tool execution:
 | |
| 
 | |
| ```console
 | |
| $ uvx --with <extra-package> <tool>
 | |
| ```
 | |
| 
 | |
| And, during tool installation:
 | |
| 
 | |
| ```console
 | |
| $ uv tool install --with <extra-package> <tool-package>
 | |
| ```
 | |
| 
 | |
| The `--with` option can be provided multiple times to include additional packages.
 | |
| 
 | |
| The `--with` option supports package specifications, so a specific version can be requested:
 | |
| 
 | |
| ```console
 | |
| $ uvx --with <extra-package>==<version> <tool-package>
 | |
| ```
 | |
| 
 | |
| If the requested version conflicts with the requirements of the tool package, package resolution
 | |
| will fail and the command will error.
 | |
| 
 | |
| ## Tool executables
 | |
| 
 | |
| Tool executables include all console entry points, script entry points, and binary scripts provided
 | |
| by a Python package. Tool executables are symlinked into the `bin` directory on Unix and copied on
 | |
| Windows.
 | |
| 
 | |
| ### The `bin` directory
 | |
| 
 | |
| Executables are installed into the user `bin` directory following the XDG standard, e.g.,
 | |
| `~/.local/bin`. Unlike other directory schemes in uv, the XDG standard is used on _all platforms_
 | |
| notably including Windows and macOS — there is no clear alternative location to place executables on
 | |
| these platforms. The installation directory is determined from the first available environment
 | |
| variable:
 | |
| 
 | |
| - `$UV_TOOL_BIN_DIR`
 | |
| - `$XDG_BIN_HOME`
 | |
| - `$XDG_DATA_HOME/../bin`
 | |
| - `$HOME/.local/bin`
 | |
| 
 | |
| Executables provided by dependencies of tool packages are not installed.
 | |
| 
 | |
| ### The `PATH`
 | |
| 
 | |
| The `bin` directory must be in the `PATH` variable for tool executables to be available from the
 | |
| shell. If it is not in the `PATH`, a warning will be displayed. The `uv tool update-shell` command
 | |
| can be used to add the `bin` directory to the `PATH` in common shell configuration files.
 | |
| 
 | |
| ### Overwriting executables
 | |
| 
 | |
| Installation of tools will not overwrite executables in the `bin` directory that were not previously
 | |
| installed by uv. For example, if `pipx` has been used to install a tool, `uv tool install` will
 | |
| fail. The `--force` flag can be used to override this behavior.
 | |
| 
 | |
| ## Relationship to `uv run`
 | |
| 
 | |
| The invocation `uv tool run <name>` (or `uvx <name>`) is nearly equivalent to:
 | |
| 
 | |
| ```console
 | |
| $ uv run --no-project --with <name> -- <name>
 | |
| ```
 | |
| 
 | |
| However, there are a couple notable differences when using uv's tool interface:
 | |
| 
 | |
| - The `--with` option is not needed — the required package is inferred from the command name.
 | |
| - The temporary environment is cached in a dedicated location.
 | |
| - The `--no-project` flag is not needed — tools are always run isolated from the project.
 | |
| - If a tool is already installed, `uv tool run` will use the installed version but `uv run` will
 | |
|   not.
 | |
| 
 | |
| If the tool should not be isolated from the project, e.g., when running `pytest` or `mypy`, then
 | |
| `uv run` should be used instead of `uv tool run`.
 | 
