| [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 | // | 
|---|
| [c92bdcc] | 7 | // ParseNode.hpp -- | 
|---|
| [b87a5ed] | 8 | // | 
|---|
|  | 9 | // Author           : Rodolfo G. Esteves | 
|---|
|  | 10 | // Created On       : Sat May 16 13:28:16 2015 | 
|---|
| [b1f2007d] | 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 | 
|---|
| [51b73452] | 17 |  | 
|---|
| [c92bdcc] | 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 | 
|---|
|  | 25 |  | 
|---|
|  | 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 | 
|---|
|  | 29 | #include "Common/CodeLocation.hpp"   // for CodeLocation | 
|---|
|  | 30 | #include "Common/SemanticError.hpp"  // for SemanticError | 
|---|
|  | 31 | #include "Common/UniqueName.hpp"     // for UniqueName | 
|---|
|  | 32 | #include "Parser/ParserUtility.hpp"  // for maybeBuild, maybeCopy | 
|---|
| [d180746] | 33 |  | 
|---|
| [b2e0df3] | 34 | struct DeclarationNode; | 
|---|
| [dc3fbe5] | 35 | struct InitializerNode; | 
|---|
|  | 36 | struct ExpressionNode; | 
|---|
| [b2e0df3] | 37 | struct StatementNode; | 
|---|
| [51b73452] | 38 |  | 
|---|
| [b1f2007d] | 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; | 
|---|
| [51b73452] | 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 | } | 
|---|
| [51b73452] | 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 | }; | 
|---|
| [51b73452] | 83 |  | 
|---|
| [4a72fef] | 84 | template<typename Node> | 
|---|
|  | 85 | void extend( Node *& list, Node * value ) { | 
|---|
|  | 86 | if ( list ) { | 
|---|
|  | 87 | extend( list->next, value ); | 
|---|
|  | 88 | } else { | 
|---|
|  | 89 | list = value; | 
|---|
|  | 90 | } | 
|---|
|  | 91 | } | 
|---|
|  | 92 |  | 
|---|
| [e5f2a67] | 93 | // Must harmonize with OperName. | 
|---|
| [d9e2280] | 94 | enum class OperKinds { | 
|---|
|  | 95 | // diadic | 
|---|
| [e5f2a67] | 96 | SizeOf, AlignOf, OffsetOf, Plus, Minus, Exp, Mul, Div, Mod, Or, And, | 
|---|
| [d9e2280] | 97 | BitOr, BitAnd, Xor, Cast, LShift, RShift, LThan, GThan, LEThan, GEThan, Eq, Neq, | 
|---|
| [e5f2a67] | 98 | Assign, AtAssn, ExpAssn, MulAssn, DivAssn, ModAssn, PlusAssn, MinusAssn, LSAssn, RSAssn, AndAssn, ERAssn, OrAssn, | 
|---|
| [d9e2280] | 99 | Index, Range, | 
|---|
|  | 100 | // monadic | 
|---|
| [5809461] | 101 | UnPlus, UnMinus, AddressOf, PointTo, Neg, BitNeg, Incr, IncrPost, Decr, DecrPost, | 
|---|
| [d9e2280] | 102 | Ctor, Dtor, | 
|---|
| [c1c1112] | 103 | }; // OperKinds | 
|---|
| [51b73452] | 104 |  | 
|---|
| [7cf8006] | 105 | enum class EnumHiding { Visible, Hide }; | 
|---|
|  | 106 |  | 
|---|
| [e82aa9df] | 107 | struct LabelNode { | 
|---|
| [bb7422a] | 108 | std::vector<ast::Label> labels; | 
|---|
| [e82aa9df] | 109 | }; | 
|---|
|  | 110 |  | 
|---|
| [c8dfcd3] | 111 | std::ostream & operator<<( std::ostream & out, const ParseNode * node ); | 
|---|
| [7ecbb7e] | 112 |  | 
|---|
| [b1f2007d] | 113 | __attribute__((noreturn)) static inline void SemanticError( const ParseNode * obj, const std::string & error ) { | 
|---|
|  | 114 | SemanticError( obj->location, toString( error, obj ) ); | 
|---|
|  | 115 | } | 
|---|
|  | 116 |  | 
|---|
| [51b73452] | 117 | // Local Variables: // | 
|---|
| [b87a5ed] | 118 | // tab-width: 4 // | 
|---|
|  | 119 | // mode: c++ // | 
|---|
|  | 120 | // compile-command: "make install" // | 
|---|
| [51b73452] | 121 | // End: // | 
|---|