-
-
Notifications
You must be signed in to change notification settings - Fork 30.9k
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
GH-81079: Add case_sensitive argument to pathlib.Path.glob()
#102710
GH-81079: Add case_sensitive argument to pathlib.Path.glob()
#102710
Conversation
This argument allows case-sensitive matching to be enabled on Windows, and case-insensitive matching to be enabled on Posix.
pathlib.Path.glob()
It might be nice to describe the We don't have to implement those yet, but let's not lock ourselves out by documenting the specific rules. We can also file a feature request now to implement proper case support - it might help find someone motivated to make it happen. Also, like with the symlink change, I'd like to see clearly stated which parts of the pattern are affected, as I assume it only applies to segments from the first wildcard (that is, I trust you (and the tests) on the implementation. It takes me a good few hours to get this code into my head in a way I can judge it, and I don't have time for that today, but also don't want to block on it when all the tests look good :) |
Thanks for taking a look!
Good shout, will do!
It affects all parts of the pattern! So it would match both your examples. I think this is the behaviour users expect when passing (The same thing will apply when we add support for
I'll expand the PR description to (hopefully) make it easier for you (or anyone else) to get into the patch. |
I was thinking of the |
While thinking about how to explain this PR, I realised it could be broken down further. So here's two new smallish PRs:
I'll mark this one as a draft for now. |
One more for good luck: |
If we'd like to add a case_sensitive argument to |
Co-authored-by: Steve Dower <[email protected]>
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.
LGTM
* main: (61 commits) pythongh-64595: Argument Clinic: Touch source file if any output file changed (python#104152) pythongh-64631: Test exception messages in cloned Argument Clinic funcs (python#104167) pythongh-68395: Avoid naming conflicts by mangling variable names in Argument Clinic (python#104065) pythongh-64658: Expand Argument Clinic return converter docs (python#104175) pythonGH-103092: port `_asyncio` freelist to module state (python#104196) pythongh-104051: fix crash in test_xxtestfuzz with -We (python#104052) pythongh-104190: fix ubsan crash (python#104191) pythongh-104106: Add gcc fallback of mkfifoat/mknodat for macOS (pythongh-104129) pythonGH-104142: Fix _Py_RefcntAdd to respect immortality (pythonGH-104143) pythongh-104112: link from cached_property docs to method-caching FAQ (python#104113) pythongh-68968: Correcting message display issue with assertEqual (python#103937) pythonGH-103899: Provide a hint when accidentally calling a module (pythonGH-103900) pythongh-103963: fix 'make regen-opcode' in out-of-tree builds (python#104177) pythongh-102500: Add PEP 688 and 698 to the 3.12 release highlights (python#104174) pythonGH-81079: Add case_sensitive argument to `pathlib.Path.glob()` (pythonGH-102710) pythongh-91896: Deprecate collections.abc.ByteString (python#102096) pythongh-99593: Add tests for Unicode C API (part 2) (python#99868) pythongh-102500: Document PEP 688 (python#102571) pythongh-102500: Implement PEP 688 (python#102521) pythongh-96534: socketmodule: support FreeBSD divert(4) socket (python#96536) ...
This argument allows case-sensitive matching to be enabled on Windows, and case-insensitive matching to be enabled on Posix.
This PR removes
_PreciseSelector
and uses_WildcardSelector
to select non-wildcard patterns. This allows case sensitivity rules to be varied, and ensures the paths returned fromglob()
use filesystem casing.