Kaydet (Commit) 62a99515 authored tarafından Serhiy Storchaka's avatar Serhiy Storchaka Kaydeden (comit) GitHub

bpo-29900: Simplify pathlib implementation. (#814)

Since functions in the os module support path-like objects, explicit
converting Path to str no longer needed.
üst 4aec9a8b
...@@ -384,49 +384,37 @@ class _Accessor: ...@@ -384,49 +384,37 @@ class _Accessor:
class _NormalAccessor(_Accessor): class _NormalAccessor(_Accessor):
def _wrap_strfunc(strfunc): stat = os.stat
@functools.wraps(strfunc)
def wrapped(pathobj, *args):
return strfunc(str(pathobj), *args)
return staticmethod(wrapped)
def _wrap_binary_strfunc(strfunc): lstat = os.lstat
@functools.wraps(strfunc)
def wrapped(pathobjA, pathobjB, *args):
return strfunc(str(pathobjA), str(pathobjB), *args)
return staticmethod(wrapped)
stat = _wrap_strfunc(os.stat) open = os.open
lstat = _wrap_strfunc(os.lstat) listdir = os.listdir
open = _wrap_strfunc(os.open) scandir = os.scandir
listdir = _wrap_strfunc(os.listdir) chmod = os.chmod
scandir = _wrap_strfunc(os.scandir)
chmod = _wrap_strfunc(os.chmod)
if hasattr(os, "lchmod"): if hasattr(os, "lchmod"):
lchmod = _wrap_strfunc(os.lchmod) lchmod = os.lchmod
else: else:
def lchmod(self, pathobj, mode): def lchmod(self, pathobj, mode):
raise NotImplementedError("lchmod() not available on this system") raise NotImplementedError("lchmod() not available on this system")
mkdir = _wrap_strfunc(os.mkdir) mkdir = os.mkdir
unlink = _wrap_strfunc(os.unlink) unlink = os.unlink
rmdir = _wrap_strfunc(os.rmdir) rmdir = os.rmdir
rename = _wrap_binary_strfunc(os.rename) rename = os.rename
replace = _wrap_binary_strfunc(os.replace) replace = os.replace
if nt: if nt:
if supports_symlinks: if supports_symlinks:
symlink = _wrap_binary_strfunc(os.symlink) symlink = os.symlink
else: else:
def symlink(a, b, target_is_directory): def symlink(a, b, target_is_directory):
raise NotImplementedError("symlink() not available on this system") raise NotImplementedError("symlink() not available on this system")
...@@ -434,9 +422,9 @@ class _NormalAccessor(_Accessor): ...@@ -434,9 +422,9 @@ class _NormalAccessor(_Accessor):
# Under POSIX, os.symlink() takes two args # Under POSIX, os.symlink() takes two args
@staticmethod @staticmethod
def symlink(a, b, target_is_directory): def symlink(a, b, target_is_directory):
return os.symlink(str(a), str(b)) return os.symlink(a, b)
utime = _wrap_strfunc(os.utime) utime = os.utime
# Helper for resolve() # Helper for resolve()
def readlink(self, path): def readlink(self, path):
...@@ -711,7 +699,7 @@ class PurePath(object): ...@@ -711,7 +699,7 @@ class PurePath(object):
def __bytes__(self): def __bytes__(self):
"""Return the bytes representation of the path. This is only """Return the bytes representation of the path. This is only
recommended to use under Unix.""" recommended to use under Unix."""
return os.fsencode(str(self)) return os.fsencode(self)
def __repr__(self): def __repr__(self):
return "{}({!r})".format(self.__class__.__name__, self.as_posix()) return "{}({!r})".format(self.__class__.__name__, self.as_posix())
...@@ -1160,7 +1148,7 @@ class Path(PurePath): ...@@ -1160,7 +1148,7 @@ class Path(PurePath):
""" """
if self._closed: if self._closed:
self._raise_closed() self._raise_closed()
return io.open(str(self), mode, buffering, encoding, errors, newline, return io.open(self, mode, buffering, encoding, errors, newline,
opener=self._opener) opener=self._opener)
def read_bytes(self): def read_bytes(self):
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment