X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ast_t.h;h=652909087298be0cba18232f51b9f575a1fff182;hb=6c0cf065657863296355786c99aac830b85e2d9b;hp=508f19ab41ee1a547d2fc1b15c8398d1c841a9ab;hpb=5ba6c59ce75fd069dfbfac1ce4d9a261c99251f6;p=cparser diff --git a/ast_t.h b/ast_t.h index 508f19a..6529090 100644 --- a/ast_t.h +++ b/ast_t.h @@ -61,6 +61,7 @@ typedef enum expression_kind_t { EXPR_VA_START, EXPR_VA_ARG, EXPR_STATEMENT, + EXPR_LABEL_ADDRESS, /**< GCC extension &&label operator */ EXPR_UNARY_FIRST, EXPR_UNARY_NEGATE = EXPR_UNARY_FIRST, @@ -337,6 +338,11 @@ struct classify_type_expression_t { expression_t *type_expression; }; +struct label_address_expression_t { + expression_base_t base; + declaration_t *declaration; +}; + union expression_t { expression_kind_t kind; expression_base_t base; @@ -361,6 +367,7 @@ union expression_t { conditional_expression_t conditional; statement_expression_t statement; classify_type_expression_t classify_type; + label_address_expression_t label_address; }; typedef enum storage_class_tag_t { @@ -382,6 +389,7 @@ typedef enum namespace_t { NAMESPACE_UNION, NAMESPACE_ENUM, NAMESPACE_LABEL, + NAMESPACE_LOCAL_LABEL } namespace_t; typedef enum initializer_kind_t { @@ -599,8 +607,8 @@ typedef enum statement_kind_t { STATEMENT_DO_WHILE, STATEMENT_FOR, STATEMENT_ASM, - STATEMENT_MS_TRY, - STATEMENT_LEAVE + STATEMENT_MS_TRY, /**< MS __try/__finally or __try/__except */ + STATEMENT_LEAVE /**< MS __leave */ } statement_kind_t; struct statement_base_t { @@ -651,8 +659,8 @@ struct switch_statement_t { expression_t *expression; statement_t *body; case_label_statement_t *first_case, *last_case; /**< List of all cases, including default. */ - case_label_statement_t *default_label; /**< The default label if existent. */ - unsigned long default_proj_nr; /**< The Proj-number for the default Proj. */ + case_label_statement_t *default_label; /**< The default label if existent. */ + unsigned long default_proj_nr; /**< The Proj-number for the default Proj. */ }; struct goto_statement_t { @@ -664,14 +672,14 @@ struct goto_statement_t { struct case_label_statement_t { statement_base_t base; - expression_t *expression; /**< The case label expression, NULL for default label. */ - expression_t *end_range; /**< For GNUC case a .. b: the end range expression, NULL else. */ - case_label_statement_t *next; /**< link to the next case label in switch */ + expression_t *expression; /**< The case label expression, NULL for default label. */ + expression_t *end_range; /**< For GNUC case a .. b: the end range expression, NULL else. */ + case_label_statement_t *next; /**< link to the next case label in switch */ statement_t *statement; - long first_case; /**< The folded value of expression. */ - long last_case; /**< The folded value of end_range. */ - bool is_bad; /**< If set marked as bad to supress warnings. */ - bool is_empty; /**< If set marked this is a empty range. */ + long first_case; /**< The folded value of expression. */ + long last_case; /**< The folded value of end_range. */ + bool is_bad; /**< If set marked as bad to suppress warnings. */ + bool is_empty_range; /**< If set marked this as an empty range. */ }; struct label_statement_t {