Libvcs

Latest version: v0.35.0

Safety actively analyzes 723607 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 6 of 14

0.18.0

New features

URLs

- Added `weight` to matchers (428)

- More heavily weighted matcher will have preference over others
- Fixes an issue where `defaults` would be overwritten

The first, highest weighted will "win", avoiding the recursion causing defau defaults for other
matchers to be applied.

0.17.0

New features

- URLs: Added `registry`, match find which VCS a URL matches with (420)
- `create_project`: Learn to guess VCS from URL, if none provided (420)

Breaking changes

URL renamings (417):

- `Matcher` -> `Rule`, `MatcherRegistry` -> `Rules`
- `matches` -> `rule_map`
- `default_patterns` -> `patterns`
- `MATCHERS` -> `RULES`

Improvements

pytest plugin:

- `create_{git,svn,hg}_remote_repo()` now accepts `init_cmd_args` (`list[str]`, default:
`['--bare']`, 426)

To not use bare, pass `init_cmd_args=None`

Sync:

- `git`: Fix `update_repo` when there are only untracked files (425, credit: jfpedroza)

URL (423):

- `hg`: Add `HgBaseURL`, `HgPipURL`
- `svn`: Add `SvnBaseURL`, `SvnPipURL`
- `URLProtocol`: Fix `is_valid` to use `classmethod`
- All: Fix `is_valid` to use default of `None` to avoid implicitly filtering
- Reduce duplicated code in methods by using `super()`

Packaging

- Migrate `.coveragerc` to `pyproject.toml` (421)
- Remove `.tmuxp.before-script.sh` (was a `before_script` in `.tmuxp.yaml`) that was unused.
- Move `conftest.py` to root level

- Can be excluded from wheel, included in sdist
- Required to satisfy pytest's `pytest_plugins` only being in top-level confte conftest.py files
since 4.0 (see
[notice](https://docs.pytest.org/en/stable/deprecations.html#pytest-plugins-in-non-top-level-conftest-files))
- Makes it possible to run `pytest README.md` with doctest plugin

0.16.5

Bug fixes

- Use pytest's public API when importing (418)

0.16.4

Infrastructure

- Bump poetry to 1.1.x to 1.2.x

0.16.3

Bug fixes

- `QueryList`: Fix lookups of objects (415)

Tests

- Basic pytest plugin test (413)
- Add test for object based lookups (414)

Documentation

- Improve doc examples / tests for `keygetter` and `QueryList` to show deep lookups for objects
(415)

Infrastructure

- CI speedups (416)

- Avoid fetching unused apt package
- Split out release to separate job so the PyPI Upload docker image isn't pulled on normal runs
- Clean up CodeQL

0.16.2

Bug fix

Remove `Faker` dependency (412)

Page 6 of 14

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.