mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 14:05:18 +00:00
virDomainGraphicsDefParseXMLSpice: Use virXMLProp*
Signed-off-by: Tim Wiederhake <twiederh@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
4ecf7ff393
commit
bb94b3d28d
@ -12653,25 +12653,11 @@ virDomainGraphicsDefParseXMLSpice(virDomainGraphicsDef *def,
|
|||||||
xmlXPathContextPtr ctxt,
|
xmlXPathContextPtr ctxt,
|
||||||
unsigned int flags)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
int defaultModeVal;
|
|
||||||
g_autofree xmlNodePtr *node_list = NULL;
|
g_autofree xmlNodePtr *node_list = NULL;
|
||||||
int n = 0;
|
int n = 0;
|
||||||
size_t i = 0;
|
size_t i = 0;
|
||||||
int value = 0;
|
virTristateBool autoport = VIR_TRISTATE_BOOL_NO;
|
||||||
g_autofree char *port = virXMLPropString(node, "port");
|
xmlNodePtr cur;
|
||||||
g_autofree char *tlsPort = virXMLPropString(node, "tlsPort");
|
|
||||||
g_autofree char *autoport = virXMLPropString(node, "autoport");
|
|
||||||
g_autofree char *defaultMode = virXMLPropString(node, "defaultMode");
|
|
||||||
g_autofree char *compression = NULL;
|
|
||||||
g_autofree char *jpeg_compression = NULL;
|
|
||||||
g_autofree char *zlib_compression = NULL;
|
|
||||||
g_autofree char *playback_compression = NULL;
|
|
||||||
g_autofree char *streaming_mode = NULL;
|
|
||||||
g_autofree char *copypaste = NULL;
|
|
||||||
g_autofree char *filetransfer_enable = NULL;
|
|
||||||
g_autofree char *gl_enable = NULL;
|
|
||||||
g_autofree char *mouse_mode = NULL;
|
|
||||||
g_autofree char *rendernode = NULL;
|
|
||||||
VIR_XPATH_NODE_AUTORESTORE(ctxt)
|
VIR_XPATH_NODE_AUTORESTORE(ctxt)
|
||||||
|
|
||||||
ctxt->node = node;
|
ctxt->node = node;
|
||||||
@ -12679,40 +12665,26 @@ virDomainGraphicsDefParseXMLSpice(virDomainGraphicsDef *def,
|
|||||||
if (virDomainGraphicsListensParseXML(def, node, ctxt, flags) < 0)
|
if (virDomainGraphicsListensParseXML(def, node, ctxt, flags) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (port) {
|
def->data.spice.port = 0;
|
||||||
if (virStrToLong_i(port, NULL, 10, &def->data.spice.port) < 0) {
|
if (virXMLPropInt(node, "port", 10, VIR_XML_PROP_NONE,
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
&def->data.spice.port) < 0)
|
||||||
_("cannot parse spice port %s"), port);
|
return -1;
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
def->data.spice.port = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (tlsPort) {
|
def->data.spice.tlsPort = 0;
|
||||||
if (virStrToLong_i(tlsPort, NULL, 10, &def->data.spice.tlsPort) < 0) {
|
if (virXMLPropInt(node, "tlsPort", 10, VIR_XML_PROP_NONE,
|
||||||
virReportError(VIR_ERR_INTERNAL_ERROR,
|
&def->data.spice.tlsPort) < 0)
|
||||||
_("cannot parse spice tlsPort %s"), tlsPort);
|
return -1;
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
def->data.spice.tlsPort = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (STREQ_NULLABLE(autoport, "yes"))
|
if (virXMLPropTristateBool(node, "autoport", VIR_XML_PROP_NONE,
|
||||||
def->data.spice.autoport = true;
|
&autoport) < 0)
|
||||||
|
return -1;
|
||||||
|
def->data.spice.autoport = autoport == VIR_TRISTATE_BOOL_YES;
|
||||||
|
|
||||||
def->data.spice.defaultMode = VIR_DOMAIN_GRAPHICS_SPICE_CHANNEL_MODE_ANY;
|
def->data.spice.defaultMode = VIR_DOMAIN_GRAPHICS_SPICE_CHANNEL_MODE_ANY;
|
||||||
|
if (virXMLPropEnum(node, "defaultMode",
|
||||||
if (defaultMode) {
|
virDomainGraphicsSpiceChannelModeTypeFromString,
|
||||||
if ((defaultModeVal = virDomainGraphicsSpiceChannelModeTypeFromString(defaultMode)) < 0) {
|
VIR_XML_PROP_NONE, &def->data.spice.defaultMode) < 0)
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
return -1;
|
||||||
_("unknown default spice channel mode %s"),
|
|
||||||
defaultMode);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
def->data.spice.defaultMode = defaultModeVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (def->data.spice.port == -1 && def->data.spice.tlsPort == -1) {
|
if (def->data.spice.port == -1 && def->data.spice.tlsPort == -1) {
|
||||||
/* Legacy compat syntax, used -1 for auto-port */
|
/* Legacy compat syntax, used -1 for auto-port */
|
||||||
@ -12750,95 +12722,90 @@ virDomainGraphicsDefParseXMLSpice(virDomainGraphicsDef *def,
|
|||||||
def->data.spice.channels[name] = mode;
|
def->data.spice.channels[name] = mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((compression = virXPathString("string(./image/@compression)", ctxt))) {
|
if ((cur = virXPathNode("./image", ctxt))) {
|
||||||
if ((value =
|
virDomainGraphicsSpiceImageCompression compression;
|
||||||
virDomainGraphicsSpiceImageCompressionTypeFromString(compression)) <= 0) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
if (virXMLPropEnum(cur, "compression",
|
||||||
_("unknown spice image compression %s"), compression);
|
virDomainGraphicsSpiceImageCompressionTypeFromString,
|
||||||
|
VIR_XML_PROP_REQUIRED | VIR_XML_PROP_NONZERO,
|
||||||
|
&compression) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.image = value;
|
def->data.spice.image = compression;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((jpeg_compression = virXPathString("string(./jpeg/@compression)", ctxt))) {
|
if ((cur = virXPathNode("./jpeg", ctxt))) {
|
||||||
if ((value =
|
virDomainGraphicsSpiceJpegCompression compression;
|
||||||
virDomainGraphicsSpiceJpegCompressionTypeFromString(jpeg_compression)) <= 0) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
if (virXMLPropEnum(cur, "compression",
|
||||||
_("unknown spice jpeg compression %s"),
|
virDomainGraphicsSpiceJpegCompressionTypeFromString,
|
||||||
jpeg_compression);
|
VIR_XML_PROP_REQUIRED | VIR_XML_PROP_NONZERO,
|
||||||
|
&compression) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.jpeg = value;
|
def->data.spice.jpeg = compression;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((zlib_compression = virXPathString("string(./zlib/@compression)", ctxt))) {
|
if ((cur = virXPathNode("./zlib", ctxt))) {
|
||||||
if ((value =
|
virDomainGraphicsSpiceZlibCompression compression;
|
||||||
virDomainGraphicsSpiceZlibCompressionTypeFromString(zlib_compression)) <= 0) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
if (virXMLPropEnum(cur, "compression",
|
||||||
_("unknown spice zlib compression %s"),
|
virDomainGraphicsSpiceZlibCompressionTypeFromString,
|
||||||
zlib_compression);
|
VIR_XML_PROP_REQUIRED | VIR_XML_PROP_NONZERO,
|
||||||
|
&compression) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.zlib = value;
|
def->data.spice.zlib = compression;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((playback_compression = virXPathString("string(./playback/@compression)", ctxt))) {
|
if ((cur = virXPathNode("./playback", ctxt))) {
|
||||||
if ((value = virTristateSwitchTypeFromString(playback_compression)) <= 0) {
|
if (virXMLPropTristateSwitch(cur, "compression",
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
VIR_XML_PROP_REQUIRED,
|
||||||
_("unknown spice playback compression"));
|
&def->data.spice.playback) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.playback = value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((streaming_mode = virXPathString("string(./streaming/@mode)", ctxt))) {
|
if ((cur = virXPathNode("./streaming", ctxt))) {
|
||||||
if ((value =
|
virDomainGraphicsSpiceStreamingMode mode;
|
||||||
virDomainGraphicsSpiceStreamingModeTypeFromString(streaming_mode)) <= 0) {
|
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
|
if (virXMLPropEnum(cur, "mode",
|
||||||
_("unknown spice streaming mode"));
|
virDomainGraphicsSpiceStreamingModeTypeFromString,
|
||||||
|
VIR_XML_PROP_REQUIRED | VIR_XML_PROP_NONZERO,
|
||||||
|
&mode) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.streaming = value;
|
def->data.spice.streaming = mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((copypaste = virXPathString("string(./clipboard/@copypaste)", ctxt))) {
|
if ((cur = virXPathNode("./clipboard", ctxt))) {
|
||||||
if ((value = virTristateBoolTypeFromString(copypaste)) <= 0) {
|
if (virXMLPropTristateBool(cur, "copypaste",
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
VIR_XML_PROP_REQUIRED,
|
||||||
_("unknown copypaste value '%s'"), copypaste);
|
&def->data.spice.copypaste) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.copypaste = value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((filetransfer_enable = virXPathString("string(./filetransfer/@enable)", ctxt))) {
|
if ((cur = virXPathNode("./filetransfer", ctxt))) {
|
||||||
if ((value = virTristateBoolTypeFromString(filetransfer_enable)) <= 0) {
|
if (virXMLPropTristateBool(cur, "enable",
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
VIR_XML_PROP_REQUIRED,
|
||||||
_("unknown enable value '%s'"),
|
&def->data.spice.filetransfer) < 0)
|
||||||
filetransfer_enable);
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.filetransfer = value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((gl_enable = virXPathString("string(./gl/@enable)", ctxt))) {
|
if ((cur = virXPathNode("./gl", ctxt))) {
|
||||||
rendernode = virXPathString("string(./gl/@rendernode)", ctxt);
|
def->data.spice.rendernode = virXMLPropString(cur, "rendernode");
|
||||||
|
|
||||||
if ((value = virTristateBoolTypeFromString(gl_enable)) <= 0) {
|
if (virXMLPropTristateBool(cur, "enable",
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
VIR_XML_PROP_REQUIRED,
|
||||||
_("unknown enable value '%s'"), gl_enable);
|
&def->data.spice.gl) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.gl = value;
|
|
||||||
def->data.spice.rendernode = g_steal_pointer(&rendernode);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((mouse_mode = virXPathString("string(./mouse/@mode)", ctxt))) {
|
if ((cur = virXPathNode("./mouse", ctxt))) {
|
||||||
if ((value = virDomainGraphicsSpiceMouseModeTypeFromString(mouse_mode)) <= 0) {
|
if (virXMLPropEnum(cur, "mode",
|
||||||
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
virDomainGraphicsSpiceMouseModeTypeFromString,
|
||||||
_("unknown mouse mode value '%s'"), mouse_mode);
|
VIR_XML_PROP_REQUIRED | VIR_XML_PROP_NONZERO,
|
||||||
|
&def->data.spice.mousemode) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
def->data.spice.mousemode = value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user