-
-
Notifications
You must be signed in to change notification settings - Fork 32.1k
GH-125413: Add pathlib.Path.info
attribute
#127730
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
When a path object is generated by `PathBase.iterdir()`, then its `_info` attribute now stores a `os.DirEntry`-like object that can be used to query the file type. This removes any need for a `_scandir()` method. Currently the `_info` attribute is private and only guaranteed to be populated in paths from `iterdir()`. Later on, I'm hoping to rename it to `info` and ensure that it's populated for all kinds of paths (this probably involves adding a `pathlib.FileInfo` class.) In the pathlib ABCs, `info` will replace `stat()` as the lowest-level abstract file status querying mechanism.
Steve - hopefully this helps address the issues you raised in #127377, but perhaps I'm only moving the problem around here. |
I think this is just moving stuff around. It might end up being the right places, but let's see the Discourse discussion play out a bit first. |
_scandir()
with _info
_scandir()
with _status
_scandir()
with _status
pathlib.Path.status
attribute
I've revised the PR to be a more complete implementation of what I described on the forum, mostly as a demonstration/proof-of-concept at this stage. |
Right, I think this is ready for review. Alyssa, sorry if this seems like deja-vu! |
pathlib.Path.status
attributepathlib.Path.info
attribute
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks great, thank you!
I do have a nitpick:
Co-authored-by: Petr Viktorin <[email protected]>
Thank you Petr :) I'll wait another month until I merge, in case Alyssa or Steve have feedback |
I'll merge this on Friday if there's no further feedback. Cheers |
Add
pathlib.Path.info
attribute, which stores an object implementing thepathlib.types.PathInfo
protocol (also new). The object supports querying the file type and internally cachingos.stat()
results. Path objects generated byPath.iterdir()
are initialised with status information fromos.DirEntry
objects, which is gleaned from scanning the parent directory.The
PathInfo
protocol has four methods:exists()
,is_dir()
,is_file()
andis_symlink()
.os.DirEntry
objects from pathlib #125413