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:03:27 +0100 |
commit | 08542718504d2b53d140a9e6be73c84cc0e047e0 (patch) | |
tree | 58b6bd74e071c6d7d75f5384e7d39c3521ee6912 | |
parent | 71a3ba536d022eea3a199cf4d6c5c791d91603a0 (diff) | |
download | openembedded-core-08542718504d2b53d140a9e6be73c84cc0e047e0.tar.gz openembedded-core-08542718504d2b53d140a9e6be73c84cc0e047e0.tar.bz2 openembedded-core-08542718504d2b53d140a9e6be73c84cc0e047e0.zip |
scripts/cp-noerror: Copy the code from shutils.copytree, update not to error if the mkdir fails
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 |