X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=token_t.h;h=c8e0e109aa5636624086f171839ab6ee59aa78a0;hb=9398959e7dda6fb86547df8a6d5ce6383cfc969f;hp=762f143a47885a94ff061eeb165cfb1df976b66d;hpb=cdca5b5a7f3a8d64d426cf8fc99345179e9cca46;p=cparser diff --git a/token_t.h b/token_t.h index 762f143..c8e0e10 100644 --- a/token_t.h +++ b/token_t.h @@ -2,12 +2,13 @@ #define TOKEN_T_H #include +#include "string_rep.h" #include "symbol.h" #include "symbol_table.h" #include "type.h" typedef enum { -#define T(x,str,val) T_##x val, +#define T(mode,x,str,val) T_##x val, #define TS(x,str,val) T_##x val, #include "tokens.inc" #undef TS @@ -18,7 +19,7 @@ typedef enum { } token_type_t; typedef enum { -#define T(x,str,val) TP_##x val, +#define T(mode,x,str,val) TP_##x val, #define TS(x,str,val) TP_##x val, #include "tokens_preprocessor.inc" #undef TS @@ -31,13 +32,17 @@ struct source_position_t { unsigned linenr; }; +/* position used for "builtin" declarations/types */ +extern source_position_t builtin_source_position; + typedef struct { int type; union { - symbol_t *symbol; - long long intvalue; - long double floatvalue; - const char *string; + symbol_t *symbol; + long long intvalue; + long double floatvalue; + string_t string; + wide_string_t wide_string; } v; type_t *datatype; source_position_t source_position;