Changeset 4789f44 for src/GenPoly/Box.cc


Ignore:
Timestamp:
Feb 5, 2016, 12:28:21 PM (9 years ago)
Author:
Rob Schluntz <rschlunt@…>
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, string, with_gc
Children:
408d460, bd85400
Parents:
b4cd03b7 (diff), 2a4b088 (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' into fix-argument-passing-type-warnings

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/GenPoly/Box.cc

    rb4cd03b7 r4789f44  
    123123                };
    124124
    125                 /// Replaces member expressions for polymorphic types with calculated add-field-offset-and-dereference
     125                /// Replaces member expressions for polymorphic types with calculated add-field-offset-and-dereference;
     126                /// also fixes offsetof expressions.
    126127                class MemberExprFixer : public PolyMutator {
    127128                  public:
     
    136137                        virtual Type *mutate( FunctionType *funcType );
    137138                        virtual Expression *mutate( MemberExpr *memberExpr );
     139                        virtual Expression *mutate( OffsetofExpr *offsetofExpr );
    138140                };
    139141
     
    12831285                }
    12841286
     1287                /// Finds the member in the base list that matches the given declaration; returns its index, or -1 if not present
     1288                long findMember( DeclarationWithType *memberDecl, std::list< Declaration* > &baseDecls ) {
     1289                        long i = 0;
     1290                        for(std::list< Declaration* >::const_iterator decl = baseDecls.begin(); decl != baseDecls.end(); ++decl, ++i ) {
     1291                                if ( memberDecl->get_name() != (*decl)->get_name() ) continue;
     1292
     1293                                if ( DeclarationWithType *declWithType = dynamic_cast< DeclarationWithType* >( *decl ) ) {
     1294                                        if ( memberDecl->get_mangleName() == declWithType->get_mangleName() ) return i;
     1295                                        else continue;
     1296                                } else return i;
     1297                        }
     1298                        return -1;
     1299                }
     1300
     1301                /// Returns an index expression into the offset array for a type
     1302                Expression *makeOffsetIndex( Type *objectType, long i ) {
     1303                        std::stringstream offset_namer;
     1304                        offset_namer << i;
     1305                        ConstantExpr *fieldIndex = new ConstantExpr( Constant( new BasicType( Type::Qualifiers(), BasicType::LongUnsignedInt ), offset_namer.str() ) );
     1306                        UntypedExpr *fieldOffset = new UntypedExpr( new NameExpr( "?[?]" ) );
     1307                        fieldOffset->get_args().push_back( new NameExpr( offsetofName( objectType ) ) );
     1308                        fieldOffset->get_args().push_back( fieldIndex );
     1309                        return fieldOffset;
     1310                }
     1311
     1312                /// Returns an expression dereferenced n times
     1313                Expression *makeDerefdVar( Expression *derefdVar, long n ) {
     1314                        for ( int i = 1; i < n; ++i ) {
     1315                                UntypedExpr *derefExpr = new UntypedExpr( new NameExpr( "*?" ) );
     1316                                derefExpr->get_args().push_back( derefdVar );
     1317                                derefdVar = derefExpr;
     1318                        }
     1319                        return derefdVar;
     1320                }
     1321               
    12851322                Expression *MemberExprFixer::mutate( MemberExpr *memberExpr ) {
    12861323                        // mutate, exiting early if no longer MemberExpr
     
    13011338                        if ( ! objectType ) return memberExpr;
    13021339
    1303                         // get base aggregate for type so members can be looked up
    1304                         AggregateDecl *memberBase = 0;
    13051340                        if ( StructInstType *structType = dynamic_cast< StructInstType* >( objectType ) ) {
    1306                                 memberBase = structType->get_baseStruct();
     1341                                // look up offset index
     1342                                long i = findMember( memberExpr->get_member(), structType->get_baseStruct()->get_members() );
     1343                                if ( i == -1 ) return memberExpr;
     1344
     1345                                // replace member expression with pointer to base plus offset
     1346                                UntypedExpr *fieldLoc = new UntypedExpr( new NameExpr( "?+?" ) );
     1347                                fieldLoc->get_args().push_back( makeDerefdVar( varExpr->clone(), varDepth ) );
     1348                                fieldLoc->get_args().push_back( makeOffsetIndex( objectType, i ) );
     1349
     1350                                delete memberExpr;
     1351                                return fieldLoc;
    13071352                        } else if ( UnionInstType *unionType = dynamic_cast< UnionInstType* >( objectType ) ) {
    1308                                 memberBase = unionType->get_baseUnion();
     1353                                // union members are all at offset zero, so build appropriately-dereferenced variable
     1354                                Expression *derefdVar = makeDerefdVar( varExpr->clone(), varDepth );
     1355                                delete memberExpr;
     1356                                return derefdVar;
    13091357                        } else return memberExpr;
    1310 
    1311                         // look up numeric index of member in base aggregate
    1312                         DeclarationWithType *memberDecl = memberExpr->get_member();
    1313                         std::list< Declaration* > &baseDecls = memberBase->get_members();
    1314                         std::list< Declaration* >::const_iterator decl = baseDecls.begin();
    1315                         unsigned long i = 0;
    1316                         for( ; decl != baseDecls.end(); ++decl, ++i ) {
    1317                                 if ( memberDecl->get_name() != (*decl)->get_name() ) continue;
    1318 
    1319                                 if ( DeclarationWithType *declWithType = dynamic_cast< DeclarationWithType* >( *decl ) ) {
    1320                                         if ( memberDecl->get_mangleName() == declWithType->get_mangleName() ) break;
    1321                                         else continue;
    1322                                 } else break;
    1323                         }
    1324                         if ( decl == baseDecls.end() ) return memberExpr;
    1325 
    1326                         // replace member expression with pointer to base plus offset
    1327                         // get offset for field
    1328                         std::stringstream offset_namer;
    1329                         offset_namer << i;
    1330                         ConstantExpr *fieldIndex = new ConstantExpr( Constant( new BasicType( Type::Qualifiers(), BasicType::LongUnsignedInt ), offset_namer.str() ) );
    1331                         UntypedExpr *fieldOffset = new UntypedExpr( new NameExpr( "?[?]" ) );
    1332                         fieldOffset->get_args().push_back( new NameExpr( offsetofName( objectType ) ) );
    1333                         fieldOffset->get_args().push_back( fieldIndex );
    1334                         // build appropriately-dereferenced variable
    1335                         Expression *derefdVar = varExpr->clone();
    1336                         for ( int i = 1; i < varDepth; ++i ) {
    1337                                 UntypedExpr *derefExpr = new UntypedExpr( new NameExpr( "*?" ) );
    1338                                 derefExpr->get_args().push_back( derefdVar );
    1339                                 derefdVar = derefExpr;
    1340                         }
    1341                         // add offset to deref'd variable
    1342                         UntypedExpr *fieldLoc = new UntypedExpr( new NameExpr( "?+?" ) );
    1343                         fieldLoc->get_args().push_back( derefdVar );
    1344                         fieldLoc->get_args().push_back( fieldOffset );
    1345 
    1346                         delete memberExpr;
    1347                         return fieldLoc;
     1358                }
     1359
     1360                Expression *MemberExprFixer::mutate( OffsetofExpr *offsetofExpr ) {
     1361                        // mutate, exiting early if no longer OffsetofExpr
     1362                        Expression *expr = Mutator::mutate( offsetofExpr );
     1363                        offsetofExpr = dynamic_cast< OffsetofExpr* >( expr );
     1364                        if ( ! offsetofExpr ) return expr;
     1365
     1366                        // only mutate expressions for polymorphic structs/unions
     1367                        Type *ty = isPolyType( offsetofExpr->get_type(), scopeTyVars );
     1368                        if ( ! ty ) return offsetofExpr;
     1369
     1370                        if ( StructInstType *structType = dynamic_cast< StructInstType* >( ty ) ) {
     1371                                // replace offsetof expression by index into offset array
     1372                                long i = findMember( offsetofExpr->get_member(), structType->get_baseStruct()->get_members() );
     1373                                if ( i == -1 ) return offsetofExpr;
     1374
     1375                                Expression *offsetInd = makeOffsetIndex( ty, i );
     1376                                delete offsetofExpr;
     1377                                return offsetInd;
     1378                        } else if ( UnionInstType *unionType = dynamic_cast< UnionInstType* >( ty ) ) {
     1379                                // all union members are at offset zero
     1380                                delete offsetofExpr;
     1381                                return new ConstantExpr( Constant( new BasicType( Type::Qualifiers(), BasicType::LongUnsignedInt ), std::string("0") ) );
     1382                        } else return offsetofExpr;
    13481383                }
    13491384
Note: See TracChangeset for help on using the changeset viewer.