switch to shutil.copy rather than os.system(cp)

reviewable/pr18780/r1
Dave Hatton 13 years ago
parent 8b15c93355
commit 2454c6c12d

11
copy

@ -21,6 +21,7 @@
import sys import sys
import os import os
import shlex import shlex
import shutil
import syslog import syslog
# =========================================== # ===========================================
@ -85,10 +86,16 @@ if os.path.exists(dest):
md5sum_dest = md5_sum(dest) md5sum_dest = md5_sum(dest)
else: else:
if not os.access(os.path.dirname(dest), os.W_OK): if not os.access(os.path.dirname(dest), os.W_OK):
exit_kv(rc=1, failed=1, msg="Destination %s not writable" % (dest)) exit_kv(rc=1, failed=1, msg="Destination %s not writable" % (os.path.dirname(dest)))
if md5sum_src != md5sum_dest: if md5sum_src != md5sum_dest:
os.system("cp %s %s" % (src, dest)) # was os.system("cp %s %s" % (src, dest))
try:
shutil.copyfile(src, dest)
except shutil.Error:
exit_kv(rc=1, failed=1, msg="failed to copy: %s and %s are the same" % (src, dest))
except IOError:
exit_kv(rc=1, failed=1, msg="failed to copy: %s to %s" % (src, dest))
changed = True changed = True
else: else:
changed = False changed = False

Loading…
Cancel
Save