diff options
-rw-r--r-- | meta/lib/oe/path.py | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/meta/lib/oe/path.py b/meta/lib/oe/path.py index 3c07df33d4..631c3b430c 100644 --- a/meta/lib/oe/path.py +++ b/meta/lib/oe/path.py | |||
@@ -65,7 +65,7 @@ def copytree(src, dst): | |||
65 | # This way we also preserve hardlinks between files in the tree. | 65 | # This way we also preserve hardlinks between files in the tree. |
66 | 66 | ||
67 | bb.utils.mkdirhier(dst) | 67 | bb.utils.mkdirhier(dst) |
68 | cmd = 'tar -cf - -C %s -p . | tar -xf - -C %s' % (src, dst) | 68 | cmd = "tar --xattrs --xattrs-include='*' -cf - -C %s -p . | tar --xattrs --xattrs-include='*' -xf - -C %s" % (src, dst) |
69 | subprocess.check_output(cmd, shell=True, stderr=subprocess.STDOUT) | 69 | subprocess.check_output(cmd, shell=True, stderr=subprocess.STDOUT) |
70 | 70 | ||
71 | def copyhardlinktree(src, dst): | 71 | def copyhardlinktree(src, dst): |
@@ -77,9 +77,14 @@ def copyhardlinktree(src, dst): | |||
77 | if (os.stat(src).st_dev == os.stat(dst).st_dev): | 77 | if (os.stat(src).st_dev == os.stat(dst).st_dev): |
78 | # Need to copy directories only with tar first since cp will error if two | 78 | # Need to copy directories only with tar first since cp will error if two |
79 | # writers try and create a directory at the same time | 79 | # writers try and create a directory at the same time |
80 | cmd = 'cd %s; find . -type d -print | tar -cf - -C %s -p --no-recursion --files-from - | tar -xf - -C %s' % (src, src, dst) | 80 | cmd = "cd %s; find . -type d -print | tar --xattrs --xattrs-include='*' -cf - -C %s -p --no-recursion --files-from - | tar --xattrs --xattrs-include='*' -xf - -C %s" % (src, src, dst) |
81 | subprocess.check_output(cmd, shell=True, stderr=subprocess.STDOUT) | 81 | subprocess.check_output(cmd, shell=True, stderr=subprocess.STDOUT) |
82 | cmd = 'cd %s; find . -print0 | cpio --null -pdlu %s' % (src, dst) | 82 | if os.path.isdir(src): |
83 | import glob | ||
84 | if len(glob.glob('%s/.??*' % src)) > 0: | ||
85 | src = src + '/.??* ' | ||
86 | src = src + '/*' | ||
87 | cmd = 'cp -afl --preserve=xattr %s %s' % (src, dst) | ||
83 | subprocess.check_output(cmd, shell=True, stderr=subprocess.STDOUT) | 88 | subprocess.check_output(cmd, shell=True, stderr=subprocess.STDOUT) |
84 | else: | 89 | else: |
85 | copytree(src, dst) | 90 | copytree(src, dst) |