From 65461f64029c79a8d49d44faa974cf799a2191ff Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Wed, 17 Jun 2015 13:52:28 +0300 Subject: Add parsing node CASE_LABEL_EXPR. --- src/Makefile.files | 4 ++- src/includes/nodeincludes.h | 1 + src/includes/nodeshandling.inc | 1 + src/includes/parserdefines.inc | 1 + src/nodes/expr/caselabel_expr.h | 44 ++++++++++++++++++++++++++++ src/parsers/expr/caselabel_expr.cpp | 57 +++++++++++++++++++++++++++++++++++++ 6 files changed, 107 insertions(+), 1 deletion(-) create mode 100644 src/nodes/expr/caselabel_expr.h create mode 100644 src/parsers/expr/caselabel_expr.cpp diff --git a/src/Makefile.files b/src/Makefile.files index 33839b6..e1be61b 100644 --- a/src/Makefile.files +++ b/src/Makefile.files @@ -312,4 +312,6 @@ SRC = analysis/analysis.cpp \ nodes/type/typename_type.h \ parsers/type/typename_type.cpp \ nodes/expr/vecinit_expr.h \ - parsers/expr/vecinit_expr.cpp \ No newline at end of file + parsers/expr/vecinit_expr.cpp \ + nodes/expr/caselabel_expr.h \ + parsers/expr/caselabel_expr.cpp \ No newline at end of file diff --git a/src/includes/nodeincludes.h b/src/includes/nodeincludes.h index 2eb888f..83ce2ad 100644 --- a/src/includes/nodeincludes.h +++ b/src/includes/nodeincludes.h @@ -134,3 +134,4 @@ #include "nodes/expr/truthxor_expr.h" #include "nodes/type/typename_type.h" #include "nodes/expr/vecinit_expr.h" +#include "nodes/expr/caselabel_expr.h" diff --git a/src/includes/nodeshandling.inc b/src/includes/nodeshandling.inc index 181d285..ef666d2 100644 --- a/src/includes/nodeshandling.inc +++ b/src/includes/nodeshandling.inc @@ -133,3 +133,4 @@ handleNodeType(TRUTH_OR_EXPR, TruthOrExpr) handleNodeType(TRUTH_XOR_EXPR, TruthXorExpr) handleNodeType(TYPENAME_TYPE, TypeNameType) handleNodeType(VEC_INIT_EXPR, VecInitExpr) +handleNodeType(CASE_LABEL_EXPR, CaseLabelExpr) diff --git a/src/includes/parserdefines.inc b/src/includes/parserdefines.inc index 93b9264..46e12e1 100644 --- a/src/includes/parserdefines.inc +++ b/src/includes/parserdefines.inc @@ -133,3 +133,4 @@ parserDefine(TruthOrExpr); parserDefine(TruthXorExpr); parserDefine(TypeNameType); parserDefine(VecInitExpr); +parserDefine(CaseLabelExpr); diff --git a/src/nodes/expr/caselabel_expr.h b/src/nodes/expr/caselabel_expr.h new file mode 100644 index 0000000..b5e10d0 --- /dev/null +++ b/src/nodes/expr/caselabel_expr.h @@ -0,0 +1,44 @@ +/* + * Copyright (C) 2015 Andrei Karas + * + * This file is part of AstDumper. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +#ifndef NODES_EXPR_CASELABELEXPRNODE_H +#define NODES_EXPR_CASELABELEXPRNODE_H + +#include "nodes/base/expr.h" + +#include "nodes/cst/integer_cst.h" + +#include + +struct CaseLabelExprNode : public ExprNode +{ + CaseLabelExprNode() : + ExprNode(), + caseLabel(nullptr), + caseLow(nullptr), + caseHigh(nullptr) + { + } + + Node *caseLabel; + IntegerCstNode *caseLow; + IntegerCstNode *caseHigh; +}; + +#endif // NODES_EXPR_CASELABELEXPRNODE_H diff --git a/src/parsers/expr/caselabel_expr.cpp b/src/parsers/expr/caselabel_expr.cpp new file mode 100644 index 0000000..811a9a4 --- /dev/null +++ b/src/parsers/expr/caselabel_expr.cpp @@ -0,0 +1,57 @@ +/* + * Copyright (C) 2015 Andrei Karas + * + * This file is part of AstDumper. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +#include "includes/parserincludes.h" + +parserDefine(CaseLabelExpr); + +#include "parsers/base/expr.h" + +#include "nodes/expr/caselabel_expr.h" + +namespace Generic +{ + +void parseCaseLabelExprNode(CaseLabelExprNode *node) +{ + fillType(node); + fillExprLocation(node); + Log::dump(node); + + fillExprOperands(node); + + node->caseLabel = createParseNode( + node, + CASE_LABEL(node->gccNode), + "case label"); + + if (CASE_LOW(node->gccNode)) + { + node->caseLow = static_cast(createParseNode( + node, + CASE_LOW(node->gccNode), + "case low")); + node->caseHigh = static_cast(createParseNode( + node, + CASE_HIGH(node->gccNode), + "case high")); + } +} + +} -- cgit v1.2.3-70-g09d2