From fa35b1dd55a266985823194de846138456a10b45 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Mon, 25 Nov 2013 17:15:45 +0100 Subject: [PATCH] qvm-tools: add --root-move-from/--root-copy-from options to qvm-create --- qvm-tools/qvm-create | 22 +++++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) diff --git a/qvm-tools/qvm-create b/qvm-tools/qvm-create index bfed6e2b..f51cccee 100755 --- a/qvm-tools/qvm-create +++ b/qvm-tools/qvm-create @@ -46,8 +46,10 @@ def main(): help="Create NetVM") parser.add_option ("-s", "--standalone", action="store_true", dest="standalone", default=False, help="Create standalone VM - independent of template ") - parser.add_option ("-r", "--root", dest="root", default=None, + parser.add_option ("-R", "--root-move-from", dest="root_move", default=None, help="Use provided root.img instead of default/empty one (file will be MOVED)") + parser.add_option ("-r", "--root-copy-from", dest="root_copy", default=None, + help="Use provided root.img instead of default/empty one (file will be COPIED)") parser.add_option ("-m", "--mem", dest="mem", default=None, help="Initial memory size (in MB)") parser.add_option ("-c", "--vcpus", dest="vcpus", default=None, @@ -95,7 +97,7 @@ def main(): if options.hvm_template: options.standalone = True - if not options.standalone and options.root is not None: + if not options.standalone and any([options.root_copy, options.root_move]): print >> sys.stderr, "root.img can be specified only for standalone VMs" exit (1) @@ -103,9 +105,15 @@ def main(): print >> sys.stderr, "Template VM cannot be based on another template" exit (1) + if options.root_copy and options.root_move: + print >> sys.stderr, "Only one of --root-move-from and --root-copy from can be specified" + exit(1) + if options.root_copy is not None and not os.path.exists(options.root_copy): + print >> sys.stderr, "File specified as root.img does not exists" + exit (1) - if options.root is not None and not os.path.exists(options.root): + if options.root_move is not None and not os.path.exists(options.root_move): print >> sys.stderr, "File specified as root.img does not exists" exit (1) @@ -172,9 +180,13 @@ def main(): try: vm.create_on_disk(verbose=options.verbose, source_template=template) - if options.root: + if options.root_move: os.unlink(vm.root_img) - os.rename(options.root, vm.root_img) + os.rename(options.root_move, vm.root_img) + elif options.root_copy: + os.unlink(vm.root_img) + # use "cp" to preserve sparse file + subprocess.check_call(["cp", options.root_copy, vm.root_img]) except (IOError, OSError) as err: print >> sys.stderr, "ERROR: {0}".format(err)