Ignore:
Timestamp:
Mar 16, 2017, 6:14:32 PM (7 years ago)
Author:
Peter A. Buhr <pabuhr@…>
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:
615a096
Parents:
6f95000 (diff), 1fbab5a (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/ResolvExpr/Resolver.cc

    r6f95000 r395fc37  
    240240                functionReturn = ResolvExpr::extractResultType( functionDecl->get_functionType() );
    241241                Parent::visit( functionDecl );
     242
     243                // default value expressions have an environment which shouldn't be there and trips up later passes.
     244                // xxx - it might be necessary to somehow keep the information from this environment, but I can't currently
     245                // see how it's useful.
     246                for ( Declaration * d : functionDecl->get_functionType()->get_parameters() ) {
     247                        if ( ObjectDecl * obj = dynamic_cast< ObjectDecl * >( d ) ) {
     248                                if ( SingleInit * init = dynamic_cast< SingleInit * >( obj->get_init() ) ) {
     249                                        delete init->get_value()->get_env();
     250                                        init->get_value()->set_env( nullptr );
     251                                }
     252                        }
     253                }
    242254        }
    243255
Note: See TracChangeset for help on using the changeset viewer.