summaryrefslogtreecommitdiffhomepage
path: root/src/nxt_conf.c
diff options
context:
space:
mode:
authorValentin Bartenev <vbart@nginx.com>2017-07-06 22:52:05 +0300
committerValentin Bartenev <vbart@nginx.com>2017-07-06 22:52:05 +0300
commitc9fbd832ab4f5743824b155fb3bf3a42206fdd52 (patch)
treec71a2e2b12c9d6d29d4a855d7a76b0abb6eade10 /src/nxt_conf.c
parent22d73057d93bc5f363a981763348612058077159 (diff)
downloadunit-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.c66
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) {