Simplify get_symbol_from_token(): All keywords have symbols.
[cparser] / token_t.h
1 /*
2  * This file is part of cparser.
3  * Copyright (C) 2007-2009 Matthias Braun <matze@braunis.de>
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License
7  * as published by the Free Software Foundation; either version 2
8  * of the License, or (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
18  * 02111-1307, USA.
19  */
20 #ifndef TOKEN_T_H
21 #define TOKEN_T_H
22
23 #include <stdio.h>
24 #include "string_rep.h"
25 #include "symbol.h"
26 #include "symbol_table.h"
27 #include "type.h"
28
29 typedef enum token_kind_t {
30         T_NULL  =  0,
31         T_EOF   = '\x04', // EOT
32 #define T(mode,x,str,val) T_##x val,
33 #define TS(x,str,val) T_##x val,
34 #include "tokens.inc"
35 #undef TS
36 #undef T
37         T_LAST_TOKEN
38 } token_kind_t;
39
40 typedef enum preprocessor_token_kind_t {
41         TP_NULL  = T_NULL,
42         TP_EOF   = T_EOF,
43 #define T(mode,x,str,val) TP_##x val,
44 #define TS(x,str,val) TP_##x val,
45 #include "tokens_preprocessor.inc"
46 #undef TS
47 #undef T
48         TP_LAST_TOKEN
49 } preprocessor_token_kind_t;
50
51 typedef struct source_position_t source_position_t;
52 struct source_position_t {
53         const char *input_name;
54         unsigned    lineno;
55         unsigned    colno            : 31;
56         unsigned    is_system_header : 1;
57 };
58
59 /* position used for "builtin" declarations/types */
60 extern const source_position_t builtin_source_position;
61
62 typedef struct token_base_t     token_base_t;
63 typedef struct identifier_t     identifier_t;
64 typedef struct string_literal_t string_literal_t;
65 typedef struct number_literal_t number_literal_t;
66 typedef union  token_t          token_t;
67
68 struct token_base_t {
69         unsigned          kind;
70         source_position_t source_position;
71 };
72
73 struct identifier_t {
74         token_base_t  base;
75         symbol_t     *symbol;
76 };
77
78 struct string_literal_t {
79         token_base_t  base;
80         string_t      string;
81 };
82
83 struct number_literal_t {
84         token_base_t  base;
85         string_t      number;
86         string_t      suffix;
87 };
88
89 union token_t {
90         unsigned          kind;
91         token_base_t      base;
92         identifier_t      identifier;
93         string_literal_t  string;
94         number_literal_t  number;
95 };
96
97 void init_tokens(void);
98 void exit_tokens(void);
99 void print_token_kind(FILE *out, token_kind_t token_kind);
100 void print_token(FILE *out, const token_t *token);
101
102 void print_pp_token_kind(FILE *out, int kind);
103 void print_pp_token(FILE *out, const token_t *token);
104
105 /**
106  * returns true if pasting 2 preprocessing tokens next to each other
107  * without a space in between would generate (an)other preprocessing token(s)
108  */
109 bool tokens_would_paste(preprocessor_token_kind_t token1,
110                         preprocessor_token_kind_t token2);
111
112 #endif