[51587aa] | 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 | // |
---|
[6eb8948] | 7 | // Tuples.h -- |
---|
[51587aa] | 8 | // |
---|
[843054c2] | 9 | // Author : Rodolfo G. Esteves |
---|
[51587aa] | 10 | // Created On : Mon May 18 07:44:20 2015 |
---|
[d249e0b] | 11 | // Last Modified By : Henry Xue |
---|
| 12 | // Last Modified On : Mon Aug 23 15:36:09 2021 |
---|
| 13 | // Update Count : 19 |
---|
[51587aa] | 14 | // |
---|
| 15 | |
---|
[6b0b624] | 16 | #pragma once |
---|
[51b7345] | 17 | |
---|
| 18 | #include <string> |
---|
[c43c171] | 19 | #include <vector> |
---|
[51b7345] | 20 | |
---|
[9b4f329] | 21 | #include "AST/Fwd.hpp" |
---|
| 22 | #include "AST/Node.hpp" |
---|
[51b7345] | 23 | #include "SynTree/Expression.h" |
---|
| 24 | #include "SynTree/Declaration.h" |
---|
| 25 | #include "SynTree/Type.h" |
---|
| 26 | |
---|
[141b786] | 27 | #include "ResolvExpr/AlternativeFinder.h" |
---|
[432ce7a] | 28 | #include "ResolvExpr/CandidateFinder.hpp" |
---|
[141b786] | 29 | |
---|
[51b7345] | 30 | namespace Tuples { |
---|
[6eb8948] | 31 | // TupleAssignment.cc |
---|
[77bfc80] | 32 | void handleTupleAssignment( ResolvExpr::AlternativeFinder & currentFinder, UntypedExpr * assign, |
---|
[c43c171] | 33 | std::vector< ResolvExpr::AlternativeFinder >& args ); |
---|
[432ce7a] | 34 | void handleTupleAssignment( |
---|
| 35 | ResolvExpr::CandidateFinder & finder, const ast::UntypedExpr * assign, |
---|
| 36 | std::vector< ResolvExpr::CandidateFinder > & args ); |
---|
[77bfc80] | 37 | |
---|
[6eb8948] | 38 | // TupleExpansion.cc |
---|
[bf32bb8] | 39 | /// expands z.[a, b.[x, y], c] into [z.a, z.b.x, z.b.y, z.c], inserting UniqueExprs as appropriate |
---|
| 40 | void expandMemberTuples( std::list< Declaration * > & translationUnit ); |
---|
[d249e0b] | 41 | void expandMemberTuples( ast::TranslationUnit & translationUnit ); |
---|
[bf32bb8] | 42 | |
---|
| 43 | /// replaces tuple-related elements, such as TupleType, TupleExpr, TupleAssignExpr, etc. |
---|
[6eb8948] | 44 | void expandTuples( std::list< Declaration * > & translationUnit ); |
---|
[3c13c03] | 45 | |
---|
[bf32bb8] | 46 | /// replaces UniqueExprs with a temporary variable and one call |
---|
| 47 | void expandUniqueExpr( std::list< Declaration * > & translationUnit ); |
---|
[01d433e] | 48 | void expandUniqueExpr( ast::TranslationUnit & translationUnit ); |
---|
[aefcc3b] | 49 | |
---|
[bf32bb8] | 50 | /// returns VoidType if any of the expressions have Voidtype, otherwise TupleType of the Expression result types |
---|
| 51 | Type * makeTupleType( const std::list< Expression * > & exprs ); |
---|
[9b4f329] | 52 | const ast::Type * makeTupleType( const std::vector<ast::ptr<ast::Expr>> & exprs ); |
---|
[65660bd] | 53 | |
---|
[8bf784a] | 54 | /// returns a TypeInstType if `type` is a ttype, nullptr otherwise |
---|
| 55 | TypeInstType * isTtype( Type * type ); |
---|
[fd642d2] | 56 | const TypeInstType * isTtype( const Type * type ); |
---|
[77bfc80] | 57 | const ast::TypeInstType * isTtype( const ast::Type * type ); |
---|
[8bf784a] | 58 | |
---|
[bf32bb8] | 59 | /// returns true if the expression may contain side-effects. |
---|
[335d81f] | 60 | bool maybeImpure( const Expression * expr ); |
---|
[bc92bee] | 61 | bool maybeImpure( const ast::Expr * expr ); |
---|
[9f10c4b8] | 62 | |
---|
[b910d15] | 63 | /// Returns true if the expression may contain side-effect, |
---|
| 64 | /// ignoring the presence of unique expressions. |
---|
[335d81f] | 65 | bool maybeImpureIgnoreUnique( const Expression * expr ); |
---|
[b910d15] | 66 | bool maybeImpureIgnoreUnique( const ast::Expr * expr ); |
---|
[51b7345] | 67 | } // namespace Tuples |
---|
| 68 | |
---|
[51587aa] | 69 | // Local Variables: // |
---|
| 70 | // tab-width: 4 // |
---|
| 71 | // mode: c++ // |
---|
| 72 | // compile-command: "make install" // |
---|
| 73 | // End: // |
---|