mirror of
https://github.com/python/cpython.git
synced 2024-11-21 21:09:37 +01:00
This commit is contained in:
parent
5610860840
commit
4b00aba42e
@ -553,28 +553,21 @@ except ImportError:
|
|||||||
return prefix + sep.join(comps)
|
return prefix + sep.join(comps)
|
||||||
|
|
||||||
|
|
||||||
def _abspath_fallback(path):
|
|
||||||
"""Return the absolute version of a path as a fallback function in case
|
|
||||||
`nt._getfullpathname` is not available or raises OSError. See bpo-31047 for
|
|
||||||
more.
|
|
||||||
|
|
||||||
"""
|
|
||||||
|
|
||||||
path = os.fspath(path)
|
|
||||||
if not isabs(path):
|
|
||||||
if isinstance(path, bytes):
|
|
||||||
cwd = os.getcwdb()
|
|
||||||
else:
|
|
||||||
cwd = os.getcwd()
|
|
||||||
path = join(cwd, path)
|
|
||||||
return normpath(path)
|
|
||||||
|
|
||||||
# Return an absolute path.
|
# Return an absolute path.
|
||||||
try:
|
try:
|
||||||
from nt import _getfullpathname
|
from nt import _getfullpathname
|
||||||
|
|
||||||
except ImportError: # not running on Windows - mock up something sensible
|
except ImportError: # not running on Windows - mock up something sensible
|
||||||
abspath = _abspath_fallback
|
def abspath(path):
|
||||||
|
"""Return the absolute version of a path."""
|
||||||
|
path = os.fspath(path)
|
||||||
|
if not isabs(path):
|
||||||
|
if isinstance(path, bytes):
|
||||||
|
cwd = os.getcwdb()
|
||||||
|
else:
|
||||||
|
cwd = os.getcwd()
|
||||||
|
path = join(cwd, path)
|
||||||
|
return normpath(path)
|
||||||
|
|
||||||
else: # use native Windows method on Windows
|
else: # use native Windows method on Windows
|
||||||
def abspath(path):
|
def abspath(path):
|
||||||
@ -582,7 +575,27 @@ else: # use native Windows method on Windows
|
|||||||
try:
|
try:
|
||||||
return _getfullpathname(normpath(path))
|
return _getfullpathname(normpath(path))
|
||||||
except (OSError, ValueError):
|
except (OSError, ValueError):
|
||||||
return _abspath_fallback(path)
|
# See gh-75230, handle outside for cleaner traceback
|
||||||
|
pass
|
||||||
|
path = os.fspath(path)
|
||||||
|
if not isabs(path):
|
||||||
|
if isinstance(path, bytes):
|
||||||
|
sep = b'\\'
|
||||||
|
getcwd = os.getcwdb
|
||||||
|
else:
|
||||||
|
sep = '\\'
|
||||||
|
getcwd = os.getcwd
|
||||||
|
drive, root, path = splitroot(path)
|
||||||
|
# Either drive or root can be nonempty, but not both.
|
||||||
|
if drive or root:
|
||||||
|
try:
|
||||||
|
path = join(_getfullpathname(drive + root), path)
|
||||||
|
except (OSError, ValueError):
|
||||||
|
# Drive "\0:" cannot exist; use the root directory.
|
||||||
|
path = drive + sep + path
|
||||||
|
else:
|
||||||
|
path = join(getcwd(), path)
|
||||||
|
return normpath(path)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from nt import _findfirstfile, _getfinalpathname, readlink as _nt_readlink
|
from nt import _findfirstfile, _getfinalpathname, readlink as _nt_readlink
|
||||||
|
@ -806,6 +806,9 @@ class TestNtpath(NtpathTestCase):
|
|||||||
tester('ntpath.abspath("C:\\spam. . .")', "C:\\spam")
|
tester('ntpath.abspath("C:\\spam. . .")', "C:\\spam")
|
||||||
tester('ntpath.abspath("C:/nul")', "\\\\.\\nul")
|
tester('ntpath.abspath("C:/nul")', "\\\\.\\nul")
|
||||||
tester('ntpath.abspath("C:\\nul")', "\\\\.\\nul")
|
tester('ntpath.abspath("C:\\nul")', "\\\\.\\nul")
|
||||||
|
self.assertTrue(ntpath.isabs(ntpath.abspath("C:spam")))
|
||||||
|
self.assertEqual(ntpath.abspath("C:\x00"), ntpath.join(ntpath.abspath("C:"), "\x00"))
|
||||||
|
self.assertEqual(ntpath.abspath("\x00:spam"), "\x00:\\spam")
|
||||||
tester('ntpath.abspath("//..")', "\\\\")
|
tester('ntpath.abspath("//..")', "\\\\")
|
||||||
tester('ntpath.abspath("//../")', "\\\\..\\")
|
tester('ntpath.abspath("//../")', "\\\\..\\")
|
||||||
tester('ntpath.abspath("//../..")', "\\\\..\\")
|
tester('ntpath.abspath("//../..")', "\\\\..\\")
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
Always return an absolute path for :func:`os.path.abspath` on Windows.
|
Loading…
Reference in New Issue
Block a user