uv/crates/uv-build-frontend/src
konsti 62bf92132b
Add a 5 min default timeout for deadlocks (#16342)
When a process is running and another calls `uv cache clean` or `uv
cache prune` we currently deadlock - sometimes until the CI timeout
(https://github.com/astral-sh/setup-uv/issues/588). To avoid this, we
add a default 5 min timeout waiting for a lock. 5 min balances allowing
in-progress builds to finish, especially with larger native
dependencies, while also giving timely errors for deadlocks on (remote)
systems.

Commit 1 is a refactoring.

This branch also fixes a problem with the logging where acquired and
released resources currently mismatch:

```
DEBUG Acquired lock for `https://github.com/tqdm/tqdm`
DEBUG Using existing Git source `https://github.com/tqdm/tqdm`
DEBUG Released lock at `C:\Users\Konsti\AppData\Local\uv\cache\git-v0\locks\16bb813afef8edd2`
```
2025-12-04 14:59:04 +01:00
..
pipreqs Add `extra-build-dependencies` hint for any missing module on build failure (#15252) 2025-08-14 12:00:57 -05:00
error.rs Import `PackageName` from `uv-normalize` (#15439) 2025-08-21 23:15:40 +00:00
lib.rs Add a 5 min default timeout for deadlocks (#16342) 2025-12-04 14:59:04 +01:00
pipreqs.rs Add `extra-build-dependencies` hint for any missing module on build failure (#15252) 2025-08-14 12:00:57 -05:00