mirror of
				git://git.psyc.eu/libpsyc
				synced 2024-08-15 03:19:02 +00:00 
			
		
		
		
	parser: more detailed return codes for incomplete values
This commit is contained in:
		
							parent
							
								
									a370f3f486
								
							
						
					
					
						commit
						72ed9a3eff
					
				
					 3 changed files with 40 additions and 18 deletions
				
			
		|  | @ -56,21 +56,27 @@ typedef enum | |||
| 	PSYC_PARSE_ENTITY = 3, | ||||
| /// Entity modifier parsing is incomplete.
 | ||||
| /// Operator & name are complete, value is incomplete.
 | ||||
| 	PSYC_PARSE_ENTITY_INCOMPLETE = 4, | ||||
| 	PSYC_PARSE_ENTITY_START = 4, | ||||
| 	PSYC_PARSE_ENTITY_CONT = 5, | ||||
| 	PSYC_PARSE_ENTITY_END = 6, | ||||
| /// Body parsing done, name contains method, value contains body.
 | ||||
| 	PSYC_PARSE_BODY = 5, | ||||
| 	PSYC_PARSE_BODY = 7, | ||||
| /// Body parsing is incomplete, name contains method, value contains part of the body.
 | ||||
| 	PSYC_PARSE_BODY_INCOMPLETE = 6, | ||||
| 	PSYC_PARSE_BODY_START = 8, | ||||
| 	PSYC_PARSE_BODY_CONT = 9, | ||||
| 	PSYC_PARSE_BODY_END = 10, | ||||
| /// Content parsing done, value contains the whole content.
 | ||||
| /// Used when PSYC_PARSE_ROUTING_ONLY is set.
 | ||||
| 	PSYC_PARSE_CONTENT = 5, | ||||
| 	PSYC_PARSE_CONTENT = 7, | ||||
| /// Content parsing is incomplete, value contains part of content.
 | ||||
| /// Used when PSYC_PARSE_ROUTING_ONLY is set.
 | ||||
| 	PSYC_PARSE_CONTENT_INCOMPLETE = 6, | ||||
| 	PSYC_PARSE_CONTENT_START = 8, | ||||
| 	PSYC_PARSE_CONTENT_CONT = 9, | ||||
| 	PSYC_PARSE_CONTENT_END = 10, | ||||
| /// Reached end of packet, parsing done.
 | ||||
| 	PSYC_PARSE_COMPLETE = 7, | ||||
| 	PSYC_PARSE_COMPLETE = 11, | ||||
| /// Binary value parsing incomplete, used internally.
 | ||||
| 	PSYC_PARSE_INCOMPLETE = 8, | ||||
| 	PSYC_PARSE_INCOMPLETE = 12, | ||||
| } psycParseRC; | ||||
| 
 | ||||
| /**
 | ||||
|  |  | |||
							
								
								
									
										10
									
								
								src/parser.c
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								src/parser.c
									
										
									
									
									
								
							|  | @ -305,9 +305,9 @@ psycParseRC psyc_parse (psycParseState *state, char *oper, | |||
| 				state->contentParsed += value->length; | ||||
| 
 | ||||
| 				if (ret == PSYC_PARSE_INCOMPLETE) | ||||
| 					return PSYC_PARSE_ENTITY_INCOMPLETE; | ||||
| 					return PSYC_PARSE_ENTITY_CONT; | ||||
| 
 | ||||
| 				return PSYC_PARSE_ENTITY; | ||||
| 				return PSYC_PARSE_ENTITY_END; | ||||
| 			} | ||||
| 
 | ||||
| 			pos = state->cursor; | ||||
|  | @ -330,7 +330,7 @@ psycParseRC psyc_parse (psycParseState *state, char *oper, | |||
| 				state->contentParsed += state->cursor - pos; | ||||
| 
 | ||||
| 				if (ret == PSYC_PARSE_INCOMPLETE) | ||||
| 					return PSYC_PARSE_ENTITY_INCOMPLETE; | ||||
| 					return PSYC_PARSE_ENTITY_START; | ||||
| 				else if (ret == PSYC_PARSE_SUCCESS) | ||||
| 					return PSYC_PARSE_ENTITY; | ||||
| 
 | ||||
|  | @ -400,11 +400,11 @@ psycParseRC psyc_parse (psycParseState *state, char *oper, | |||
| 					state->contentParsed += value->length; | ||||
| 
 | ||||
| 					if (ret == PSYC_PARSE_INCOMPLETE) | ||||
| 						return PSYC_PARSE_BODY_INCOMPLETE; | ||||
| 						return state->valueParsed == value->length ? PSYC_PARSE_BODY_START : PSYC_PARSE_BODY_CONT; | ||||
| 				} | ||||
| 
 | ||||
| 				state->part = PSYC_PART_END; | ||||
| 				return PSYC_PARSE_BODY; | ||||
| 				return state->valueLength == value->length ? PSYC_PARSE_BODY : PSYC_PARSE_BODY_END; | ||||
| 			} | ||||
| 			else // Search for the terminator.
 | ||||
| 			{ | ||||
|  |  | |||
|  | @ -103,6 +103,7 @@ int main (int argc, char **argv) | |||
| 	psycString name, value, elem; | ||||
| 	psycString *pname = NULL, *pvalue = NULL; | ||||
| 	psycParseListState listState; | ||||
| 	size_t len; | ||||
| 
 | ||||
| 	FD_ZERO(&master);    // clear the master and temp sets
 | ||||
| 	FD_ZERO(&read_fds); | ||||
|  | @ -256,14 +257,16 @@ int main (int argc, char **argv) | |||
| 									packets[i].routing.lines++; | ||||
| 									break; | ||||
| 
 | ||||
| 								case PSYC_PARSE_ENTITY_INCOMPLETE: | ||||
| 								case PSYC_PARSE_ENTITY_START: | ||||
| 								case PSYC_PARSE_ENTITY_CONT: | ||||
| 								case PSYC_PARSE_ENTITY_END: | ||||
| 								case PSYC_PARSE_ENTITY: | ||||
| 									assert(packets[i].entity.lines < ENTITY_LINES); | ||||
| 									mod = &(packets[i].entity.modifiers[packets[i].entity.lines]); | ||||
| 									pname = &mod->name; | ||||
| 									pvalue = &mod->value; | ||||
| 
 | ||||
| 									if (ret == PSYC_PARSE_ENTITY) | ||||
| 									if (ret == PSYC_PARSE_ENTITY || ret == PSYC_PARSE_ENTITY_END) | ||||
| 									{ | ||||
| 										packets[i].entity.lines++; | ||||
| 										mod->flag = psyc_isParseValueLengthFound(&parsers[i]) ? | ||||
|  | @ -271,7 +274,9 @@ int main (int argc, char **argv) | |||
| 									} | ||||
| 									break; | ||||
| 
 | ||||
| 								case PSYC_PARSE_BODY_INCOMPLETE: | ||||
| 								case PSYC_PARSE_BODY_START: | ||||
| 								case PSYC_PARSE_BODY_CONT: | ||||
| 								case PSYC_PARSE_BODY_END: | ||||
| 								case PSYC_PARSE_BODY: | ||||
| 									pname = &(packets[i].method); | ||||
| 									pvalue = &(packets[i].data); | ||||
|  | @ -363,12 +368,16 @@ int main (int argc, char **argv) | |||
| 
 | ||||
| 							switch (ret) | ||||
| 							{ | ||||
| 								case PSYC_PARSE_ENTITY_INCOMPLETE: | ||||
| 								case PSYC_PARSE_BODY_INCOMPLETE: | ||||
| 								case PSYC_PARSE_ENTITY_START: | ||||
| 								case PSYC_PARSE_ENTITY_CONT: | ||||
| 								case PSYC_PARSE_BODY_START: | ||||
| 								case PSYC_PARSE_BODY_CONT: | ||||
| 									ret = 0; | ||||
| 								case PSYC_PARSE_ENTITY: | ||||
| 								case PSYC_PARSE_ENTITY_END: | ||||
| 								case PSYC_PARSE_ROUTING: | ||||
| 								case PSYC_PARSE_BODY: | ||||
| 								case PSYC_PARSE_BODY_END: | ||||
| 									if (oper) | ||||
| 									{ | ||||
| 										mod->oper = oper; | ||||
|  | @ -391,7 +400,13 @@ int main (int argc, char **argv) | |||
| 
 | ||||
| 									if (value.length) { | ||||
| 										if (!pvalue->length) | ||||
| 											pvalue->ptr = malloc(parsers[i].valueLength ? parsers[i].valueLength : value.length); | ||||
| 										{ | ||||
| 											if (psyc_isParseValueLengthFound(&parsers[i])) | ||||
| 												len = psyc_getParseValueLength(&parsers[i]); | ||||
| 											else | ||||
| 												len = value.length; | ||||
| 											pvalue->ptr = malloc(len); | ||||
| 										} | ||||
| 										assert(pvalue->ptr != NULL); | ||||
| 										memcpy((void*)pvalue->ptr + pvalue->length, value.ptr, value.length); | ||||
| 										pvalue->length += value.length; | ||||
|  | @ -418,6 +433,7 @@ int main (int argc, char **argv) | |||
| 							{ | ||||
| 								case PSYC_PARSE_ROUTING: | ||||
| 								case PSYC_PARSE_ENTITY: | ||||
| 								case PSYC_PARSE_ENTITY_END: | ||||
| 									if (pname->length >= 5 && memcmp(pname->ptr, "_list", 5) == 0) | ||||
| 									{ | ||||
| 										if (verbose >= 2) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue