|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [PATCH 2/2] tools/xl: Allow specifying JSON for domain configuration file format
JSON is currently used when saving domains to mass storage. Being able
to use JSON as the normal input to `xl create` has potential to be
valuable. Add the functionality.
Signed-off-by: Elliott Mitchell <ehem+xen@xxxxxxx>
---
tools/xl/xl.h | 5 +++++
tools/xl/xl_cmdtable.c | 2 ++
tools/xl/xl_vmcontrol.c | 13 +++++++++++--
3 files changed, 18 insertions(+), 2 deletions(-)
diff --git a/tools/xl/xl.h b/tools/xl/xl.h
index c5c4bedbdd..a0c03f96df 100644
--- a/tools/xl/xl.h
+++ b/tools/xl/xl.h
@@ -49,6 +49,11 @@ struct domain_create {
int migrate_fd; /* -1 means none */
int send_back_fd; /* -1 means none */
char **migration_domname_r; /* from malloc */
+ enum {
+ FORMAT_DEFAULT,
+ FORMAT_JSON,
+ FORMAT_LEGACY,
+ } format;
};
int create_domain(struct domain_create *dom_info);
diff --git a/tools/xl/xl_cmdtable.c b/tools/xl/xl_cmdtable.c
index f546beaceb..04d579a596 100644
--- a/tools/xl/xl_cmdtable.c
+++ b/tools/xl/xl_cmdtable.c
@@ -31,6 +31,8 @@ const struct cmd_spec cmd_table[] = {
"-h Print this help.\n"
"-p Leave the domain paused after it is created.\n"
"-f FILE, --defconfig=FILE\n Use the given
configuration file.\n"
+ "-j, --json Interpret configuration file as JSON format\n"
+ "-J Use traditional configuration file format
(current default)\n"
"-n, --dryrun Dry run - prints the resulting configuration\n"
" (deprecated in favour of global -N option).\n"
"-q, --quiet Quiet.\n"
diff --git a/tools/xl/xl_vmcontrol.c b/tools/xl/xl_vmcontrol.c
index 2ec4140258..41bd919d1d 100644
--- a/tools/xl/xl_vmcontrol.c
+++ b/tools/xl/xl_vmcontrol.c
@@ -789,7 +789,7 @@ int create_domain(struct domain_create *dom_info)
extra_config);
}
config_source=config_file;
- config_in_json = false;
+ config_in_json = dom_info.format == FORMAT_JSON ? true : false;
} else {
if (!config_data) {
fprintf(stderr, "Config file not specified and"
@@ -1173,6 +1173,7 @@ int main_create(int argc, char **argv)
{"defconfig", 1, 0, 'f'},
{"dryrun", 0, 0, 'n'},
{"ignore-global-affinity-masks", 0, 0, 'i'},
+ {"json", 0, 0, 'j'},
{"quiet", 0, 0, 'q'},
{"vncviewer", 0, 0, 'V'},
{"vncviewer-autopass", 0, 0, 'A'},
@@ -1181,18 +1182,23 @@ int main_create(int argc, char **argv)
dom_info.extra_config = NULL;
+ dom_info.format = FORMAT_DEFAULT;
+
if (argv[1] && argv[1][0] != '-' && !strchr(argv[1], '=')) {
filename = argv[1];
argc--; argv++;
}
- SWITCH_FOREACH_OPT(opt, "Ffnq:AVcdeip", opts, "create", 0) {
+ SWITCH_FOREACH_OPT(opt, "FJfjnq:AVcdeip", opts, "create", 0) {
case 'A':
vnc = vncautopass = 1;
break;
case 'F':
daemonize = 0;
break;
+ case 'J':
+ dom_info.format = FORMAT_LEGACY;
+ break;
case 'V':
vnc = 1;
break;
@@ -1212,6 +1218,9 @@ int main_create(int argc, char **argv)
case 'i':
ignore_masks = 1;
break;
+ case 'j':
+ dom_info.format = FORMAT_JSON;
+ break;
case 'n':
dryrun_only = 1;
break;
--
2.30.2
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |