[b87a5ed] | 1 | // |
---|
| 2 | // Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo |
---|
| 3 | // |
---|
| 4 | // The contents of this file are covered under the licence agreement in the |
---|
| 5 | // file "LICENCE" distributed with Cforall. |
---|
| 6 | // |
---|
[974906e2] | 7 | // ParseNode.h -- |
---|
[b87a5ed] | 8 | // |
---|
| 9 | // Author : Rodolfo G. Esteves |
---|
| 10 | // Created On : Sat May 16 13:28:16 2015 |
---|
[b1f2007] | 11 | // Last Modified By : Peter A. Buhr |
---|
| 12 | // Last Modified On : Sat Dec 9 17:39:34 2023 |
---|
| 13 | // Update Count : 945 |
---|
[b87a5ed] | 14 | // |
---|
| 15 | |
---|
[6b0b624] | 16 | #pragma once |
---|
[51b7345] | 17 | |
---|
[d180746] | 18 | #include <algorithm> // for move |
---|
| 19 | #include <cassert> // for assert, assertf |
---|
| 20 | #include <iosfwd> // for ostream |
---|
| 21 | #include <iterator> // for back_insert_iterator |
---|
| 22 | #include <list> // for list |
---|
| 23 | #include <memory> // for unique_ptr, pointer_traits |
---|
| 24 | #include <string> // for string |
---|
[51b7345] | 25 | |
---|
[bb7422a] | 26 | #include "AST/Expr.hpp" // for Expr, NameExpr LogicalFlag |
---|
| 27 | #include "AST/Fwd.hpp" // for ptr, Decl, DeclWithType, |
---|
| 28 | #include "AST/Stmt.hpp" // for Stmt |
---|
[21f0aa8] | 29 | #include "Common/CodeLocation.h" // for CodeLocation |
---|
[d180746] | 30 | #include "Common/SemanticError.h" // for SemanticError |
---|
[be9288a] | 31 | #include "Common/UniqueName.h" // for UniqueName |
---|
[bb7422a] | 32 | #include "Parser/parserutility.h" // for maybeBuild, maybeCopy |
---|
[d180746] | 33 | |
---|
[b2e0df3] | 34 | struct DeclarationNode; |
---|
[dc3fbe5] | 35 | struct InitializerNode; |
---|
| 36 | struct ExpressionNode; |
---|
[b2e0df3] | 37 | struct StatementNode; |
---|
[51b7345] | 38 | |
---|
[b1f2007] | 39 | |
---|
[7880579] | 40 | //############################################################################## |
---|
| 41 | |
---|
[d48e529] | 42 | typedef CodeLocation YYLTYPE; |
---|
| 43 | #define YYLTYPE_IS_DECLARED 1 /* alert the parser that we have our own definition */ |
---|
| 44 | |
---|
| 45 | extern YYLTYPE yylloc; |
---|
[294647b] | 46 | |
---|
[dc3fbe5] | 47 | struct ParseNode { |
---|
| 48 | ParseNode() {} |
---|
| 49 | virtual ~ParseNode() {} |
---|
[b6424d9] | 50 | virtual ParseNode * clone() const = 0; |
---|
[51b7345] | 51 | |
---|
[dc3fbe5] | 52 | virtual void print( __attribute__((unused)) std::ostream & os, __attribute__((unused)) int indent = 0 ) const {} |
---|
| 53 | |
---|
| 54 | static int indent_by; |
---|
| 55 | |
---|
| 56 | CodeLocation location = yylloc; |
---|
| 57 | }; // ParseNode |
---|
| 58 | |
---|
| 59 | /// Only ever use in the form `struct NAME final : public ParseList<NAME>`! |
---|
| 60 | template<typename Next> |
---|
| 61 | struct ParseList : public ParseNode { |
---|
| 62 | ParseList() {} |
---|
| 63 | virtual ~ParseList() { delete next; }; |
---|
| 64 | virtual ParseList<Next> * clone() const = 0; |
---|
[1b772749] | 65 | |
---|
[dc3fbe5] | 66 | Next * get_last() { |
---|
| 67 | Next * current = static_cast<Next *>( this ); |
---|
| 68 | while ( current->next != nullptr ) current = current->next; |
---|
[99cad3aa] | 69 | return current; |
---|
| 70 | } |
---|
[dc3fbe5] | 71 | Next * set_last( Next * newlast ) { |
---|
| 72 | if ( newlast != nullptr ) get_last()->next = newlast; |
---|
| 73 | return static_cast<Next *>( this ); |
---|
[99cad3aa] | 74 | } |
---|
[51b7345] | 75 | |
---|
[f2f512ba] | 76 | virtual void printList( std::ostream & os, int indent = 0 ) const { |
---|
[e4bc986] | 77 | print( os, indent ); |
---|
| 78 | if ( next ) next->print( os, indent ); |
---|
| 79 | } |
---|
[1b772749] | 80 | |
---|
[dc3fbe5] | 81 | Next * next = nullptr; |
---|
| 82 | }; |
---|
[51b7345] | 83 | |
---|
[e5f2a67] | 84 | // Must harmonize with OperName. |
---|
[d9e2280] | 85 | enum class OperKinds { |
---|
| 86 | // diadic |
---|
[e5f2a67] | 87 | SizeOf, AlignOf, OffsetOf, Plus, Minus, Exp, Mul, Div, Mod, Or, And, |
---|
[d9e2280] | 88 | BitOr, BitAnd, Xor, Cast, LShift, RShift, LThan, GThan, LEThan, GEThan, Eq, Neq, |
---|
[e5f2a67] | 89 | Assign, AtAssn, ExpAssn, MulAssn, DivAssn, ModAssn, PlusAssn, MinusAssn, LSAssn, RSAssn, AndAssn, ERAssn, OrAssn, |
---|
[d9e2280] | 90 | Index, Range, |
---|
| 91 | // monadic |
---|
[5809461] | 92 | UnPlus, UnMinus, AddressOf, PointTo, Neg, BitNeg, Incr, IncrPost, Decr, DecrPost, |
---|
[d9e2280] | 93 | Ctor, Dtor, |
---|
[c1c1112] | 94 | }; // OperKinds |
---|
[51b7345] | 95 | |
---|
[7cf8006] | 96 | enum class EnumHiding { Visible, Hide }; |
---|
| 97 | |
---|
[e82aa9df] | 98 | struct LabelNode { |
---|
[bb7422a] | 99 | std::vector<ast::Label> labels; |
---|
[e82aa9df] | 100 | }; |
---|
| 101 | |
---|
[c8dfcd3] | 102 | std::ostream & operator<<( std::ostream & out, const ParseNode * node ); |
---|
[7ecbb7e] | 103 | |
---|
[b1f2007] | 104 | __attribute__((noreturn)) static inline void SemanticError( const ParseNode * obj, const std::string & error ) { |
---|
| 105 | SemanticError( obj->location, toString( error, obj ) ); |
---|
| 106 | } |
---|
| 107 | |
---|
[51b7345] | 108 | // Local Variables: // |
---|
[b87a5ed] | 109 | // tab-width: 4 // |
---|
| 110 | // mode: c++ // |
---|
| 111 | // compile-command: "make install" // |
---|
[51b7345] | 112 | // End: // |
---|