Changeset d63eeb0 for src/ResolvExpr
- Timestamp:
- Feb 9, 2016, 3:25:05 PM (9 years ago)
- Branches:
- ADT, aaron-thesis, arm-eh, ast-experimental, cleanup-dtors, ctor, deferred_resn, demangler, enum, forall-pointer-decay, gc_noraii, jacob/cs343-translation, jenkins-sandbox, master, memory, new-ast, new-ast-unique-expr, new-env, no_list, persistent-indexer, pthread-emulation, qualifiedEnum, resolv-new, with_gc
- Children:
- 7528ba1
- Parents:
- 771b3c3 (diff), bd85400 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - Location:
- src/ResolvExpr
- Files:
-
- 8 edited
Legend:
- Unmodified
- Added
- Removed
-
TabularUnified src/ResolvExpr/Alternative.cc ¶
r771b3c3 rd63eeb0 17 17 #include "SynTree/Type.h" 18 18 #include "SynTree/Expression.h" 19 #include " utility.h"19 #include "Common/utility.h" 20 20 21 21 namespace ResolvExpr { -
TabularUnified src/ResolvExpr/AlternativeFinder.cc ¶
r771b3c3 rd63eeb0 38 38 #include "Tuples/TupleAssignment.h" 39 39 #include "Tuples/NameMatcher.h" 40 #include " utility.h"40 #include "Common/utility.h" 41 41 42 42 extern bool resolvep; … … 811 811 } 812 812 813 template< typename StructOrUnionType > 814 void AlternativeFinder::addOffsetof( StructOrUnionType *aggInst, const std::string &name ) { 815 std::list< Declaration* > members; 816 aggInst->lookup( name, members ); 817 for ( std::list< Declaration* >::const_iterator i = members.begin(); i != members.end(); ++i ) { 818 if ( DeclarationWithType *dwt = dynamic_cast< DeclarationWithType* >( *i ) ) { 819 alternatives.push_back( Alternative( new OffsetofExpr( aggInst->clone(), dwt->clone() ), env, Cost::zero ) ); 820 renameTypes( alternatives.back().expr ); 821 } else { 822 assert( false ); 823 } 824 } 825 } 826 827 void AlternativeFinder::visit( UntypedOffsetofExpr *offsetofExpr ) { 828 AlternativeFinder funcFinder( indexer, env ); 829 if ( StructInstType *structInst = dynamic_cast< StructInstType* >( offsetofExpr->get_type() ) ) { 830 addOffsetof( structInst, offsetofExpr->get_member() ); 831 } else if ( UnionInstType *unionInst = dynamic_cast< UnionInstType* >( offsetofExpr->get_type() ) ) { 832 addOffsetof( unionInst, offsetofExpr->get_member() ); 833 } 834 } 835 836 void AlternativeFinder::visit( OffsetofExpr *offsetofExpr ) { 837 alternatives.push_back( Alternative( offsetofExpr->clone(), env, Cost::zero ) ); 838 } 839 813 840 void AlternativeFinder::resolveAttr( DeclarationWithType *funcDecl, FunctionType *function, Type *argType, const TypeEnvironment &env ) { 814 841 // assume no polymorphism -
TabularUnified src/ResolvExpr/AlternativeFinder.h ¶
r771b3c3 rd63eeb0 56 56 virtual void visit( ConstantExpr *constantExpr ); 57 57 virtual void visit( SizeofExpr *sizeofExpr ); 58 virtual void visit( AlignofExpr *sizeofExpr ); 58 virtual void visit( AlignofExpr *alignofExpr ); 59 virtual void visit( UntypedOffsetofExpr *offsetofExpr ); 60 virtual void visit( OffsetofExpr *offsetofExpr ); 59 61 virtual void visit( AttrExpr *attrExpr ); 60 62 virtual void visit( LogicalExpr *logicalExpr ); … … 67 69 68 70 private: 71 /// Adds alternatives for member expressions, given the aggregate, conversion cost for that aggregate, and name of the member 69 72 template< typename StructOrUnionType > void addAggMembers( StructOrUnionType *aggInst, Expression *expr, const Cost &newCost, const std::string &name ); 73 /// Adds alternatives for offsetof expressions, given the base type and name of the member 74 template< typename StructOrUnionType > void addOffsetof( StructOrUnionType *aggInst, const std::string &name ); 70 75 bool instantiateFunction( std::list< DeclarationWithType* >& formals, /*const*/ AltList &actuals, bool isVarArgs, OpenVarSet& openVars, TypeEnvironment &resultEnv, AssertionSet &resultNeed, AssertionSet &resultHave ); 71 76 template< typename OutputIterator > -
TabularUnified src/ResolvExpr/AlternativePrinter.cc ¶
r771b3c3 rd63eeb0 20 20 #include "SynTree/Type.h" 21 21 #include "SynTree/Expression.h" 22 #include " utility.h"22 #include "Common/utility.h" 23 23 24 24 namespace ResolvExpr { -
TabularUnified src/ResolvExpr/Resolver.cc ¶
r771b3c3 rd63eeb0 24 24 #include "SynTree/Initializer.h" 25 25 #include "SymTab/Indexer.h" 26 #include " utility.h"26 #include "Common/utility.h" 27 27 28 28 #include <iostream> -
TabularUnified src/ResolvExpr/TypeEnvironment.cc ¶
r771b3c3 rd63eeb0 20 20 #include "SynTree/Type.h" 21 21 #include "SynTree/TypeSubstitution.h" 22 #include " utility.h"22 #include "Common/utility.h" 23 23 24 24 namespace ResolvExpr { -
TabularUnified src/ResolvExpr/Unify.cc ¶
r771b3c3 rd63eeb0 25 25 #include "SynTree/Declaration.h" 26 26 #include "SymTab/Indexer.h" 27 #include " utility.h"27 #include "Common/utility.h" 28 28 29 29 -
TabularUnified src/ResolvExpr/Unify.h ¶
r771b3c3 rd63eeb0 24 24 #include "SymTab/Indexer.h" 25 25 #include "TypeEnvironment.h" 26 #include " utility.h"26 #include "Common/utility.h" 27 27 28 28 namespace ResolvExpr {
Note: See TracChangeset
for help on using the changeset viewer.