From: Christian Brauner Date: Tue, 30 May 2017 02:35:17 +0000 (+0200) Subject: confile: config_start() X-Git-Tag: lxc-2.1.0~110^2~125 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=ebb80f95b8dd2ad5fdff107a040699cd7a21089b;p=thirdparty%2Flxc.git confile: config_start() Signed-off-by: Christian Brauner --- diff --git a/src/lxc/confile.c b/src/lxc/confile.c index b9a457209..5ad386a5a 100644 --- a/src/lxc/confile.c +++ b/src/lxc/confile.c @@ -1263,28 +1263,47 @@ static int config_pts(const char *key, const char *value, } static int config_start(const char *key, const char *value, - struct lxc_conf *lxc_conf) + struct lxc_conf *lxc_conf) { - if (config_value_empty(value)) - return 0; + bool is_empty; + + is_empty = config_value_empty(value); + + if (strcmp(key, "lxc.start.auto") == 0) { + /* Set config value to default. */ + if (is_empty) { + lxc_conf->start_auto = 0; + return 0; + } - if(strcmp(key, "lxc.start.auto") == 0) { + /* Parse new config value. */ if (lxc_safe_uint(value, &lxc_conf->start_auto) < 0) return -1; + if (lxc_conf->start_auto > 1) return -1; + return 0; + } else if (strcmp(key, "lxc.start.delay") == 0) { + /* Set config value to default. */ + if (is_empty) { + lxc_conf->start_delay = 0; + return 0; + } + + /* Parse new config value. */ + return lxc_safe_uint(value, &lxc_conf->start_delay); + } else if (strcmp(key, "lxc.start.order") == 0) { + /* Set config value to default. */ + if (is_empty) { + lxc_conf->start_order = 0; + return 0; + } + + /* Parse new config value. */ + return lxc_safe_int(value, &lxc_conf->start_order); } - else if (strcmp(key, "lxc.start.delay") == 0) { - if (lxc_safe_uint(value, &lxc_conf->start_delay) < 0) - return -1; - return 0; - } - else if (strcmp(key, "lxc.start.order") == 0) { - if (lxc_safe_int(value, &lxc_conf->start_order) < 0) - return -1; - return 0; - } + SYSERROR("Unknown key: %s", key); return -1; }