adapt to latest libfirm
[cparser] / token_t.h
index 3e14d3d..eb42775 100644 (file)
--- a/token_t.h
+++ b/token_t.h
 
 typedef enum token_kind_tag_t {
        T_NULL  =  0,
-#define T(mode,x,str,val) T_##x val,
-#define TS(x,str,val) T_##x val,
+#define T(mode,x,str,val) x val,
 #include "tokens.inc"
-#undef TS
 #undef T
        T_LAST_TOKEN
 } token_kind_tag_t;
@@ -46,25 +44,28 @@ typedef enum pp_token_kind_tag_t {
 } pp_token_kind_tag_t;
 typedef unsigned short pp_token_kind_t;
 
-typedef struct source_position_t source_position_t;
-struct source_position_t {
+typedef struct position_t position_t;
+struct position_t {
        const char *input_name;
        unsigned    lineno;
        unsigned    colno            : 31;
        unsigned    is_system_header : 1;
 };
 
+extern symbol_t *token_symbols[];
+
 /* position used for "builtin" declarations/types */
-extern const source_position_t builtin_source_position;
+extern const position_t builtin_position;
 
-typedef struct token_base_t token_base_t;
-typedef struct literal_t    literal_t;
-typedef union  token_t      token_t;
+typedef struct token_base_t      token_base_t;
+typedef struct literal_t         literal_t;
+typedef struct macro_parameter_t macro_parameter_t;
+typedef union  token_t           token_t;
 
 struct token_base_t {
-       token_kind_t      kind;
-       source_position_t source_position;
-       symbol_t         *symbol;
+       token_kind_t kind;
+       position_t   pos;
+       symbol_t    *symbol;
 };
 
 struct literal_t {
@@ -72,10 +73,16 @@ struct literal_t {
        string_t     string;
 };
 
+struct macro_parameter_t {
+       token_base_t     base;
+       pp_definition_t *def;
+};
+
 union token_t {
-       unsigned     kind;
-       token_base_t base;
-       literal_t    literal;
+       unsigned          kind;
+       token_base_t      base;
+       literal_t         literal;
+       macro_parameter_t macro_parameter;
 };
 
 char const *get_string_encoding_prefix(string_encoding_t);