summaryrefslogtreecommitdiffstats
path: root/cmd_parse.ragel
diff options
context:
space:
mode:
Diffstat (limited to 'cmd_parse.ragel')
-rw-r--r--cmd_parse.ragel57
1 files changed, 35 insertions, 22 deletions
diff --git a/cmd_parse.ragel b/cmd_parse.ragel
index a80d7d1..2fa030c 100644
--- a/cmd_parse.ragel
+++ b/cmd_parse.ragel
@@ -5,8 +5,8 @@
#define TADD(T,S,E,SZ) {cmd_tok_t *t=cmd_tok_create(S,E,SZ,T);cmd_tok_add(tl,t);tl=tl->next;}
//#define TADD(T,S,E)
-//#define PR_TK_DBG(S) printf(S);fwrite(ts,1,te-ts,stdout);printf("\n");
-#define PR_TK_DBG(S) ;
+#define PR_TK_DBG(S) printf(S);fwrite(ts,1,te-ts,stdout);printf("\n");
+//#define PR_TK_DBG(S) ;
char *new_string( const char *start, const char *end )
{
@@ -29,41 +29,54 @@ int print_token( char *s, char *e, int tok)
%%{
machine cmd;
-
- hex = '0x' [a-fA-F0-9]+;
- decimal = [0-9]+;
- binary = '0b' [0-1]+;
- string = ('"' ([a-zA-Z0-9' '])+ '"');
- seperate = ';';
- word = [a-zA-Z] ([a-zA-Z0-9])*;
-
- sp = ([' ','\t','\n']);
+ hex = '0x' [a-fA-F0-9]+;
+ decimal = [0-9]+;
+ binary = '0b' [0-1]+;
+ quoted_string = '"'
+ (
+ (any-['\\' '"' ' '])*
+ |'\\\\'
+ |'\\\"'
+ |'\\ '
+ )*
+ '"';
+ string = (any-['"' ' ']){1}
+ (any-['"' ' '])*
+ (any-['"' ' ']){1};
+ #seperate = ';';
+ word = [a-zA-Z] ([a-zA-Z0-9])*;
+ sp = ([' ','\t','\n']);
main := |*
- hex => {PR_TK_DBG("hex = ");TADD(CMDT_HEX, ts,te,te-ts);};
- sp => {PR_TK_DBG("sp = ");};
- string => {PR_TK_DBG("str = ");TADD(CMDT_STR, ts,te,te-ts);};
- decimal => {PR_TK_DBG("dec = ");TADD(CMDT_INT, ts,te,te-ts);};
- binary => {PR_TK_DBG("bin = ");TADD(CMDT_BIN, ts,te,te-ts);};
- seperate => {PR_TK_DBG("sep = ");TADD(CMDT_SP, ts,te,te-ts);};
- word => {PR_TK_DBG("wrd = ");TADD(CMDT_WORD,ts,te,te-ts);};
+ hex {PR_TK_DBG("hex = ");TADD(CMDT_HEX, ts,te,te-ts);};
+ decimal {PR_TK_DBG("dec = ");TADD(CMDT_INT, ts,te,te-ts);};
+ binary {PR_TK_DBG("bin = ");TADD(CMDT_BIN, ts,te,te-ts);};
+ quoted_string {PR_TK_DBG("qstr = ");TADD(CMDT_QSTR, ts,te,te-ts);};
+ word {PR_TK_DBG("word = ");TADD(CMDT_WORD, ts,te,te-ts);};
+ sp {PR_TK_DBG("sp = ");TADD(CMDT_SP, ts,te,te-ts);};
+ string {PR_TK_DBG("str = ");TADD(CMDT_STR, ts,te,te-ts);};
*|;
- #main := ( ' ' @{fcall lang}; );
+
write data;
}%%
-int parse_cmd( cmd_tok_t *tl, const char *str )
+int parse_cmd( cmd_tok_t *tl, const char *str, size_t str_size )
{
static uint8_t cs;
const int stacksize = 10;
- int res=0, *stack=NULL, act=0;
+ int res=0, *stack=NULL, act=0,top=0;
stack = malloc( sizeof(stack)*stacksize );
- char *p=(char *)str, *pe = (char *)str + strlen( str ), *eof=NULL;
+ char *p=(char *)str, *pe = (char *)str + str_size, *eof=pe;
char *ts, *te = 0;
+ /*save for cmd_begin state*/
+ char *ts_cb=0, *te_cb=0;
+
+ printf("PE:%s %02x\n",pe,(unsigned char)*pe);
+
/*
variables used in state machine
*/