Changeset e15ba975


Ignore:
Timestamp:
Sep 8, 2018, 9:47:36 AM (3 years ago)
Author:
Peter A. Buhr <pabuhr@…>
Branches:
aaron-thesis, arm-eh, cleanup-dtors, deferred_resn, jacob/cs343-translation, jenkins-sandbox, master, new-ast, new-ast-unique-expr, no_list, persistent-indexer
Children:
bedb40e
Parents:
7117ac3 (diff), 7e08acf (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 plg2:software/cfa/cfa-cc

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/SymTab/Validate.cc

    r7117ac3 re15ba975  
    403403                        assert( aggr ); // TODO: need to handle forward declarations
    404404                        for ( Declaration * member : aggr->members ) {
    405                                 if ( StructInstType * inst = dynamic_cast< StructInstType * >( child ) ) {
    406                                         if ( StructDecl * aggr = dynamic_cast< StructDecl * >( member ) ) {
    407                                                 if ( aggr->name == inst->name ) {
    408                                                         // TODO: is this case, and other non-TypeInstType cases, necessary?
    409                                                         return new StructInstType( qualType->get_qualifiers(), aggr );
    410                                                 }
    411                                         }
    412                                 } else if ( UnionInstType * inst = dynamic_cast< UnionInstType * >( child ) ) {
    413                                         if ( UnionDecl * aggr = dynamic_cast< UnionDecl * > ( member ) ) {
    414                                                 if ( aggr->name == inst->name ) {
    415                                                         return new UnionInstType( qualType->get_qualifiers(), aggr );
    416                                                 }
    417                                         }
    418                                 } else if ( EnumInstType * inst = dynamic_cast< EnumInstType * >( child ) ) {
    419                                         if ( EnumDecl * aggr = dynamic_cast< EnumDecl * > ( member ) ) {
    420                                                 if ( aggr->name == inst->name ) {
    421                                                         return new EnumInstType( qualType->get_qualifiers(), aggr );
    422                                                 }
    423                                         }
    424                                 } else if ( TypeInstType * inst = dynamic_cast< TypeInstType * >( child ) ) {
     405                                if ( TypeInstType * inst = dynamic_cast< TypeInstType * >( child ) ) {
    425406                                        // name on the right is a typedef
    426407                                        if ( NamedTypeDecl * aggr = dynamic_cast< NamedTypeDecl * > ( member ) ) {
     
    429410                                                        Type * ret = aggr->base->clone();
    430411                                                        ret->get_qualifiers() = qualType->get_qualifiers();
     412                                                        TypeSubstitution sub = parent->genericSubstitution();
     413                                                        sub.apply(ret);
    431414                                                        return ret;
    432415                                                }
Note: See TracChangeset for help on using the changeset viewer.