source: src/ResolvExpr/ConversionCost.h@ 4d2d7e27

Last change on this file since 4d2d7e27 was fed6a0f, checked in by Andrew Beach <ajbeach@…>, 3 years ago

Header Clean-up: Moving more declarations to the header of the implementation file.

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