X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2FSDCC.lex;h=0fc43d00445ed1bd3f5881bb047b091f04423282;hb=5a1d5e778e85664f4e6657019348b4756b16eacb;hp=fbabe7031115955c54d871984f7c21ab0f1348ff;hpb=4a4c65f10dba40f3b16ff71db00e1a7cf840b73c;p=fw%2Fsdcc diff --git a/src/SDCC.lex b/src/SDCC.lex index fbabe703..0fc43d00 100644 --- a/src/SDCC.lex +++ b/src/SDCC.lex @@ -1,6 +1,6 @@ /*----------------------------------------------------------------------- - SDCC.lex - lexical analyser for use with sdcc ( a freeware compiler for - 8/16 bit microcontrollers) + SDCC.lex - lexical analyser for use with sdcc (free open source + compiler for 8/16 bit microcontrollers) Written by : Sandeep Dutta . sandeep.dutta@usa.net (1997) This program is free software; you can redistribute it and/or modify it @@ -22,9 +22,9 @@ what you give them. Help stamp out software-hoarding! -------------------------------------------------------------------------*/ +B [0-1] D [0-9] -L [a-zA-Z_] -L_DOLL [a-zA-Z_$] +L [a-zA-Z_$] H [a-fA-F0-9] E [Ee][+-]?{D}+ FS (f|F|l|L) @@ -58,6 +58,7 @@ int lexLineno = 1; static struct dbuf_s asmbuff; /* reusable _asm buffer */ /* forward declarations */ +int yyerror(char *s); static const char *stringLiteral(void); static void count(void); static void count_char(int); @@ -191,15 +192,22 @@ _?"_asm" { "__overlay" { count(); TKEYWORD(OVERLAY); } "inline" { count(); TKEYWORD99(INLINE); } "restrict" { count(); TKEYWORD99(RESTRICT); } -{L}({L}|{D})* { count(); return(check_type()); } -{L_DOLL}({L_DOLL}|{D})* { - if (options.dollars_in_ident) +{L}({L}|{D})* { + if (!options.dollars_in_ident && strchr(yytext, '$')) { - count(); - return(check_type()); + yyerror("stray '$' in program"); } - else - REJECT; + count(); + return(check_type()); +} +0[bB]{B}+{IS}? { + if (!options.std_sdcc) + { + yyerror("binary (0b) constants are not allowed in ISO C"); + } + count(); + yylval.val = constVal(yytext); + return(CONSTANT); } 0[xX]{H}+{IS}? { count(); yylval.val = constVal(yytext); return(CONSTANT); } 0[0-7]*{IS}? { count(); yylval.val = constVal(yytext); return(CONSTANT); } @@ -332,14 +340,18 @@ static int checkCurrFile (const char *s) else { const char *sb = s; + char *tmpFname; /* find the end of the file name */ while (*s && *s != '"') ++s; + tmpFname = Safe_malloc(s - sb + 1); + memcpy(tmpFname, sb, s - sb); + tmpFname[s - sb] = '\0'; + lexFilename = Safe_malloc(s - sb + 1); - memcpy(lexFilename, sb, s - sb); - lexFilename[s - sb] = '\0'; + copyStr(lexFilename, tmpFname); } filename = lexFilename; @@ -381,7 +393,7 @@ static int check_type(void) /* check if it is in the table as a typedef */ if (!ignoreTypedefType && sym && IS_SPEC (sym->etype) - && SPEC_TYPEDEF (sym->etype)) + && SPEC_TYPEDEF (sym->etype) && findSym(TypedefTab, NULL, yytext)) return (TYPE_NAME); else return(IDENTIFIER); @@ -499,8 +511,10 @@ static const char *stringLiteral(void) dbuf_destroy(&linebuf); } else - unput(ch); - break; + { + unput(ch); + goto out; + } default: count_char(ch);