]> git.proxmox.com Git - pve-container.git/commitdiff
Adjust snapshot_create and snapshot_prepare signatures
authorFabian Grünbichler <f.gruenbichler@proxmox.com>
Mon, 22 Feb 2016 12:08:57 +0000 (13:08 +0100)
committerDietmar Maurer <dietmar@proxmox.com>
Mon, 22 Feb 2016 14:52:04 +0000 (15:52 +0100)
Add new save_vmstate parameter to snapshot_create and
snapshot_prepare, like in QemuServer.pm
Also make snapshot_prepare and snapshot_commit proper subs.

src/PVE/API2/LXC/Snapshot.pm
src/PVE/LXC.pm
src/PVE/VZDump/LXC.pm

index 49fd4f56e70ad98984a7ffb20e70b57bcb39b3dd..4da2d87356ec5375838dde94814e1b96094901a1 100644 (file)
@@ -128,7 +128,7 @@ __PACKAGE__->register_method({
 
        my $realcmd = sub {
            PVE::Cluster::log_msg('info', $authuser, "snapshot container $vmid: $snapname");
-           PVE::LXC::snapshot_create($vmid, $snapname, $param->{description});
+           PVE::LXC::snapshot_create($vmid, $snapname, 0, $param->{description});
        };
 
        return $rpcenv->fork_worker('pctsnapshot', $vmid, $authuser, $realcmd);
index a1fb74627c663092ea5be5f531b0638bf8b9284f..2aaa6a7a74b4f4a0539d48fd6394140f9a1a4b7d 100644 (file)
@@ -1748,8 +1748,8 @@ my $snapshot_copy_config = sub {
     }
 };
 
-my $snapshot_prepare = sub {
-    my ($vmid, $snapname, $comment) = @_;
+sub snapshot_prepare {
+    my ($vmid, $snapname, $save_vmstate, $comment) = @_;
 
     my $snap;
 
@@ -1786,9 +1786,9 @@ my $snapshot_prepare = sub {
     lock_config($vmid, $updatefn);
 
     return $snap;
-};
+}
 
-my $snapshot_commit = sub {
+sub snapshot_commit {
     my ($vmid, $snapname) = @_;
 
     my $updatefn = sub {
@@ -1812,8 +1812,8 @@ my $snapshot_commit = sub {
        write_config($vmid, $conf);
     };
 
-    lock_config($vmid ,$updatefn);
-};
+    lock_config($vmid$updatefn);
+}
 
 sub has_feature {
     my ($feature, $conf, $storecfg, $snapname) = @_;
@@ -1908,9 +1908,9 @@ sub sync_container_namespace {
 }
 
 sub snapshot_create {
-    my ($vmid, $snapname, $comment) = @_;
+    my ($vmid, $snapname, $save_vmstate, $comment) = @_;
 
-    my $snap = &$snapshot_prepare($vmid, $snapname, $comment);
+    my $snap = snapshot_prepare($vmid, $snapname, $save_vmstate, $comment);
 
     my $conf = load_config($vmid);
 
@@ -1947,7 +1947,7 @@ sub snapshot_create {
        die "$err\n";
     }
 
-    &$snapshot_commit($vmid, $snapname);
+    snapshot_commit($vmid, $snapname);
 }
 
 # Note: $drivehash is only set when called from snapshot_create.
index 0979f15db2b3967d264a45e5e45b847e659a45fd..1d24036e92aed7a32de35ea9562cad93ae48b07a 100644 (file)
@@ -211,7 +211,7 @@ sub snapshot {
     $self->loginfo("create storage snapshot 'vzdump'");
 
     # todo: freeze/unfreeze if we have more than one volid
-    PVE::LXC::snapshot_create($vmid, 'vzdump', "vzdump backup snapshot");
+    PVE::LXC::snapshot_create($vmid, 'vzdump', 0, "vzdump backup snapshot");
     $task->{cleanup}->{remove_snapshot} = 1;
     
     # reload config