mirror of
https://github.com/python/cpython.git
synced 2025-07-13 22:35:18 +00:00
bpo-26978: Implement pathlib.Path.link_to (Using os.link) (GH-12990)
This commit is contained in:
parent
f0900199d5
commit
6b5b013bcc
5 changed files with 42 additions and 0 deletions
|
@ -1054,6 +1054,13 @@ call fails (for example because the path doesn't exist).
|
||||||
use :func:`Path.rmdir` instead.
|
use :func:`Path.rmdir` instead.
|
||||||
|
|
||||||
|
|
||||||
|
.. method:: Path.link_to(target)
|
||||||
|
|
||||||
|
Create a hard link pointing to a path named *target*.
|
||||||
|
|
||||||
|
.. versionchanged:: 3.8
|
||||||
|
|
||||||
|
|
||||||
.. method:: Path.write_bytes(data)
|
.. method:: Path.write_bytes(data)
|
||||||
|
|
||||||
Open the file pointed to in bytes mode, write *data* to it, and close the
|
Open the file pointed to in bytes mode, write *data* to it, and close the
|
||||||
|
|
|
@ -369,6 +369,10 @@ pathlib
|
||||||
contain characters unrepresentable at the OS level.
|
contain characters unrepresentable at the OS level.
|
||||||
(Contributed by Serhiy Storchaka in :issue:`33721`.)
|
(Contributed by Serhiy Storchaka in :issue:`33721`.)
|
||||||
|
|
||||||
|
Added :meth:`pathlib.Path.link_to()` which creates a hard link pointing
|
||||||
|
to a path.
|
||||||
|
(Contributed by Joannah Nanjekye in :issue:`26978`)
|
||||||
|
|
||||||
|
|
||||||
socket
|
socket
|
||||||
------
|
------
|
||||||
|
|
|
@ -411,6 +411,8 @@ class _NormalAccessor(_Accessor):
|
||||||
|
|
||||||
unlink = os.unlink
|
unlink = os.unlink
|
||||||
|
|
||||||
|
link_to = os.link
|
||||||
|
|
||||||
rmdir = os.rmdir
|
rmdir = os.rmdir
|
||||||
|
|
||||||
rename = os.rename
|
rename = os.rename
|
||||||
|
@ -1303,6 +1305,14 @@ class Path(PurePath):
|
||||||
self._raise_closed()
|
self._raise_closed()
|
||||||
return self._accessor.lstat(self)
|
return self._accessor.lstat(self)
|
||||||
|
|
||||||
|
def link_to(self, target):
|
||||||
|
"""
|
||||||
|
Create a hard link pointing to a path named target.
|
||||||
|
"""
|
||||||
|
if self._closed:
|
||||||
|
self._raise_closed()
|
||||||
|
self._accessor.link_to(self, target)
|
||||||
|
|
||||||
def rename(self, target):
|
def rename(self, target):
|
||||||
"""
|
"""
|
||||||
Rename this path to the given path.
|
Rename this path to the given path.
|
||||||
|
|
|
@ -1643,6 +1643,25 @@ class _BasePathTest(object):
|
||||||
self.assertFileNotFound(p.stat)
|
self.assertFileNotFound(p.stat)
|
||||||
self.assertFileNotFound(p.unlink)
|
self.assertFileNotFound(p.unlink)
|
||||||
|
|
||||||
|
def test_link_to(self):
|
||||||
|
P = self.cls(BASE)
|
||||||
|
p = P / 'fileA'
|
||||||
|
size = p.stat().st_size
|
||||||
|
# linking to another path.
|
||||||
|
q = P / 'dirA' / 'fileAA'
|
||||||
|
try:
|
||||||
|
p.link_to(q)
|
||||||
|
except PermissionError as e:
|
||||||
|
self.skipTest('os.link(): %s' % e)
|
||||||
|
self.assertEqual(q.stat().st_size, size)
|
||||||
|
self.assertEqual(os.path.samefile(p, q), True)
|
||||||
|
self.assertTrue(p.stat)
|
||||||
|
# Linking to a str of a relative path.
|
||||||
|
r = rel_join('fileAAA')
|
||||||
|
q.link_to(r)
|
||||||
|
self.assertEqual(os.stat(r).st_size, size)
|
||||||
|
self.assertTrue(q.stat)
|
||||||
|
|
||||||
def test_rename(self):
|
def test_rename(self):
|
||||||
P = self.cls(BASE)
|
P = self.cls(BASE)
|
||||||
p = P / 'fileA'
|
p = P / 'fileA'
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
`pathlib.path.link_to()` is now implemented. It creates a hard link pointing
|
||||||
|
to a path.
|
Loading…
Add table
Add a link
Reference in a new issue