diff options
author | Valentin Bartenev <vbart@nginx.com> | 2017-07-06 22:52:05 +0300 |
---|---|---|
committer | Valentin Bartenev <vbart@nginx.com> | 2017-07-06 22:52:05 +0300 |
commit | c9fbd832ab4f5743824b155fb3bf3a42206fdd52 (patch) | |
tree | c71a2e2b12c9d6d29d4a855d7a76b0abb6eade10 /src/nxt_conf.c | |
parent | 22d73057d93bc5f363a981763348612058077159 (diff) | |
download | unit-c9fbd832ab4f5743824b155fb3bf3a42206fdd52.tar.gz unit-c9fbd832ab4f5743824b155fb3bf3a42206fdd52.tar.bz2 |
Controller: sending JSON configuration to router.
Diffstat (limited to 'src/nxt_conf.c')
-rw-r--r-- | src/nxt_conf.c | 66 |
1 files changed, 65 insertions, 1 deletions
diff --git a/src/nxt_conf.c b/src/nxt_conf.c index c091b260..f891f71e 100644 --- a/src/nxt_conf.c +++ b/src/nxt_conf.c @@ -137,7 +137,7 @@ nxt_conf_json_indentation(u_char *p, uint32_t level) } -nxt_inline void +void nxt_conf_get_string(nxt_conf_value_t *value, nxt_str_t *str) { if (value->type == NXT_CONF_VALUE_SHORT_STRING) { @@ -151,6 +151,70 @@ nxt_conf_get_string(nxt_conf_value_t *value, nxt_str_t *str) nxt_uint_t +nxt_conf_object_members_count(nxt_conf_value_t *value) +{ + return value->u.object->count; +} + + +nxt_conf_value_t * +nxt_conf_create_object(nxt_mp_t *mp, nxt_uint_t count) +{ + size_t size; + nxt_conf_value_t *value; + + size = sizeof(nxt_conf_value_t) + + sizeof(nxt_conf_object_t) + + count * sizeof(nxt_conf_object_member_t); + + value = nxt_mp_get(mp, size); + if (nxt_slow_path(value == NULL)) { + return NULL; + } + + value->u.object = nxt_pointer_to(value, sizeof(nxt_conf_value_t)); + value->u.object->count = count; + + value->type = NXT_CONF_VALUE_OBJECT; + + return value; +} + + +nxt_int_t +nxt_conf_set_object_member(nxt_mp_t *mp, nxt_conf_value_t *object, + nxt_str_t *name, nxt_conf_value_t *value, uint32_t index) +{ + nxt_conf_value_t *name_value; + nxt_conf_object_member_t *member; + + member = &object->u.object->members[index]; + name_value = &member->name; + + if (name->length > NXT_CONF_MAX_SHORT_STRING) { + name_value->type = NXT_CONF_VALUE_STRING; + name_value->u.string = nxt_str_alloc(mp, 0); + + if (nxt_slow_path(name_value->u.string == NULL)) { + return NXT_ERROR; + } + + *name_value->u.string = *name; + + } else { + name_value->type = NXT_CONF_VALUE_SHORT_STRING; + name_value->u.str[0] = name->length; + + nxt_memcpy(&name_value->u.str[1], name->start, name->length); + } + + member->value = *value; + + return NXT_OK; +} + + +nxt_uint_t nxt_conf_type(nxt_conf_value_t *value) { switch (value->type) { |