diff options
| -rw-r--r-- | bitbake/lib/bb/utils.py | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/bitbake/lib/bb/utils.py b/bitbake/lib/bb/utils.py index 44419d8f2a..a6f1337114 100644 --- a/bitbake/lib/bb/utils.py +++ b/bitbake/lib/bb/utils.py | |||
| @@ -773,16 +773,23 @@ def copyfile(src, dest, newmtime = None, sstat = None): | |||
| 773 | return False | 773 | return False |
| 774 | 774 | ||
| 775 | if stat.S_ISREG(sstat[stat.ST_MODE]): | 775 | if stat.S_ISREG(sstat[stat.ST_MODE]): |
| 776 | os.chmod(src, stat.S_IRUSR) # Make sure we can read it | 776 | try: |
| 777 | try: # For safety copy then move it over. | 777 | srcchown = False |
| 778 | if not os.access(src, os.R_OK): | ||
| 779 | # Make sure we can read it | ||
| 780 | srcchown = True | ||
| 781 | os.chmod(src, sstat[stat.ST_MODE] | stat.S_IRUSR) | ||
| 782 | |||
| 783 | # For safety copy then move it over. | ||
| 778 | shutil.copyfile(src, dest + "#new") | 784 | shutil.copyfile(src, dest + "#new") |
| 779 | os.rename(dest + "#new", dest) | 785 | os.rename(dest + "#new", dest) |
| 780 | except Exception as e: | 786 | except Exception as e: |
| 781 | print('copyfile: copy', src, '->', dest, 'failed.', e) | 787 | print('copyfile: copy', src, '->', dest, 'failed.', e) |
| 782 | return False | 788 | return False |
| 783 | finally: | 789 | finally: |
| 784 | os.chmod(src, sstat[stat.ST_MODE]) | 790 | if srcchown: |
| 785 | os.utime(src, (sstat[stat.ST_ATIME], sstat[stat.ST_MTIME])) | 791 | os.chmod(src, sstat[stat.ST_MODE]) |
| 792 | os.utime(src, (sstat[stat.ST_ATIME], sstat[stat.ST_MTIME])) | ||
| 786 | 793 | ||
| 787 | else: | 794 | else: |
| 788 | #we don't yet handle special, so we need to fall back to /bin/mv | 795 | #we don't yet handle special, so we need to fall back to /bin/mv |
