diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2012-10-05 15:09:02 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2012-10-18 12:13:46 +0100 |
commit | e8338b7b143a451be7dc56c9acef7e5dbf2220b8 (patch) | |
tree | ba7470f60bf7544e7379fb4ca299160ec4cb96d9 | |
parent | 25e060dde108a3d534be78f84a481ae7aeaec915 (diff) | |
download | openembedded-core-contrib-e8338b7b143a451be7dc56c9acef7e5dbf2220b8.tar.gz |
scripts/cp-noerror: Copy the code from shutils.copytree, update not to error if the mkdir fails
(From OE-Core rev: 08542718504d2b53d140a9e6be73c84cc0e047e0)
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rwxr-xr-x | scripts/cp-noerror | 30 |
1 files changed, 29 insertions, 1 deletions
diff --git a/scripts/cp-noerror b/scripts/cp-noerror index fdb3d2d19a..f0cd243586 100755 --- a/scripts/cp-noerror +++ b/scripts/cp-noerror @@ -5,10 +5,38 @@ # import sys +import os import shutil +def copytree(src, dst, symlinks=False, ignore=None): + """Based on shutil.copytree""" + names = os.listdir(src) + try: + os.makedirs(dst) + except OSError: + # Already exists + pass + errors = [] + for name in names: + srcname = os.path.join(src, name) + dstname = os.path.join(dst, name) + try: + shutil.copy2(srcname, dstname) + # catch the Error from the recursive copytree so that we can + # continue with other files + except shutil.Error, err: + errors.extend(err.args[0]) + except EnvironmentError, why: + errors.append((srcname, dstname, str(why))) + try: + shutil.copystat(src, dst) + except OSError, why: + errors.extend((src, dst, str(why))) + if errors: + raise shutil.Error, errors + try: - shutil.copytree(sys.argv[1], sys.argv[2]) + copytree(sys.argv[1], sys.argv[2]) except shutil.Error: pass |