mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-09-13 11:15:08 +00:00
Switch XM config file driver to use new domain APIs for XML generation
This commit is contained in:
parent
225fb3e93c
commit
547bd71a4a
@ -1,3 +1,11 @@
|
|||||||
|
Fri Jul 25 14:48:27 BST 2008 Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
|
||||||
|
* src/xend_internal.c, src/xend_internal.h: Remove the
|
||||||
|
sound_string_to_xml() and make xenDaemonParseSxprChar
|
||||||
|
non-static
|
||||||
|
* src/xm_internal.c: Switch config -> XML parser to use
|
||||||
|
the new domain APIs
|
||||||
|
|
||||||
Fri Jul 25 14:29:27 BST 2008 Daniel P. Berrange <berrange@redhat.com>
|
Fri Jul 25 14:29:27 BST 2008 Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
|
||||||
Prepare xm_internal driver for new domain XML apis.
|
Prepare xm_internal driver for new domain XML apis.
|
||||||
|
@ -828,68 +828,6 @@ int is_sound_model_conflict(const char *model, const char *soundstr) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* sound_string_to_xml:
|
|
||||||
* @soundstr : soundhw string for the form m1,m2,m3 ...
|
|
||||||
*
|
|
||||||
* Parses the passed string and returns a heap allocated string containing
|
|
||||||
* the valid libvirt soundxml. Must be free'd by caller.
|
|
||||||
*
|
|
||||||
* Returns NULL on fail, xml string on success (can be the empty string).
|
|
||||||
*/
|
|
||||||
char *sound_string_to_xml(const char *sound) {
|
|
||||||
|
|
||||||
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
|
||||||
char *tmp;
|
|
||||||
|
|
||||||
while (sound) {
|
|
||||||
int modelsize, valid, collision = 0;
|
|
||||||
char *model = NULL;
|
|
||||||
char *model_end = strchr(sound, ',');
|
|
||||||
modelsize = (model_end ? (model_end - sound) : strlen(sound));
|
|
||||||
|
|
||||||
if(!(model = strndup(sound, modelsize)))
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
if (!(valid = is_sound_model_valid(model))) {
|
|
||||||
// Check for magic 'all' model. If found, throw out current xml
|
|
||||||
// and build with all available models
|
|
||||||
if (STREQ(model, "all")) {
|
|
||||||
int i;
|
|
||||||
if (virBufferError(&buf)) {
|
|
||||||
VIR_FREE(model);
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
tmp = virBufferContentAndReset(&buf);
|
|
||||||
VIR_FREE(tmp);
|
|
||||||
|
|
||||||
for (i=0; i < sizeof(sound_models)/sizeof(*sound_models); ++i)
|
|
||||||
virBufferVSprintf(&buf, " <sound model='%s'/>\n",
|
|
||||||
sound_models[i]);
|
|
||||||
VIR_FREE(model);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (valid && model_end)
|
|
||||||
collision = is_sound_model_conflict(model, model_end);
|
|
||||||
if (valid && !collision)
|
|
||||||
virBufferVSprintf(&buf, " <sound model='%s'/>\n", model);
|
|
||||||
|
|
||||||
sound = (model_end ? ++model_end : NULL);
|
|
||||||
VIR_FREE(model);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (virBufferError(&buf))
|
|
||||||
goto error;
|
|
||||||
return virBufferContentAndReset(&buf);
|
|
||||||
|
|
||||||
error:
|
|
||||||
tmp = virBufferContentAndReset(&buf);
|
|
||||||
VIR_FREE(tmp);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* PUBLIC FUNCTIONS */
|
/* PUBLIC FUNCTIONS */
|
||||||
|
|
||||||
@ -1544,7 +1482,7 @@ error:
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static virDomainChrDefPtr
|
virDomainChrDefPtr
|
||||||
xenDaemonParseSxprChar(virConnectPtr conn,
|
xenDaemonParseSxprChar(virConnectPtr conn,
|
||||||
const char *value,
|
const char *value,
|
||||||
const char *tty)
|
const char *tty)
|
||||||
@ -1957,7 +1895,8 @@ cleanup:
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
|
||||||
|
int
|
||||||
xenDaemonParseSxprSound(virConnectPtr conn,
|
xenDaemonParseSxprSound(virConnectPtr conn,
|
||||||
virDomainDefPtr def,
|
virDomainDefPtr def,
|
||||||
const char *str)
|
const char *str)
|
||||||
|
@ -103,6 +103,16 @@ virDomainDefPtr
|
|||||||
xenDaemonParseSxprString(virConnectPtr conn,
|
xenDaemonParseSxprString(virConnectPtr conn,
|
||||||
const char *sexpr,
|
const char *sexpr,
|
||||||
int xendConfigVersion);
|
int xendConfigVersion);
|
||||||
|
|
||||||
|
int
|
||||||
|
xenDaemonParseSxprSound(virConnectPtr conn,
|
||||||
|
virDomainDefPtr def,
|
||||||
|
const char *str);
|
||||||
|
virDomainChrDefPtr
|
||||||
|
xenDaemonParseSxprChar(virConnectPtr conn,
|
||||||
|
const char *value,
|
||||||
|
const char *tty);
|
||||||
|
|
||||||
char *
|
char *
|
||||||
xenDaemonFormatSxpr(virConnectPtr conn,
|
xenDaemonFormatSxpr(virConnectPtr conn,
|
||||||
virDomainDefPtr def,
|
virDomainDefPtr def,
|
||||||
@ -110,7 +120,6 @@ xenDaemonFormatSxpr(virConnectPtr conn,
|
|||||||
|
|
||||||
int is_sound_model_valid(const char *model);
|
int is_sound_model_valid(const char *model);
|
||||||
int is_sound_model_conflict(const char *model, const char *soundstr);
|
int is_sound_model_conflict(const char *model, const char *soundstr);
|
||||||
char *sound_string_to_xml(const char *sound);
|
|
||||||
|
|
||||||
|
|
||||||
/* refactored ones */
|
/* refactored ones */
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user