mirror of
				git://git.psyc.eu/libpsyc
				synced 2024-08-15 03:19:02 +00:00 
			
		
		
		
	ready for testing now.
This commit is contained in:
		
							parent
							
								
									b6ef420efa
								
							
						
					
					
						commit
						fc829ecbb3
					
				
					 4 changed files with 55 additions and 43 deletions
				
			
		|  | @ -30,7 +30,7 @@ typedef struct | ||||||
| 	PSYC_Array buffer; | 	PSYC_Array buffer; | ||||||
| 	uint8_t flags; | 	uint8_t flags; | ||||||
| 
 | 
 | ||||||
| 	char inHeader; | 	char inBody; | ||||||
| 	unsigned int length; | 	unsigned int length; | ||||||
| 	unsigned int contentLength; | 	unsigned int contentLength; | ||||||
| } PSYC_State; | } PSYC_State; | ||||||
|  | @ -59,8 +59,6 @@ inline void PSYC_nextBuffer (PSYC_State* state, PSYC_Array newBuf) | ||||||
| 	state->buffer = newBuf;  | 	state->buffer = newBuf;  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| inline unsigned int PSYC_getBodyLength (PSYC_State* state) | inline unsigned int PSYC_getBodyLength (PSYC_State* state) | ||||||
| { | { | ||||||
| 	return state->length; | 	return state->length; | ||||||
|  |  | ||||||
|  | @ -12,7 +12,7 @@ diet: | ||||||
| 	/opt/diet/bin/diet ar rcs libpsyc.a $O | 	/opt/diet/bin/diet ar rcs libpsyc.a $O | ||||||
| 
 | 
 | ||||||
| lib: $S | lib: $S | ||||||
| 	${CC} -static -c -Os $S -lc -DDEBUG -DPSYC_COMPILE_LIBRARY | 	${CC} -static -c -g -O0 $S -lc -DDEBUG -DPSYC_COMPILE_LIBRARY | ||||||
| 	ar rcs libpsyc.a $O | 	ar rcs libpsyc.a $O | ||||||
| 
 | 
 | ||||||
| match: match.c | match: match.c | ||||||
|  |  | ||||||
							
								
								
									
										36
									
								
								src/parser.c
									
										
									
									
									
								
							
							
						
						
									
										36
									
								
								src/parser.c
									
										
									
									
									
								
							|  | @ -61,7 +61,7 @@ start: | ||||||
| 	/* each line of the header starts with a glyph.
 | 	/* each line of the header starts with a glyph.
 | ||||||
| 	 * iE :_name, -_name +_name etc, so just test if  | 	 * iE :_name, -_name +_name etc, so just test if  | ||||||
| 	 * the first char is a glyph. */ | 	 * the first char is a glyph. */ | ||||||
| 	if(1==state->inHeader) | 	if(0==state->inBody) | ||||||
| 	{ | 	{ | ||||||
| 		if(!isGlyph(state->buffer.ptr[state->cursor])) // is the first char not a glyph?
 | 		if(!isGlyph(state->buffer.ptr[state->cursor])) // is the first char not a glyph?
 | ||||||
| 		{ | 		{ | ||||||
|  | @ -95,7 +95,7 @@ start: | ||||||
| 			// is complete(empty packet) or that the method started.
 | 			// is complete(empty packet) or that the method started.
 | ||||||
| 			if(isAlphaNumeric(state->buffer.ptr[state->cursor])) | 			if(isAlphaNumeric(state->buffer.ptr[state->cursor])) | ||||||
| 			{ | 			{ | ||||||
| 				state->inHeader = 0; | 				state->inBody = 1; | ||||||
| 				if (state->flags & PSYC_HEADER_ONLY) | 				if (state->flags & PSYC_HEADER_ONLY) | ||||||
| 					return PSYC_HEADER_COMPLETE; // return header finished
 | 					return PSYC_HEADER_COMPLETE; // return header finished
 | ||||||
| 				else | 				else | ||||||
|  | @ -113,6 +113,7 @@ start: | ||||||
| 				if(state->buffer.ptr[state->cursor]=='\n') | 				if(state->buffer.ptr[state->cursor]=='\n') | ||||||
| 				{ | 				{ | ||||||
| 					++(state->cursor); | 					++(state->cursor); | ||||||
|  | 					state->inBody = 0; | ||||||
| 					return PSYC_COMPLETE; // return packet finished
 | 					return PSYC_COMPLETE; // return packet finished
 | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  | @ -130,14 +131,19 @@ start: | ||||||
| 
 | 
 | ||||||
| 			name->ptr = state->buffer.ptr + state->cursor; | 			name->ptr = state->buffer.ptr + state->cursor; | ||||||
| 
 | 
 | ||||||
| 			name->length = 0; | 			name->length = 1; | ||||||
| 		} |  | ||||||
| 		} | 		} | ||||||
|  | 	} // endif inBody=0
 | ||||||
| 
 | 
 | ||||||
| 	char method=0; | 	char method=0; | ||||||
|  | 	/* each line of the header starts with a glyph.
 | ||||||
|  | 	 * iE :_name, -_name +_name etc, so just test if  | ||||||
|  | 	 * the first char is a glyph. */ | ||||||
| 	/* in the body, the same applies, only that the
 | 	/* in the body, the same applies, only that the
 | ||||||
| 	 * method does not start with a glyph.*/  | 	 * method does not start with a glyph.*/  | ||||||
| 	if(0==state->inHeader && !isGlyph(state->buffer.ptr[state->cursor])) | 	if(1==state->inBody) | ||||||
|  | 	{ | ||||||
|  | 		if(!isGlyph(state->buffer.ptr[state->cursor])) | ||||||
| 		{ | 		{ | ||||||
| 			if(!isAlphaNumeric(state->buffer.ptr[state->cursor]) && state->buffer.ptr[state->cursor] != '_') | 			if(!isAlphaNumeric(state->buffer.ptr[state->cursor]) && state->buffer.ptr[state->cursor] != '_') | ||||||
| 			{ | 			{ | ||||||
|  | @ -154,6 +160,7 @@ start: | ||||||
| 					if(state->buffer.ptr[state->cursor]=='\n') | 					if(state->buffer.ptr[state->cursor]=='\n') | ||||||
| 					{ | 					{ | ||||||
| 						++(state->cursor); | 						++(state->cursor); | ||||||
|  | 						state->inBody = 0; | ||||||
| 						return PSYC_COMPLETE; // return packet finished
 | 						return PSYC_COMPLETE; // return packet finished
 | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
|  | @ -179,6 +186,7 @@ start: | ||||||
| 			name->ptr = state->buffer.ptr+state->cursor; | 			name->ptr = state->buffer.ptr+state->cursor; | ||||||
| 			name->length=1; | 			name->length=1; | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	/* validate the incremented cursor */ | 	/* validate the incremented cursor */ | ||||||
| 	if(state->buffer.length <= ++(state->cursor)) | 	if(state->buffer.length <= ++(state->cursor)) | ||||||
|  | @ -293,6 +301,7 @@ start: | ||||||
| 							{ | 							{ | ||||||
| 								/* packet finishes here */ | 								/* packet finishes here */ | ||||||
| 								state->cursor+=3; | 								state->cursor+=3; | ||||||
|  | 								state->inBody = 0; | ||||||
| 								return PSYC_COMPLETE; | 								return PSYC_COMPLETE; | ||||||
| 							} | 							} | ||||||
| 							 | 							 | ||||||
|  | @ -302,7 +311,7 @@ start: | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	else if(state->inHeader == 0 && method==0 && state->buffer.ptr[state->cursor] == ' ') // oi, its a binary var!
 | 	else if(state->inBody == 1 && method==0 && state->buffer.ptr[state->cursor] == ' ') // oi, its a binary var!
 | ||||||
| 	{ // after SP the length follows.
 | 	{ // after SP the length follows.
 | ||||||
| 		unsigned int binLength= 0; | 		unsigned int binLength= 0; | ||||||
| 
 | 
 | ||||||
|  | @ -344,7 +353,7 @@ start: | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	/* if there was a \t, then we parsed up until the 
 | 	/* if there was a \t, then we parsed up until the 
 | ||||||
| 	 * \n char from the simple-arg rule ( \t arg-state->buffer.ptr \n ) | 	 * \n char from the simple-arg rule ( \t arg-data \n ) | ||||||
| 	 * | 	 * | ||||||
| 	 * Now, if there would be no \t, we still would be at | 	 * Now, if there would be no \t, we still would be at | ||||||
| 	 * the point where a \n must follow. | 	 * the point where a \n must follow. | ||||||
|  | @ -366,16 +375,20 @@ start: | ||||||
| 		return PSYC_INSUFFICIENT; // return insufficient
 | 		return PSYC_INSUFFICIENT; // return insufficient
 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if(1 == state->inHeader && state->buffer.ptr[state->cursor] == '\n')  | 	if(0 == state->inBody && state->buffer.ptr[state->cursor] == '\n')  | ||||||
| 	{ | 	{ | ||||||
| 		state->cursor+=1; | 		state->cursor+=1; | ||||||
| 		state->inHeader = 0; | 		state->inBody = 1; | ||||||
| 		return 2; // line is complete, but body starts now.
 | 		 | ||||||
|  | 		if (state->flags & PSYC_HEADER_ONLY) | ||||||
|  | 			return PSYC_HEADER_COMPLETE; // return header finished
 | ||||||
|  | 		else | ||||||
|  | 			goto start; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if(state->buffer.ptr[state->cursor] != '|') // no pipe, then only line complete, not the packet.
 | 	if(state->buffer.ptr[state->cursor] != '|') // no pipe, then only line complete, not the packet.
 | ||||||
| 	{ | 	{ | ||||||
| 		if (state->inHeader == 1) | 		if (state->inBody == 0) | ||||||
| 			return PSYC_ROUTING; | 			return PSYC_ROUTING; | ||||||
| 		else | 		else | ||||||
| 			return PSYC_ENTITY;	 | 			return PSYC_ENTITY;	 | ||||||
|  | @ -389,6 +402,7 @@ start: | ||||||
| 		return -4; | 		return -4; | ||||||
| 
 | 
 | ||||||
| 	state->cursor+=1; | 	state->cursor+=1; | ||||||
|  | 	state->inBody = 0; | ||||||
| 	return PSYC_COMPLETE; // packet is complete
 | 	return PSYC_COMPLETE; // packet is complete
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ CFLAGS=-I.. -DDEBUG | ||||||
| LDFLAGS=-L.. -lpsyc | LDFLAGS=-L.. -lpsyc | ||||||
| 
 | 
 | ||||||
| works: | works: | ||||||
| 	cc -I../../include -DDEBUG -L.. parser/testParser.c -o testParser -lpsyc | 	cc -I../../include -g -O0 -DDEBUG -L.. parser/testParser.c -o testParser -lpsyc | ||||||
| 
 | 
 | ||||||
| it: testParser | it: testParser | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue