Changes in / [eca3d10:1cb758f2]
- Location:
- src
- Files:
-
- 10 edited
Legend:
- Unmodified
- Added
- Removed
-
src/GenPoly/Box.cc
reca3d10 r1cb758f2 756 756 Type * newType = arg->get_result()->clone(); 757 757 if ( env ) env->apply( newType ); 758 std:: auto_ptr<Type> manager( newType );758 std::unique_ptr<Type> manager( newType ); 759 759 if ( isPolyType( newType ) ) { 760 760 // if the argument's type is polymorphic, we don't need to box again! … … 774 774 newObj->get_type()->get_qualifiers() = Type::Qualifiers(); // TODO: is this right??? 775 775 stmtsToAdd.push_back( new DeclStmt( noLabels, newObj ) ); 776 UntypedExpr *assign = new UntypedExpr( new NameExpr( "?=?" ) ); 776 UntypedExpr *assign = new UntypedExpr( new NameExpr( "?=?" ) ); // TODO: why doesn't this just use initialization syntax? 777 777 assign->get_args().push_back( new VariableExpr( newObj ) ); 778 778 assign->get_args().push_back( arg ); -
src/InitTweak/InitTweak.cc
reca3d10 r1cb758f2 418 418 assertf( ! tuple->get_exprs().empty(), "TupleAssignExpr somehow has empty tuple expr." ); 419 419 return getCallArg( tuple->get_exprs().front(), pos ); 420 } else if ( ImplicitCopyCtorExpr * copyCtor = dynamic_cast< ImplicitCopyCtorExpr * >( callExpr ) ) { 421 return getCallArg( copyCtor->callExpr, pos ); 420 422 } else { 421 423 assertf( false, "Unexpected expression type passed to getCallArg: %s", toString( callExpr ).c_str() ); … … 450 452 } else if ( ApplicationExpr * appExpr = dynamic_cast< ApplicationExpr * >( func ) ) { 451 453 return handleDerefName( appExpr ); 454 } else if ( ConstructorExpr * ctorExpr = dynamic_cast< ConstructorExpr * >( func ) ) { 455 return funcName( getCallArg( ctorExpr->get_callExpr(), 0 ) ); 452 456 } else { 453 assertf( false, "Unexpected expression type being called as a function in call expression ");457 assertf( false, "Unexpected expression type being called as a function in call expression: %s", toString( func ).c_str() ); 454 458 } 455 459 } -
src/ResolvExpr/AlternativeFinder.cc
reca3d10 r1cb758f2 698 698 699 699 void AlternativeFinder::visit( UntypedExpr *untypedExpr ) { 700 bool doneInit = false;701 AlternativeFinder funcOpFinder( indexer, env );702 703 AlternativeFinder funcFinder( indexer, env );704 705 700 { 706 701 std::string fname = InitTweak::getFunctionName( untypedExpr ); … … 715 710 } 716 711 712 AlternativeFinder funcFinder( indexer, env ); 717 713 funcFinder.findWithAdjustment( untypedExpr->get_function() ); 714 // if there are no function alternatives, then proceeding is a waste of time. 715 if ( funcFinder.alternatives.empty() ) return; 716 718 717 std::list< AlternativeFinder > argAlternatives; 719 718 findSubExprs( untypedExpr->begin_args(), untypedExpr->end_args(), back_inserter( argAlternatives ) ); … … 725 724 // if not tuple assignment, assignment is taken care of as a normal function call 726 725 Tuples::handleTupleAssignment( *this, untypedExpr, possibilities ); 726 727 // find function operators 728 AlternativeFinder funcOpFinder( indexer, env ); 729 NameExpr *opExpr = new NameExpr( "?()" ); 730 try { 731 funcOpFinder.findWithAdjustment( opExpr ); 732 } catch( SemanticError &e ) { 733 // it's ok if there aren't any defined function ops 734 } 735 PRINT( 736 std::cerr << "known function ops:" << std::endl; 737 printAlts( funcOpFinder.alternatives, std::cerr, 8 ); 738 ) 727 739 728 740 AltList candidates; … … 754 766 } // if 755 767 } // if 756 } else { 757 // seek a function operator that's compatible 758 if ( ! doneInit ) { 759 doneInit = true; 760 NameExpr *opExpr = new NameExpr( "?()" ); 761 try { 762 funcOpFinder.findWithAdjustment( opExpr ); 763 } catch( SemanticError &e ) { 764 // it's ok if there aren't any defined function ops 765 } 766 PRINT( 767 std::cerr << "known function ops:" << std::endl; 768 printAlts( funcOpFinder.alternatives, std::cerr, 8 ); 769 ) 770 } 771 772 for ( AltList::iterator funcOp = funcOpFinder.alternatives.begin(); funcOp != funcOpFinder.alternatives.end(); ++funcOp ) { 773 // check if the type is pointer to function 774 if ( PointerType *pointer = dynamic_cast< PointerType* >( funcOp->expr->get_result()->stripReferences() ) ) { 775 if ( FunctionType *function = dynamic_cast< FunctionType* >( pointer->get_base() ) ) { 776 referenceToRvalueConversion( funcOp->expr ); 777 for ( std::list< AltList >::iterator actualAlt = possibilities.begin(); actualAlt != possibilities.end(); ++actualAlt ) { 778 AltList currentAlt; 779 currentAlt.push_back( *func ); 780 currentAlt.insert( currentAlt.end(), actualAlt->begin(), actualAlt->end() ); 781 makeFunctionAlternatives( *funcOp, function, currentAlt, std::back_inserter( candidates ) ); 782 } // for 783 } // if 768 } 769 770 // try each function operator ?() with the current function alternative and each of the argument combinations 771 for ( AltList::iterator funcOp = funcOpFinder.alternatives.begin(); funcOp != funcOpFinder.alternatives.end(); ++funcOp ) { 772 // check if the type is pointer to function 773 if ( PointerType *pointer = dynamic_cast< PointerType* >( funcOp->expr->get_result()->stripReferences() ) ) { 774 if ( FunctionType *function = dynamic_cast< FunctionType* >( pointer->get_base() ) ) { 775 referenceToRvalueConversion( funcOp->expr ); 776 for ( std::list< AltList >::iterator actualAlt = possibilities.begin(); actualAlt != possibilities.end(); ++actualAlt ) { 777 AltList currentAlt; 778 currentAlt.push_back( *func ); 779 currentAlt.insert( currentAlt.end(), actualAlt->begin(), actualAlt->end() ); 780 makeFunctionAlternatives( *funcOp, function, currentAlt, std::back_inserter( candidates ) ); 781 } // for 784 782 } // if 785 } // for786 } // if783 } // if 784 } // for 787 785 } catch ( SemanticError &e ) { 788 786 errors.append( e ); -
src/ResolvExpr/CastCost.cc
reca3d10 r1cb758f2 58 58 return Cost::safe; 59 59 } else if ( ReferenceType * refType = dynamic_cast< ReferenceType * > ( dest ) ) { 60 return convertToReferenceCost( src, refType, indexer, env ); 60 return convertToReferenceCost( src, refType, indexer, env, [](Type * t1, Type * t2, const TypeEnvironment & env, const SymTab::Indexer & indexer) { 61 return ptrsCastable( t1, t2, env, indexer ); 62 }); 61 63 } else { 62 64 CastCost converter( dest, indexer, env ); -
src/ResolvExpr/ConversionCost.cc
reca3d10 r1cb758f2 40 40 #define PRINT(x) 41 41 #endif 42 43 42 Cost conversionCost( Type *src, Type *dest, const SymTab::Indexer &indexer, const TypeEnvironment &env ) { 44 43 if ( TypeInstType *destAsTypeInst = dynamic_cast< TypeInstType* >( dest ) ) { … … 78 77 } else if ( ReferenceType * refType = dynamic_cast< ReferenceType * > ( dest ) ) { 79 78 PRINT( std::cerr << "conversionCost: dest is reference" << std::endl; ) 80 return convertToReferenceCost( src, refType, indexer, env ); 79 return convertToReferenceCost( src, refType, indexer, env, [](Type * t1, Type * t2, const TypeEnvironment & env, const SymTab::Indexer &){ 80 return ptrsAssignable( t1, t2, env ); 81 }); 81 82 } else { 82 83 ConversionCost converter( dest, indexer, env ); … … 90 91 } 91 92 92 Cost convertToReferenceCost( Type * src, Type * dest, int diff, const SymTab::Indexer & indexer, const TypeEnvironment & env ) {93 Cost convertToReferenceCost( Type * src, Type * dest, int diff, const SymTab::Indexer & indexer, const TypeEnvironment & env, PtrsFunction func ) { 93 94 PRINT( std::cerr << "convert to reference cost..." << std::endl; ) 94 95 if ( diff > 0 ) { 95 96 // TODO: document this 96 Cost cost = convertToReferenceCost( safe_dynamic_cast< ReferenceType * >( src )->get_base(), dest, diff-1, indexer, env );97 Cost cost = convertToReferenceCost( safe_dynamic_cast< ReferenceType * >( src )->get_base(), dest, diff-1, indexer, env, func ); 97 98 cost.incReference(); 98 99 return cost; 99 100 } else if ( diff < -1 ) { 100 101 // TODO: document this 101 Cost cost = convertToReferenceCost( src, safe_dynamic_cast< ReferenceType * >( dest )->get_base(), diff+1, indexer, env );102 Cost cost = convertToReferenceCost( src, safe_dynamic_cast< ReferenceType * >( dest )->get_base(), diff+1, indexer, env, func ); 102 103 cost.incReference(); 103 104 return cost; … … 110 111 return Cost::safe; 111 112 } else { // xxx - this discards reference qualifiers from consideration -- reducing qualifiers is a safe conversion; is this right? 112 int assignResult = ptrsAssignable( srcAsRef->get_base(), destAsRef->get_base(), env);113 int assignResult = func( srcAsRef->get_base(), destAsRef->get_base(), env, indexer ); 113 114 PRINT( std::cerr << "comparing references: " << assignResult << " " << srcAsRef << " " << destAsRef << std::endl; ) 114 115 if ( assignResult < 0 ) { … … 157 158 } 158 159 159 Cost convertToReferenceCost( Type * src, ReferenceType * dest, const SymTab::Indexer & indexer, const TypeEnvironment & env ) {160 Cost convertToReferenceCost( Type * src, ReferenceType * dest, const SymTab::Indexer & indexer, const TypeEnvironment & env, PtrsFunction func ) { 160 161 int sdepth = src->referenceDepth(), ddepth = dest->referenceDepth(); 161 return convertToReferenceCost( src, dest, sdepth-ddepth, indexer, env );162 return convertToReferenceCost( src, dest, sdepth-ddepth, indexer, env, func ); 162 163 } 163 164 -
src/ResolvExpr/ConversionCost.h
reca3d10 r1cb758f2 16 16 #pragma once 17 17 18 #include <functional> // for function 19 18 20 #include "Cost.h" // for Cost 19 21 #include "SynTree/Visitor.h" // for Visitor … … 21 23 22 24 namespace SymTab { 23 class Indexer;25 class Indexer; 24 26 } // namespace SymTab 25 27 26 28 namespace ResolvExpr { 27 class TypeEnvironment;29 class TypeEnvironment; 28 30 29 31 class ConversionCost : public Visitor { … … 55 57 }; 56 58 57 Cost convertToReferenceCost( Type * src, ReferenceType * dest, const SymTab::Indexer & indexer, const TypeEnvironment & env ); 59 typedef std::function<int(Type *, Type *, const TypeEnvironment &, const SymTab::Indexer &)> PtrsFunction; 60 Cost convertToReferenceCost( Type * src, ReferenceType * dest, const SymTab::Indexer & indexer, const TypeEnvironment & env, PtrsFunction func ); 58 61 } // namespace ResolvExpr 59 62 -
src/SymTab/Indexer.cc
reca3d10 r1cb758f2 345 345 leaveScope(); 346 346 347 debugPrint( "Adding context " << aggregateDecl->get_name() << std::endl );347 debugPrint( "Adding trait " << aggregateDecl->get_name() << std::endl ); 348 348 addTrait( aggregateDecl ); 349 349 } -
src/SymTab/Validate.cc
reca3d10 r1cb758f2 467 467 return; 468 468 } 469 470 // handle other traits 469 471 TraitDecl *traitDecl = indexer->lookupTrait( traitInst->get_name() ); 470 472 if ( ! traitDecl ) { -
src/SynTree/Expression.cc
reca3d10 r1cb758f2 645 645 } 646 646 } 647 // ensure that StmtExpr has a result type 648 if ( ! result ) { 649 set_result( new VoidType( Type::Qualifiers() ) ); 650 } 647 651 } 648 652 StmtExpr::StmtExpr( const StmtExpr &other ) : Expression( other ), statements( other.statements->clone() ) { -
src/tests/multiDimension.c
reca3d10 r1cb758f2 59 59 } 60 60 61 // ensure constructed const arrays continue to compile 62 const int global[1] = { -2 }; 63 61 64 int main() { 62 65 X abc[4][4] = {
Note: See TracChangeset
for help on using the changeset viewer.