mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-10 05:17:59 +03:00
virDomainSnapshotDefParse: Decouple parsing of memory snapshot config
Separate the steps of parsing the memory snapshot config from the post-processing and validation code. The upcoming patch refactoring the parsing will be simpler. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
parent
8a5a096d72
commit
5984e5e6fd
@ -317,27 +317,37 @@ virDomainSnapshotDefParse(xmlXPathContextPtr ctxt,
|
|||||||
memorySnapshot);
|
memorySnapshot);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (def->memorysnapshotfile &&
|
|
||||||
def->memory != VIR_DOMAIN_SNAPSHOT_LOCATION_EXTERNAL) {
|
|
||||||
virReportError(VIR_ERR_XML_ERROR,
|
|
||||||
_("memory filename '%s' requires external snapshot"),
|
|
||||||
def->memorysnapshotfile);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
if (!def->memorysnapshotfile &&
|
|
||||||
def->memory == VIR_DOMAIN_SNAPSHOT_LOCATION_EXTERNAL) {
|
|
||||||
virReportError(VIR_ERR_XML_ERROR, "%s",
|
|
||||||
_("external memory snapshots require a filename"));
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
} else if (def->memorysnapshotfile) {
|
|
||||||
def->memory = VIR_DOMAIN_SNAPSHOT_LOCATION_EXTERNAL;
|
|
||||||
} else if (flags & VIR_DOMAIN_SNAPSHOT_PARSE_REDEFINE) {
|
|
||||||
def->memory = (offline ?
|
|
||||||
VIR_DOMAIN_SNAPSHOT_LOCATION_NO :
|
|
||||||
VIR_DOMAIN_SNAPSHOT_LOCATION_INTERNAL);
|
|
||||||
}
|
}
|
||||||
if (offline && def->memory &&
|
|
||||||
|
if (def->memory == VIR_DOMAIN_SNAPSHOT_LOCATION_DEFAULT) {
|
||||||
|
if (def->memorysnapshotfile) {
|
||||||
|
def->memory = VIR_DOMAIN_SNAPSHOT_LOCATION_EXTERNAL;
|
||||||
|
} else if (flags & VIR_DOMAIN_SNAPSHOT_PARSE_REDEFINE) {
|
||||||
|
if (offline) {
|
||||||
|
def->memory = VIR_DOMAIN_SNAPSHOT_LOCATION_NO;
|
||||||
|
} else {
|
||||||
|
def->memory = VIR_DOMAIN_SNAPSHOT_LOCATION_INTERNAL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (def->memorysnapshotfile &&
|
||||||
|
def->memory != VIR_DOMAIN_SNAPSHOT_LOCATION_EXTERNAL) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR,
|
||||||
|
_("memory filename '%s' requires external snapshot"),
|
||||||
|
def->memorysnapshotfile);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!def->memorysnapshotfile &&
|
||||||
|
def->memory == VIR_DOMAIN_SNAPSHOT_LOCATION_EXTERNAL) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
|
_("external memory snapshots require a filename"));
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (offline &&
|
||||||
|
def->memory != VIR_DOMAIN_SNAPSHOT_LOCATION_DEFAULT &&
|
||||||
def->memory != VIR_DOMAIN_SNAPSHOT_LOCATION_NO) {
|
def->memory != VIR_DOMAIN_SNAPSHOT_LOCATION_NO) {
|
||||||
virReportError(VIR_ERR_XML_ERROR, "%s",
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
_("memory state cannot be saved with offline or "
|
_("memory state cannot be saved with offline or "
|
||||||
|
Loading…
Reference in New Issue
Block a user