- File:
-
- 1 edited
-
src/ResolvExpr/AlternativeFinder.cc (modified) (6 diffs)
Legend:
- Unmodified
- Added
- Removed
-
src/ResolvExpr/AlternativeFinder.cc
r85517ddb r31468a2 42 42 #include "Common/utility.h" 43 43 #include "InitTweak/InitTweak.h" 44 #include "ResolveTypeof.h"45 44 46 45 extern bool resolvep; … … 708 707 void AlternativeFinder::visit( CastExpr *castExpr ) { 709 708 for ( std::list< Type* >::iterator i = castExpr->get_results().begin(); i != castExpr->get_results().end(); ++i ) { 710 *i = resolveTypeof( *i, indexer );711 709 SymTab::validateType( *i, &indexer ); 712 710 adjustExprType( *i, env, indexer ); … … 797 795 798 796 void AlternativeFinder::visit( VariableExpr *variableExpr ) { 799 // not sufficient to clone here, because variable's type may have changed 800 // since the VariableExpr was originally created. 801 alternatives.push_back( Alternative( new VariableExpr( variableExpr->get_var() ), env, Cost::zero ) ); 797 alternatives.push_back( Alternative( variableExpr->clone(), env, Cost::zero ) ); 802 798 } 803 799 … … 808 804 void AlternativeFinder::visit( SizeofExpr *sizeofExpr ) { 809 805 if ( sizeofExpr->get_isType() ) { 810 // xxx - resolveTypeof?811 806 alternatives.push_back( Alternative( sizeofExpr->clone(), env, Cost::zero ) ); 812 807 } else { … … 828 823 void AlternativeFinder::visit( AlignofExpr *alignofExpr ) { 829 824 if ( alignofExpr->get_isType() ) { 830 // xxx - resolveTypeof?831 825 alternatives.push_back( Alternative( alignofExpr->clone(), env, Cost::zero ) ); 832 826 } else { … … 862 856 void AlternativeFinder::visit( UntypedOffsetofExpr *offsetofExpr ) { 863 857 AlternativeFinder funcFinder( indexer, env ); 864 // xxx - resolveTypeof?865 858 if ( StructInstType *structInst = dynamic_cast< StructInstType* >( offsetofExpr->get_type() ) ) { 866 859 addOffsetof( structInst, offsetofExpr->get_member() );
Note:
See TracChangeset
for help on using the changeset viewer.