Changeset b3f252a for src/GenPoly/Box.cc


Ignore:
Timestamp:
Sep 7, 2017, 10:36:35 AM (7 years ago)
Author:
Thierry Delisle <tdelisle@…>
Branches:
ADT, aaron-thesis, arm-eh, ast-experimental, cleanup-dtors, deferred_resn, demangler, enum, forall-pointer-decay, jacob/cs343-translation, jenkins-sandbox, master, new-ast, new-ast-unique-expr, new-env, no_list, persistent-indexer, pthread-emulation, qualifiedEnum, resolv-new, with_gc
Children:
e0886db
Parents:
871cdb4 (diff), 416cc86 (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.
Message:

Merge branch 'master' of plg.uwaterloo.ca:software/cfa/cfa-cc

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/GenPoly/Box.cc

    r871cdb4 rb3f252a  
    141141                        virtual StructDecl *mutate( StructDecl *structDecl ) override;
    142142                        virtual UnionDecl *mutate( UnionDecl *unionDecl ) override;
     143                        virtual TraitDecl *mutate( TraitDecl *unionDecl ) override;
    143144                        virtual TypeDecl *mutate( TypeDecl *typeDecl ) override;
    144145                        virtual TypedefDecl *mutate( TypedefDecl *typedefDecl ) override;
     
    216217                  private:
    217218                };
    218 
    219219        } // anonymous namespace
    220220
     
    896896                                addAdapterParams( adapteeApp, arg, param, adapterType->get_parameters().end(), realParam, tyVars );
    897897                                bodyStmt = new ExprStmt( noLabels, adapteeApp );
    898 //                      } else if ( isPolyType( adaptee->get_returnVals().front()->get_type(), tyVars ) ) {
    899898                        } else if ( isDynType( adaptee->get_returnVals().front()->get_type(), tyVars ) ) {
    900899                                // return type T
     
    12991298                }
    13001299
    1301                 /// determines if `pref` is a prefix of `str`
    1302                 bool isPrefix( const std::string & str, const std::string & pref ) {
    1303                         if ( pref.size() > str.size() ) return false;
    1304                         auto its = std::mismatch( pref.begin(), pref.end(), str.begin() );
    1305                         return its.first == pref.end();
    1306                 }
    1307 
    13081300                DeclarationWithType * Pass2::mutate( FunctionDecl *functionDecl ) {
    13091301                        functionDecl = safe_dynamic_cast< FunctionDecl * > ( handleDecl( functionDecl ) );
     
    13521344                }
    13531345
     1346                TraitDecl * Pass2::mutate( TraitDecl *aggDecl ) {
     1347                        return handleAggDecl( aggDecl );
     1348                }
     1349
    13541350                TypeDecl * Pass2::mutate( TypeDecl *typeDecl ) {
    13551351                        addToTyVarMap( typeDecl, scopeTyVars );
     
    13771373                Type *Pass2::mutate( FunctionType *funcType ) {
    13781374                        scopeTyVars.beginScope();
     1375
    13791376                        makeTyVarMap( funcType, scopeTyVars );
    13801377
     
    15501547                                        // (alloca was previously used, but can't be safely used in loops)
    15511548                                        Type *declType = objectDecl->get_type();
    1552                                         std::string bufName = bufNamer.newName();
    1553                                         ObjectDecl *newBuf = new ObjectDecl( bufName, Type::StorageClasses(), LinkageSpec::C, 0,
     1549                                        ObjectDecl *newBuf = new ObjectDecl( bufNamer.newName(), Type::StorageClasses(), LinkageSpec::C, 0,
    15541550                                                new ArrayType( Type::Qualifiers(), new BasicType( Type::Qualifiers(), BasicType::Kind::Char), new NameExpr( sizeofName( mangleType(declType) ) ),
    1555                                                 true, false, std::list<Attribute*>{ new Attribute( std::string{"aligned"}, std::list<Expression*>{ new ConstantExpr( Constant::from_int(8) ) } ) } ), 0 );
     1551                                                true, false, std::list<Attribute*>{ new Attribute( "aligned", std::list<Expression*>{ new ConstantExpr( Constant::from_int(8) ) } ) } ), 0 );
    15561552                                        stmtsToAdd.push_back( new DeclStmt( noLabels, newBuf ) );
    15571553
    15581554                                        delete objectDecl->get_init();
    1559 
    1560                                         objectDecl->set_init( new SingleInit( new NameExpr( bufName ) ) );
     1555                                        objectDecl->set_init( new SingleInit( new VariableExpr( newBuf ) ) );
    15611556                                }
    15621557                        }
Note: See TracChangeset for help on using the changeset viewer.