summaryrefslogtreecommitdiffhomepage
path: root/src/nxt_http_parse.c
diff options
context:
space:
mode:
authorMax Romanov <max.romanov@nginx.com>2019-08-16 00:56:38 +0300
committerMax Romanov <max.romanov@nginx.com>2019-08-16 00:56:38 +0300
commit29911538ea91705fcdcbcf0e271cfbc5c8ed674b (patch)
treea3a63b97f073cfe67e1b31d2f8c87fdfad4e3520 /src/nxt_http_parse.c
parentcaea9d3c07543fecf9035ff2b406c190b714989e (diff)
downloadunit-29911538ea91705fcdcbcf0e271cfbc5c8ed674b.tar.gz
unit-29911538ea91705fcdcbcf0e271cfbc5c8ed674b.tar.bz2
Improving response header fields processing.
Fields are filtered one by one before being added to fields list. This avoids adding and then skipping connection-specific fields.
Diffstat (limited to 'src/nxt_http_parse.c')
-rw-r--r--src/nxt_http_parse.c23
1 files changed, 4 insertions, 19 deletions
diff --git a/src/nxt_http_parse.c b/src/nxt_http_parse.c
index 05df245e..8b4bf47c 100644
--- a/src/nxt_http_parse.c
+++ b/src/nxt_http_parse.c
@@ -1110,7 +1110,7 @@ done:
}
-static const nxt_lvlhsh_proto_t nxt_http_fields_hash_proto nxt_aligned(64) = {
+const nxt_lvlhsh_proto_t nxt_http_fields_hash_proto nxt_aligned(64) = {
NXT_LVLHSH_BUCKET_SIZE(64),
{ NXT_HTTP_FIELD_LVLHSH_SHIFT, 0, 0, 0, 0, 0, 0, 0 },
nxt_http_field_hash_test,
@@ -1240,27 +1240,12 @@ nxt_http_fields_hash_collisions(nxt_lvlhsh_t *hash, nxt_mp_t *mp,
nxt_int_t
nxt_http_fields_process(nxt_list_t *fields, nxt_lvlhsh_t *hash, void *ctx)
{
- nxt_int_t ret;
- nxt_http_field_t *field;
- nxt_lvlhsh_query_t lhq;
- nxt_http_field_proc_t *proc;
-
- lhq.proto = &nxt_http_fields_hash_proto;
+ nxt_int_t ret;
+ nxt_http_field_t *field;
nxt_list_each(field, fields) {
- lhq.key_hash = field->hash;
- lhq.key.length = field->name_length;
- lhq.key.start = field->name;
-
- if (nxt_lvlhsh_find(hash, &lhq) != NXT_OK) {
- continue;
- }
-
- proc = lhq.value;
-
- ret = proc->handler(ctx, field, proc->data);
-
+ ret = nxt_http_field_process(field, hash, ctx);
if (nxt_slow_path(ret != NXT_OK)) {
return ret;
}