source: translator/Parser/InitializerNode.cc @ c11e31c

ADTaaron-thesisarm-ehast-experimentalcleanup-dtorsctordeferred_resndemanglerenumforall-pointer-decaygc_noraiijacob/cs343-translationjenkins-sandboxmemorynew-astnew-ast-unique-exprnew-envno_listpersistent-indexerpthread-emulationqualifiedEnumresolv-newstringwith_gc
Last change on this file since c11e31c was bdd516a, checked in by Peter A. Buhr <pabuhr@…>, 9 years ago

fixed sizeof type variable, find lowest cost alternative for sizeof expression, removed unused classes, added compiler flag, remove temporary file for -CFA, formatting

  • Property mode set to 100644
File size: 2.3 KB
RevLine 
[51b7345]1#include <cassert>
[d9a0e76]2#include <iostream>
3using namespace std;
[51b7345]4
[bdd516a]5#include "ParseNode.h"
6#include "SynTree/Expression.h"
7#include "SynTree/Initializer.h"
8
[51b7345]9InitializerNode::InitializerNode( ExpressionNode *_expr, bool aggrp, ExpressionNode *des )
[3848e0e]10        : expr( _expr ), aggregate( aggrp ), designator( des ), kids( 0 ) {
11    if ( aggrp )
12        kids = dynamic_cast< InitializerNode *>( get_link() );
[51b7345]13
[3848e0e]14    if ( kids != 0 )
15        set_link( 0 );
[51b7345]16}
17
18InitializerNode::InitializerNode( InitializerNode *init, bool aggrp, ExpressionNode *des )
[0b8cd722]19    : expr( 0 ), aggregate( aggrp ), designator( des ), kids( 0 ) {
[3848e0e]20    if ( init != 0 )
21        set_link(init);
[51b7345]22
[3848e0e]23    if ( aggrp )
24        kids = dynamic_cast< InitializerNode *>( get_link() );
[51b7345]25
[3848e0e]26    if ( kids != 0 )
27        set_next( 0 );
[51b7345]28}
29
30InitializerNode::~InitializerNode() {
[3848e0e]31    delete expr;
[51b7345]32}
33
34void InitializerNode::print( std::ostream &os, int indent ) const {
[3848e0e]35    os << std::string(indent, ' ') << "Initializer expression" << std::endl;
[51b7345]36}
37
38void InitializerNode::printOneLine( std::ostream &os ) const {
[3848e0e]39    if ( ! aggregate ) {
40        if ( designator != 0 ) {
41            os << "designated by: (";
[17cd4eb]42            ExpressionNode *curdes = designator;
[3848e0e]43            while( curdes != 0) {
44                curdes->printOneLine(os);
45                curdes = (ExpressionNode *)(curdes->get_link());
46                if ( curdes ) os << ", ";
[17cd4eb]47            } // while
[3848e0e]48            os << ")";
[17cd4eb]49        } // if
[3848e0e]50        if ( expr ) expr->printOneLine(os);
51    } else {  // It's an aggregate
52        os << "[--";
53        if ( next_init() != 0 )
54            next_init()->printOneLine(os);
55        if (aggregate) os << "--]";
[17cd4eb]56    } // if
[51b7345]57
[3848e0e]58    InitializerNode *moreInit;
59    if  ( get_link() != 0 && ((moreInit = dynamic_cast< InitializerNode * >( get_link() ) ) != 0) )
60        moreInit->printOneLine( os );
[51b7345]61}
62
63Initializer *InitializerNode::build() const {
[3848e0e]64    // if ( get_expression() == 0 ) return 0;  // XXX (?)
[51b7345]65
[3848e0e]66    if ( aggregate ) {
67        assert( next_init() != 0 );
[51b7345]68
[3848e0e]69        std::list< Initializer *> initlist;
70        buildList<Initializer, InitializerNode>( next_init(), initlist );
[51b7345]71
[3848e0e]72        std::list< Expression *> designlist;
[d9a0e76]73
74        if ( designator != 0 ) {
[3848e0e]75            buildList<Expression, ExpressionNode>( designator, designlist );
[d9a0e76]76        } // if
[51b7345]77
[3848e0e]78        return new ListInit( initlist, designlist );
79    } else {
80        std::list< Expression *> designators;
[51b7345]81
[3848e0e]82        if ( designator != 0 )
83            buildList<Expression, ExpressionNode>( designator, designators );
[51b7345]84
[3848e0e]85        if ( get_expression() != 0)
86            return new SingleInit( get_expression()->build(), designators );
[17cd4eb]87    } // if
[51b7345]88
[3848e0e]89    return 0;
[51b7345]90}
Note: See TracBrowser for help on using the repository browser.