diff options
author | Valentin Bartenev <vbart@nginx.com> | 2017-07-18 18:00:19 +0300 |
---|---|---|
committer | Valentin Bartenev <vbart@nginx.com> | 2017-07-18 18:00:19 +0300 |
commit | a6c4ef7a10aebe595aa2b9d00198a8e791baa5b3 (patch) | |
tree | 4de7d081ae4423c52fffa593a3a9fe5b71f0a2fa /src | |
parent | f16510585fc139b667261bdfcd759e41553abb36 (diff) | |
download | unit-a6c4ef7a10aebe595aa2b9d00198a8e791baa5b3.tar.gz unit-a6c4ef7a10aebe595aa2b9d00198a8e791baa5b3.tar.bz2 |
Configuration: reduced memory consumption of long strings.
Diffstat (limited to '')
-rw-r--r-- | src/nxt_conf.c | 57 | ||||
-rw-r--r-- | src/nxt_conf.h | 4 |
2 files changed, 35 insertions, 26 deletions
diff --git a/src/nxt_conf.c b/src/nxt_conf.c index b4c6df47..7e5fb2a0 100644 --- a/src/nxt_conf.c +++ b/src/nxt_conf.c @@ -14,6 +14,7 @@ #define NXT_CONF_MAX_SHORT_STRING 14 +#define NXT_CONF_MAX_STRING NXT_INT32_T_MAX typedef enum { @@ -46,7 +47,12 @@ struct nxt_aligned(8) nxt_conf_value_s { int64_t integer; double number; u_char str[1 + NXT_CONF_MAX_SHORT_STRING]; - nxt_str_t *string; + + struct nxt_packed { + u_char *start; + uint32_t length; + } string; + nxt_conf_array_t *array; nxt_conf_object_t *object; } u; @@ -145,7 +151,8 @@ nxt_conf_get_string(nxt_conf_value_t *value, nxt_str_t *str) str->start = &value->u.str[1]; } else { - *str = *value->u.string; + str->length = value->u.string.length; + str->start = value->u.string.start; } } @@ -182,8 +189,8 @@ nxt_conf_create_object(nxt_mp_t *mp, nxt_uint_t count) 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_set_object_member(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; @@ -193,13 +200,8 @@ nxt_conf_set_object_member(nxt_mp_t *mp, nxt_conf_value_t *object, 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; + name_value->u.string.length = name->length; + name_value->u.string.start = name->start; } else { name_value->type = NXT_CONF_VALUE_SHORT_STRING; @@ -552,13 +554,9 @@ nxt_conf_op_compile(nxt_mp_t *mp, nxt_conf_op_t **ops, nxt_conf_value_t *root, } if (token.length > NXT_CONF_MAX_SHORT_STRING) { + member->name.u.string.length = token.length; + member->name.u.string.start = token.start; - member->name.u.string = nxt_mp_get(mp, sizeof(nxt_str_t)); - if (nxt_slow_path(member->name.u.string == NULL)) { - return NXT_ERROR; - } - - *member->name.u.string = token; member->name.type = NXT_CONF_VALUE_STRING; } else { @@ -621,12 +619,16 @@ nxt_conf_copy_value(nxt_mp_t *mp, nxt_conf_op_t *op, nxt_conf_value_t *dst, case NXT_CONF_VALUE_STRING: - dst->u.string = nxt_str_dup(mp, NULL, src->u.string); - - if (nxt_slow_path(dst->u.string == NULL)) { + dst->u.string.start = nxt_mp_nget(mp, src->u.string.length); + if (nxt_slow_path(dst->u.string.start == NULL)) { return NXT_ERROR; } + nxt_memcpy(dst->u.string.start, src->u.string.start, + src->u.string.length); + + dst->u.string.length = src->u.string.length; + break; case NXT_CONF_VALUE_ARRAY: @@ -1289,14 +1291,21 @@ nxt_conf_json_parse_string(nxt_mp_t *mp, nxt_conf_value_t *value, u_char *start, size = last - start - surplus; if (size > NXT_CONF_MAX_SHORT_STRING) { + + if (nxt_slow_path(size > NXT_CONF_MAX_STRING)) { + return NULL; + } + value->type = NXT_CONF_VALUE_STRING; - value->u.string = nxt_str_alloc(mp, size); - if (nxt_slow_path(value->u.string == NULL)) { + value->u.string.start = nxt_mp_nget(mp, size); + if (nxt_slow_path(value->u.string.start == NULL)) { return NULL; } - s = value->u.string->start; + value->u.string.length = size; + + s = value->u.string.start; } else { value->type = NXT_CONF_VALUE_SHORT_STRING; @@ -1392,7 +1401,7 @@ nxt_conf_json_parse_string(nxt_mp_t *mp, nxt_conf_value_t *value, u_char *start, } while (p != last); if (size > NXT_CONF_MAX_SHORT_STRING) { - value->u.string->length = s - value->u.string->start; + value->u.string.length = s - value->u.string.start; } else { value->u.str[0] = s - &value->u.str[1]; diff --git a/src/nxt_conf.h b/src/nxt_conf.h index 90a4450a..7262d890 100644 --- a/src/nxt_conf.h +++ b/src/nxt_conf.h @@ -82,8 +82,8 @@ void nxt_conf_get_string(nxt_conf_value_t *value, nxt_str_t *str); // FIXME reimplement and reorder functions below nxt_uint_t nxt_conf_object_members_count(nxt_conf_value_t *value); nxt_conf_value_t *nxt_conf_create_object(nxt_mp_t *mp, nxt_uint_t count); -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_int_t nxt_conf_set_object_member(nxt_conf_value_t *object, nxt_str_t *name, + nxt_conf_value_t *value, uint32_t index); #endif /* _NXT_CONF_INCLUDED_ */ |