Commit a16387ab authored by Ying Wang's avatar Ying Wang Committed by Giampaolo Rodola

bpo-24564: shutil.copystat(): ignore EINVAL on os.setxattr() (GH-13369)

parent 80878312
...@@ -309,7 +309,7 @@ if hasattr(os, 'listxattr'): ...@@ -309,7 +309,7 @@ if hasattr(os, 'listxattr'):
try: try:
names = os.listxattr(src, follow_symlinks=follow_symlinks) names = os.listxattr(src, follow_symlinks=follow_symlinks)
except OSError as e: except OSError as e:
if e.errno not in (errno.ENOTSUP, errno.ENODATA): if e.errno not in (errno.ENOTSUP, errno.ENODATA, errno.EINVAL):
raise raise
return return
for name in names: for name in names:
...@@ -317,7 +317,8 @@ if hasattr(os, 'listxattr'): ...@@ -317,7 +317,8 @@ if hasattr(os, 'listxattr'):
value = os.getxattr(src, name, follow_symlinks=follow_symlinks) value = os.getxattr(src, name, follow_symlinks=follow_symlinks)
os.setxattr(dst, name, value, follow_symlinks=follow_symlinks) os.setxattr(dst, name, value, follow_symlinks=follow_symlinks)
except OSError as e: except OSError as e:
if e.errno not in (errno.EPERM, errno.ENOTSUP, errno.ENODATA): if e.errno not in (errno.EPERM, errno.ENOTSUP, errno.ENODATA,
errno.EINVAL):
raise raise
else: else:
def _copyxattr(*args, **kwargs): def _copyxattr(*args, **kwargs):
......
:func:`shutil.copystat` now ignores :const:`errno.EINVAL` on :func:`os.setxattr` which may occur when copying files on filesystems without extended attributes support.
Original patch by Giampaolo Rodola, updated by Ying Wang.
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