mirror of
git://git.psyc.eu/libpsyc
synced 2024-08-15 03:19:02 +00:00
fixed content length issues in parser & renderer
This commit is contained in:
parent
4f61f07ff2
commit
b898965e47
5 changed files with 25 additions and 22 deletions
35
src/packet.c
35
src/packet.c
|
@ -113,23 +113,30 @@ inline psycList psyc_newList(psycString *elems, size_t num_elems, psycListFlag f
|
||||||
|
|
||||||
inline psycPacketFlag psyc_checkPacketLength(psycPacket *p)
|
inline psycPacketFlag psyc_checkPacketLength(psycPacket *p)
|
||||||
{
|
{
|
||||||
psycPacketFlag flag;
|
|
||||||
|
|
||||||
if (p->data.length == 1 && p->data.ptr[0] == C_GLYPH_PACKET_DELIMITER)
|
if (p->data.length == 1 && p->data.ptr[0] == C_GLYPH_PACKET_DELIMITER)
|
||||||
flag = PSYC_PACKET_NEED_LENGTH;
|
return PSYC_PACKET_NEED_LENGTH;
|
||||||
else if (p->data.length > PSYC_CONTENT_SIZE_THRESHOLD)
|
|
||||||
flag = PSYC_PACKET_NEED_LENGTH;
|
|
||||||
else if (memmem(p->data.ptr, p->data.length, PSYC_C2ARG(PSYC_PACKET_DELIMITER)))
|
|
||||||
flag = PSYC_PACKET_NEED_LENGTH;
|
|
||||||
else
|
|
||||||
flag = PSYC_PACKET_NO_LENGTH;
|
|
||||||
|
|
||||||
return flag;
|
if (p->data.length > PSYC_CONTENT_SIZE_THRESHOLD)
|
||||||
|
return PSYC_PACKET_NEED_LENGTH;
|
||||||
|
|
||||||
|
int i;
|
||||||
|
// if any entity modifiers need length it is possible they contain
|
||||||
|
// a packet terminator, thus the content should have a length as well
|
||||||
|
for (i = 0; i < p->entity.lines; i++)
|
||||||
|
if (p->entity.modifiers[i].flag == PSYC_MODIFIER_NEED_LENGTH)
|
||||||
|
return PSYC_PACKET_NEED_LENGTH;
|
||||||
|
|
||||||
|
if (memmem(p->data.ptr, p->data.length, PSYC_C2ARG(PSYC_PACKET_DELIMITER)))
|
||||||
|
return PSYC_PACKET_NEED_LENGTH;
|
||||||
|
|
||||||
|
return PSYC_PACKET_NO_LENGTH;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline size_t psyc_setPacketLength(psycPacket *p)
|
inline size_t psyc_setPacketLength(psycPacket *p)
|
||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
|
p->routingLength = 0;
|
||||||
|
p->contentLength = 0;
|
||||||
|
|
||||||
// add routing header length
|
// add routing header length
|
||||||
for (i = 0; i < p->routing.lines; i++)
|
for (i = 0; i < p->routing.lines; i++)
|
||||||
|
@ -145,14 +152,14 @@ inline size_t psyc_setPacketLength(psycPacket *p)
|
||||||
if (p->data.length)
|
if (p->data.length)
|
||||||
p->contentLength += p->data.length + 1; // data\n
|
p->contentLength += p->data.length + 1; // data\n
|
||||||
|
|
||||||
// set total length: routing-header \n content |\n
|
// set total length: routing-header content |\n
|
||||||
p->length = p->routingLength + p->contentLength + sizeof(PSYC_PACKET_DELIMITER) - 2;
|
p->length = p->routingLength + p->contentLength + 2;
|
||||||
|
|
||||||
if (p->contentLength > 0)
|
if (p->contentLength > 0)
|
||||||
{
|
{
|
||||||
p->contentLength--; // subtract the \n from the delimiter, as that doesn't belong to the content part
|
|
||||||
p->length++; // add \n at the start of the content part
|
p->length++; // add \n at the start of the content part
|
||||||
if (p->flag == PSYC_PACKET_NEED_LENGTH) // add length of length if needed
|
if (p->flag == PSYC_PACKET_NEED_LENGTH) // add length of length if needed
|
||||||
p->length += log10((double)p->data.length) + 1;
|
p->length += log10((double)p->contentLength) + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return p->length;
|
return p->length;
|
||||||
|
|
|
@ -416,10 +416,9 @@ psycParseRC psyc_parse(psycParseState* state, char* oper, psycString* name, psyc
|
||||||
if (state->cursor >= state->buffer.length)
|
if (state->cursor >= state->buffer.length)
|
||||||
return PSYC_PARSE_BODY;
|
return PSYC_PARSE_BODY;
|
||||||
|
|
||||||
if (state->buffer.ptr[state->cursor] != '\n')
|
if (state->buffer.ptr[state->cursor] != '|')
|
||||||
return PSYC_PARSE_ERROR_BODY;
|
return PSYC_PARSE_ERROR_BODY;
|
||||||
|
|
||||||
state->cursor++;
|
|
||||||
state->part = PSYC_PART_END;
|
state->part = PSYC_PART_END;
|
||||||
return PSYC_PARSE_BODY;
|
return PSYC_PARSE_BODY;
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,7 +47,6 @@ inline size_t psyc_renderModifier(psycModifier *mod, char *buffer)
|
||||||
if (mod->flag == PSYC_MODIFIER_NEED_LENGTH)
|
if (mod->flag == PSYC_MODIFIER_NEED_LENGTH)
|
||||||
{
|
{
|
||||||
buffer[cur++] = ' ';
|
buffer[cur++] = ' ';
|
||||||
//cur += sprintf(buffer + cur, "%ld", mod->value.length);
|
|
||||||
cur += itoa(mod->value.length, buffer + cur, 10);
|
cur += itoa(mod->value.length, buffer + cur, 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,10 +70,8 @@ psycRenderRC psyc_render(psycPacket *packet, char *buffer, size_t buflen)
|
||||||
cur += psyc_renderModifier(&packet->routing.modifiers[i], buffer + cur);
|
cur += psyc_renderModifier(&packet->routing.modifiers[i], buffer + cur);
|
||||||
|
|
||||||
// add length if needed
|
// add length if needed
|
||||||
if (packet->flag == PSYC_PACKET_NEED_LENGTH) {
|
if (packet->flag == PSYC_PACKET_NEED_LENGTH)
|
||||||
//cur += sprintf(buffer + cur, "%ld", packet->contentLength);
|
|
||||||
cur += itoa(packet->contentLength, buffer + cur, 10);
|
cur += itoa(packet->contentLength, buffer + cur, 10);
|
||||||
}
|
|
||||||
|
|
||||||
if (packet->entity.lines || packet->method.length || packet->data.length)
|
if (packet->entity.lines || packet->method.length || packet->data.length)
|
||||||
buffer[cur++] = '\n'; // start of content part if there's content
|
buffer[cur++] = '\n'; // start of content part if there's content
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
:_source psyc://foo/~bar
|
:_source psyc://foo/~bar
|
||||||
:_target psyc://bar/~baz
|
:_target psyc://bar/~baz
|
||||||
:_tag sch1828hu3r2cm
|
:_tag sch1828hu3r2cm
|
||||||
85
|
86
|
||||||
:_foo bar baz
|
:_foo bar baz
|
||||||
:_abc_def 11 foo bar
|
:_abc_def 11 foo bar
|
||||||
baz
|
baz
|
||||||
|
|
|
@ -99,7 +99,7 @@ _notice_presence\n\
|
||||||
if (testList("\
|
if (testList("\
|
||||||
:_source psyc://10.100.1000/~ludwig\n\
|
:_source psyc://10.100.1000/~ludwig\n\
|
||||||
:_context psyc://10.100.1000/~ludwig\n\
|
:_context psyc://10.100.1000/~ludwig\n\
|
||||||
\n\
|
85\n\
|
||||||
:_list_text |foo|bar|baz\n\
|
:_list_text |foo|bar|baz\n\
|
||||||
:_list_binary 21 3 foo|3 b|r|7 baz\n\
|
:_list_binary 21 3 foo|3 b|r|7 baz\n\
|
||||||
qux\n\
|
qux\n\
|
||||||
|
|
Loading…
Reference in a new issue