From ef8a9a29e8a3db03f0ed36aea5f727363f9a4060 Mon Sep 17 00:00:00 2001 From: Michael Jumper Date: Thu, 3 Oct 2013 17:16:16 -0700 Subject: [PATCH] Allow continuous parsing of length, rather than restarting if unfinished. --- src/libguac/instruction.c | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/libguac/instruction.c b/src/libguac/instruction.c index 600e2f9c..d34c865c 100644 --- a/src/libguac/instruction.c +++ b/src/libguac/instruction.c @@ -65,6 +65,7 @@ void guac_instruction_reset(guac_instruction* instruction) { instruction->argc = 0; instruction->state = GUAC_INSTRUCTION_PARSE_LENGTH; instruction->__elementc = 0; + instruction->__element_length = 0; } int guac_instruction_append(guac_instruction* instr, @@ -83,7 +84,7 @@ int guac_instruction_append(guac_instruction* instr, /* Parse element length */ if (instr->state == GUAC_INSTRUCTION_PARSE_LENGTH) { - int parsed_length = 0; + int parsed_length = instr->__element_length; while (bytes_parsed < length) { /* Pull next character */ @@ -96,7 +97,6 @@ int guac_instruction_append(guac_instruction* instr, /* If period, switch to parsing content */ else if (c == '.') { - instr->__element_length = parsed_length; instr->__elementv[instr->__elementc++] = char_buffer; instr->state = GUAC_INSTRUCTION_PARSE_CONTENT; break; @@ -116,6 +116,9 @@ int guac_instruction_append(guac_instruction* instr, return 0; } + /* Save length */ + instr->__element_length = parsed_length; + } /* end parse length */ /* Parse element content */ @@ -168,12 +171,9 @@ int guac_instruction_append(guac_instruction* instr, } - return bytes_parsed; - } /* end parse content */ - /* If unable to move past reading length, parse failed */ - return 0; + return bytes_parsed; }