diff options
author | Max Romanov <max.romanov@nginx.com> | 2018-01-18 09:08:25 +0300 |
---|---|---|
committer | Max Romanov <max.romanov@nginx.com> | 2018-01-18 09:08:25 +0300 |
commit | 2db8e586e584ef31d1dab0513573d5e3e4adafde (patch) | |
tree | 9a2084083689dc42e7d9b4361ef2526f40231d54 /src/nxt_conf_validation.c | |
parent | c2918a001465ada671bffba4e01a37e3904cfe45 (diff) | |
download | unit-2db8e586e584ef31d1dab0513573d5e3e4adafde.tar.gz unit-2db8e586e584ef31d1dab0513573d5e3e4adafde.tar.bz2 |
Reduced duplication of validated app config options.
Common options moved to separate array. Application-specific arrays refers
to common options.
Diffstat (limited to 'src/nxt_conf_validation.c')
-rw-r--r-- | src/nxt_conf_validation.c | 82 |
1 files changed, 17 insertions, 65 deletions
diff --git a/src/nxt_conf_validation.c b/src/nxt_conf_validation.c index f134ba41..e683a94c 100644 --- a/src/nxt_conf_validation.c +++ b/src/nxt_conf_validation.c @@ -18,7 +18,8 @@ typedef struct { } nxt_conf_vldt_object_t; -#define NXT_CONF_VLDT_END { nxt_null_string, 0, NULL, NULL } +#define NXT_CONF_VLDT_NEXT(f) { nxt_null_string, 0, NULL, (f) } +#define NXT_CONF_VLDT_END { nxt_null_string, 0, NULL, NULL } typedef nxt_int_t (*nxt_conf_vldt_member_t)(nxt_conf_validation_t *vldt, @@ -95,7 +96,7 @@ static nxt_conf_vldt_object_t nxt_conf_vldt_app_limits_members[] = { }; -static nxt_conf_vldt_object_t nxt_conf_vldt_python_members[] = { +static nxt_conf_vldt_object_t nxt_conf_vldt_common_members[] = { { nxt_string("type"), NXT_CONF_STRING, NULL, @@ -126,6 +127,11 @@ static nxt_conf_vldt_object_t nxt_conf_vldt_python_members[] = { NULL, NULL }, + NXT_CONF_VLDT_END +}; + + +static nxt_conf_vldt_object_t nxt_conf_vldt_python_members[] = { { nxt_string("home"), NXT_CONF_STRING, NULL, @@ -141,41 +147,11 @@ static nxt_conf_vldt_object_t nxt_conf_vldt_python_members[] = { NULL, NULL }, - NXT_CONF_VLDT_END + NXT_CONF_VLDT_NEXT(&nxt_conf_vldt_common_members) }; static nxt_conf_vldt_object_t nxt_conf_vldt_php_members[] = { - { nxt_string("type"), - NXT_CONF_STRING, - NULL, - NULL }, - - { nxt_string("workers"), - NXT_CONF_INTEGER, - NULL, - NULL }, - - { nxt_string("limits"), - NXT_CONF_OBJECT, - &nxt_conf_vldt_object, - (void *) &nxt_conf_vldt_app_limits_members }, - - { nxt_string("user"), - NXT_CONF_STRING, - nxt_conf_vldt_system, - (void *) &nxt_conf_vldt_user }, - - { nxt_string("group"), - NXT_CONF_STRING, - nxt_conf_vldt_system, - (void *) &nxt_conf_vldt_group }, - - { nxt_string("working_directory"), - NXT_CONF_STRING, - NULL, - NULL }, - { nxt_string("root"), NXT_CONF_STRING, NULL, @@ -191,47 +167,17 @@ static nxt_conf_vldt_object_t nxt_conf_vldt_php_members[] = { NULL, NULL }, - NXT_CONF_VLDT_END + NXT_CONF_VLDT_NEXT(&nxt_conf_vldt_common_members) }; static nxt_conf_vldt_object_t nxt_conf_vldt_go_members[] = { - { nxt_string("type"), - NXT_CONF_STRING, - NULL, - NULL }, - - { nxt_string("workers"), - NXT_CONF_INTEGER, - NULL, - NULL }, - - { nxt_string("limits"), - NXT_CONF_OBJECT, - &nxt_conf_vldt_object, - (void *) &nxt_conf_vldt_app_limits_members }, - - { nxt_string("user"), - NXT_CONF_STRING, - nxt_conf_vldt_system, - (void *) &nxt_conf_vldt_user }, - - { nxt_string("group"), - NXT_CONF_STRING, - nxt_conf_vldt_system, - (void *) &nxt_conf_vldt_group }, - - { nxt_string("working_directory"), - NXT_CONF_STRING, - NULL, - NULL }, - { nxt_string("executable"), NXT_CONF_STRING, NULL, NULL }, - NXT_CONF_VLDT_END + NXT_CONF_VLDT_NEXT(&nxt_conf_vldt_common_members) }; @@ -437,6 +383,12 @@ nxt_conf_vldt_object(nxt_conf_validation_t *vldt, nxt_conf_value_t *value, for ( ;; ) { if (vals->name.length == 0) { + + if (vals->data != NULL) { + vals = vals->data; + continue; + } + return nxt_conf_vldt_error(vldt, "Unknown parameter \"%V\".", &name); } |