Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
8f6b344d
Commit
8f6b344d
authored
Mar 07, 2017
by
Serhiy Storchaka
Committed by
GitHub
Mar 07, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bpo-28682: Added support for bytes paths in os.fwalk(). (#489)
parent
8886d5f3
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
37 additions
and
15 deletions
+37
-15
Doc/library/os.rst
Doc/library/os.rst
+3
-0
Doc/whatsnew/3.7.rst
Doc/whatsnew/3.7.rst
+6
-0
Lib/os.py
Lib/os.py
+7
-3
Lib/test/test_os.py
Lib/test/test_os.py
+19
-12
Misc/NEWS
Misc/NEWS
+2
-0
No files found.
Doc/library/os.rst
View file @
8f6b344d
...
...
@@ -2840,6 +2840,9 @@ features:
.. versionchanged:: 3.6
Accepts a :term:`path-like object`.
.. versionchanged:: 3.7
Added support for :class:`bytes` paths.
Linux extended attributes
~~~~~~~~~~~~~~~~~~~~~~~~~
...
...
Doc/whatsnew/3.7.rst
View file @
8f6b344d
...
...
@@ -97,6 +97,12 @@ New Modules
Improved Modules
================
os
--
Added support for :class:`bytes` paths in :func:`~os.fwalk`.
(Contributed by Serhiy Storchaka in :issue:`28682`.)
unittest.mock
-------------
...
...
Lib/os.py
View file @
8f6b344d
...
...
@@ -460,16 +460,19 @@ if {open, stat} <= supports_dir_fd and {listdir, stat} <= supports_fd:
try
:
if
(
follow_symlinks
or
(
st
.
S_ISDIR
(
orig_st
.
st_mode
)
and
path
.
samestat
(
orig_st
,
stat
(
topfd
)))):
yield
from
_fwalk
(
topfd
,
top
,
topdown
,
onerror
,
follow_symlinks
)
yield
from
_fwalk
(
topfd
,
top
,
isinstance
(
top
,
bytes
),
topdown
,
onerror
,
follow_symlinks
)
finally
:
close
(
topfd
)
def
_fwalk
(
topfd
,
toppath
,
topdown
,
onerror
,
follow_symlinks
):
def
_fwalk
(
topfd
,
toppath
,
isbytes
,
topdown
,
onerror
,
follow_symlinks
):
# Note: This uses O(depth of the directory tree) file descriptors: if
# necessary, it can be adapted to only require O(1) FDs, see issue
# #13734.
names
=
listdir
(
topfd
)
if
isbytes
:
names
=
map
(
fsencode
,
names
)
dirs
,
nondirs
=
[],
[]
for
name
in
names
:
try
:
...
...
@@ -504,7 +507,8 @@ if {open, stat} <= supports_dir_fd and {listdir, stat} <= supports_fd:
try
:
if
follow_symlinks
or
path
.
samestat
(
orig_st
,
stat
(
dirfd
)):
dirpath
=
path
.
join
(
toppath
,
name
)
yield
from
_fwalk
(
dirfd
,
dirpath
,
topdown
,
onerror
,
follow_symlinks
)
yield
from
_fwalk
(
dirfd
,
dirpath
,
isbytes
,
topdown
,
onerror
,
follow_symlinks
)
finally
:
close
(
dirfd
)
...
...
Lib/test/test_os.py
View file @
8f6b344d
...
...
@@ -1010,9 +1010,12 @@ class FwalkTests(WalkTests):
"""Tests for os.fwalk()."""
def
walk
(
self
,
top
,
**
kwargs
):
for
root
,
dirs
,
files
,
root_fd
in
os
.
fwalk
(
top
,
**
kwargs
):
for
root
,
dirs
,
files
,
root_fd
in
self
.
fwalk
(
top
,
**
kwargs
):
yield
(
root
,
dirs
,
files
)
def
fwalk
(
self
,
*
args
,
**
kwargs
):
return
os
.
fwalk
(
*
args
,
**
kwargs
)
def
_compare_to_walk
(
self
,
walk_kwargs
,
fwalk_kwargs
):
"""
compare with walk() results.
...
...
@@ -1027,7 +1030,7 @@ class FwalkTests(WalkTests):
for
root
,
dirs
,
files
in
os
.
walk
(
**
walk_kwargs
):
expected
[
root
]
=
(
set
(
dirs
),
set
(
files
))
for
root
,
dirs
,
files
,
rootfd
in
os
.
fwalk
(
**
fwalk_kwargs
):
for
root
,
dirs
,
files
,
rootfd
in
self
.
fwalk
(
**
fwalk_kwargs
):
self
.
assertIn
(
root
,
expected
)
self
.
assertEqual
(
expected
[
root
],
(
set
(
dirs
),
set
(
files
)))
...
...
@@ -1049,7 +1052,7 @@ class FwalkTests(WalkTests):
# check returned file descriptors
for
topdown
,
follow_symlinks
in
itertools
.
product
((
True
,
False
),
repeat
=
2
):
args
=
support
.
TESTFN
,
topdown
,
None
for
root
,
dirs
,
files
,
rootfd
in
os
.
fwalk
(
*
args
,
follow_symlinks
=
follow_symlinks
):
for
root
,
dirs
,
files
,
rootfd
in
self
.
fwalk
(
*
args
,
follow_symlinks
=
follow_symlinks
):
# check that the FD is valid
os
.
fstat
(
rootfd
)
# redundant check
...
...
@@ -1064,7 +1067,7 @@ class FwalkTests(WalkTests):
minfd
=
os
.
dup
(
1
)
os
.
close
(
minfd
)
for
i
in
range
(
256
):
for
x
in
os
.
fwalk
(
support
.
TESTFN
):
for
x
in
self
.
fwalk
(
support
.
TESTFN
):
pass
newfd
=
os
.
dup
(
1
)
self
.
addCleanup
(
os
.
close
,
newfd
)
...
...
@@ -1072,14 +1075,6 @@ class FwalkTests(WalkTests):
class
BytesWalkTests
(
WalkTests
):
"""Tests for os.walk() with bytes."""
def
setUp
(
self
):
super
().
setUp
()
self
.
stack
=
contextlib
.
ExitStack
()
def
tearDown
(
self
):
self
.
stack
.
close
()
super
().
tearDown
()
def
walk
(
self
,
top
,
**
kwargs
):
if
'follow_symlinks'
in
kwargs
:
kwargs
[
'followlinks'
]
=
kwargs
.
pop
(
'follow_symlinks'
)
...
...
@@ -1091,6 +1086,18 @@ class BytesWalkTests(WalkTests):
bdirs
[:]
=
list
(
map
(
os
.
fsencode
,
dirs
))
bfiles
[:]
=
list
(
map
(
os
.
fsencode
,
files
))
@
unittest
.
skipUnless
(
hasattr
(
os
,
'fwalk'
),
"Test needs os.fwalk()"
)
class
BytesFwalkTests
(
FwalkTests
):
"""Tests for os.walk() with bytes."""
def
fwalk
(
self
,
top
=
'.'
,
*
args
,
**
kwargs
):
for
broot
,
bdirs
,
bfiles
,
topfd
in
os
.
fwalk
(
os
.
fsencode
(
top
),
*
args
,
**
kwargs
):
root
=
os
.
fsdecode
(
broot
)
dirs
=
list
(
map
(
os
.
fsdecode
,
bdirs
))
files
=
list
(
map
(
os
.
fsdecode
,
bfiles
))
yield
(
root
,
dirs
,
files
,
topfd
)
bdirs
[:]
=
list
(
map
(
os
.
fsencode
,
dirs
))
bfiles
[:]
=
list
(
map
(
os
.
fsencode
,
files
))
class
MakedirTests
(
unittest
.
TestCase
):
def
setUp
(
self
):
...
...
Misc/NEWS
View file @
8f6b344d
...
...
@@ -265,6 +265,8 @@ Extension Modules
Library
-------
-
bpo
-
28682
:
Added
support
for
bytes
paths
in
os
.
fwalk
().
-
bpo
-
29623
:
Allow
use
of
path
-
like
object
as
a
single
argument
in
ConfigParser
.
read
().
Patch
by
David
Ellis
.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment