]> git.ipfire.org Git - thirdparty/Python/cpython.git/commit
gh-100562: improve performance of `pathlib.Path.absolute()` (GH-100563)
authorBarney Gale <barney.gale@gmail.com>
Thu, 5 Jan 2023 22:11:50 +0000 (22:11 +0000)
committerGitHub <noreply@github.com>
Thu, 5 Jan 2023 22:11:50 +0000 (14:11 -0800)
commit7fba99eadb3349a6d49d02f13b1fddf44c674393
treea8445e2fdf12cbbe1e427ae2f09b7ba578af1a23
parentaf5149f30b652737ef3b495b303819d985f439b1
gh-100562: improve performance of `pathlib.Path.absolute()` (GH-100563)

Increase performance of the `absolute()` method by calling `os.getcwd()` directly, rather than using the `Path.cwd()` class method. This avoids constructing an extra `Path` object (and the parsing/normalization that comes with it).

Decrease performance of the `cwd()` class method by calling the `Path.absolute()` method, rather than using `os.getcwd()` directly. This involves constructing an extra `Path` object. We do this to maintain a longstanding pattern where `os` functions are called from only one place, which allows them to be more readily replaced by users. As `cwd()` is generally called at most once within user programs, it's a good bargain.

```shell
# before
$ ./python -m timeit -s 'from pathlib import Path; p = Path("foo", "bar")' 'p.absolute()'
50000 loops, best of 5: 9.04 usec per loop
# after
$ ./python -m timeit -s 'from pathlib import Path; p = Path("foo", "bar")' 'p.absolute()'
50000 loops, best of 5: 5.02 usec per loop
```

Automerge-Triggered-By: GH:AlexWaygood
Lib/pathlib.py
Misc/NEWS.d/next/Library/2022-12-28-00-28-43.gh-issue-100562.Hic0Z0.rst [new file with mode: 0644]