source: src/ResolvExpr/ConversionCost.h@ 1cf2a9b

ADT arm-eh ast-experimental enum forall-pointer-decay jacob/cs343-translation new-ast new-ast-unique-expr pthread-emulation qualifiedEnum
Last change on this file since 1cf2a9b was cf32116, checked in by Andrew Beach <ajbeach@…>, 6 years ago

Implemented expression based lvalue resolution on new ast.

  • Property mode set to 100644
File size: 4.6 KB
RevLine 
[a32b204]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//
[2463d0e]7// ConversionCost.h --
[a32b204]8//
9// Author : Richard C. Bilson
10// Created On : Sun May 17 09:37:28 2015
[fb2bde4]11// Last Modified By : Andrew Beach
[cf32116]12// Last Modified On : Tue Oct 4 14:59:00 2019
13// Update Count : 7
[a32b204]14//
15
[6b0b624]16#pragma once
[51b73452]17
[0c6596f]18#include <functional> // for function
19
[ea6332d]20#include "Cost.h" // for Cost
[bd0b6b62]21
[fb2bde4]22#include "AST/Fwd.hpp"
23#include "AST/Pass.hpp" // for WithShortCircuiting
[bd0b6b62]24#include "Common/PassVisitor.h"
[ea6332d]25#include "SynTree/Visitor.h" // for Visitor
26#include "SynTree/SynTree.h" // for Visitor Nodes
27
28namespace SymTab {
[0c6596f]29 class Indexer;
[ea6332d]30} // namespace SymTab
[51b73452]31
32namespace ResolvExpr {
[0c6596f]33 class TypeEnvironment;
[ea6332d]34
[7d01cf44]35 typedef std::function<Cost(const Type *, const Type *, bool,
36 const SymTab::Indexer &, const TypeEnvironment &)> CostFunction;
37
[bd0b6b62]38 struct ConversionCost : public WithShortCircuiting {
[a32b204]39 public:
[7d01cf44]40 ConversionCost( const Type * dest, bool srcIsLvalue,
41 const SymTab::Indexer &indexer, const TypeEnvironment &env, CostFunction );
[2463d0e]42
[a32b204]43 Cost get_cost() const { return cost; }
44
[7870799]45 void previsit( const BaseSyntaxNode * ) { visit_children = false; }
[bd0b6b62]46
[7870799]47 void postvisit( const VoidType * voidType );
48 void postvisit( const BasicType * basicType );
49 void postvisit( const PointerType * pointerType );
50 void postvisit( const ArrayType * arrayType );
51 void postvisit( const ReferenceType * refType );
52 void postvisit( const FunctionType * functionType );
53 void postvisit( const StructInstType * aggregateUseType );
54 void postvisit( const UnionInstType * aggregateUseType );
55 void postvisit( const EnumInstType * aggregateUseType );
56 void postvisit( const TraitInstType * aggregateUseType );
57 void postvisit( const TypeInstType * aggregateUseType );
58 void postvisit( const TupleType * tupleType );
59 void postvisit( const VarArgsType * varArgsType );
60 void postvisit( const ZeroType * zeroType );
61 void postvisit( const OneType * oneType );
[a32b204]62 protected:
[7870799]63 const Type * dest;
[7d01cf44]64 bool srcIsLvalue;
[a32b204]65 const SymTab::Indexer &indexer;
66 Cost cost;
67 const TypeEnvironment &env;
[721cd19f]68 CostFunction costFunc;
[a32b204]69 };
[2463d0e]70
[7870799]71 typedef std::function<int(const Type *, const Type *, const SymTab::Indexer &, const TypeEnvironment &)> PtrsFunction;
[7d01cf44]72 Cost convertToReferenceCost( const Type * src, const ReferenceType * dest, bool srcIsLvalue,
73 const SymTab::Indexer & indexer, const TypeEnvironment & env, PtrsFunction func );
[fb2bde4]74
75// Some function pointer types, differ in return type.
[cf32116]76using CostCalculation = std::function<Cost(const ast::Type *, const ast::Type *, bool,
[fb2bde4]77 const ast::SymbolTable &, const ast::TypeEnvironment &)>;
[cf32116]78using PtrsCalculation = std::function<int(const ast::Type *, const ast::Type *,
[fb2bde4]79 const ast::SymbolTable &, const ast::TypeEnvironment &)>;
80
[3c89751]81#warning when the old ConversionCost is removed, get ride of the _new suffix.
[fb2bde4]82class ConversionCost_new : public ast::WithShortCircuiting {
[3c89751]83protected:
[fb2bde4]84 const ast::Type * dst;
[cf32116]85 bool srcIsLvalue;
[fb2bde4]86 const ast::SymbolTable & symtab;
87 const ast::TypeEnvironment & env;
88 CostCalculation costCalc;
89public:
90 Cost cost;
91
[cf32116]92 ConversionCost_new( const ast::Type * dst, bool srcIsLvalue, const ast::SymbolTable & symtab,
[fb2bde4]93 const ast::TypeEnvironment & env, CostCalculation costCalc ) :
[cf32116]94 dst( dst ), srcIsLvalue( srcIsLvalue ), symtab( symtab ), env( env ),
95 costCalc( costCalc ), cost( Cost::infinity )
[fb2bde4]96 {}
97
98 void previsit( const ast::Node * ) { visit_children = false; }
99
100 void postvisit( const ast::VoidType * voidType );
101 void postvisit( const ast::BasicType * basicType );
102 void postvisit( const ast::PointerType * pointerType );
103 void postvisit( const ast::ArrayType * arrayType );
104 void postvisit( const ast::ReferenceType * refType );
105 void postvisit( const ast::FunctionType * functionType );
106 void postvisit( const ast::StructInstType * structInstType );
107 void postvisit( const ast::UnionInstType * unionInstType );
108 void postvisit( const ast::EnumInstType * enumInstType );
109 void postvisit( const ast::TraitInstType * traitInstType );
110 void postvisit( const ast::TypeInstType * typeInstType );
111 void postvisit( const ast::TupleType * tupleType );
112 void postvisit( const ast::VarArgsType * varArgsType );
113 void postvisit( const ast::ZeroType * zeroType );
114 void postvisit( const ast::OneType * oneType );
115};
116
117Cost convertToReferenceCost( const ast::Type * src, const ast::ReferenceType * dest,
[cf32116]118 bool srcIsLvalue, const ast::SymbolTable & indexer, const ast::TypeEnvironment & env,
119 PtrsCalculation func );
[fb2bde4]120
[51b73452]121} // namespace ResolvExpr
122
[a32b204]123// Local Variables: //
124// tab-width: 4 //
125// mode: c++ //
126// compile-command: "make install" //
127// End: //
Note: See TracBrowser for help on using the repository browser.