source: src/Parser/InitializerNode.cc@ e85a8631

ADT aaron-thesis arm-eh ast-experimental cleanup-dtors ctor deferred_resn demangler enum forall-pointer-decay jacob/cs343-translation jenkins-sandbox new-ast new-ast-unique-expr new-env no_list persistent-indexer pthread-emulation qualifiedEnum resolv-new with_gc
Last change on this file since e85a8631 was 4f147cc, checked in by Thierry Delisle <tdelisle@…>, 9 years ago

fixed some more memory leaks and added safe_dynamic_cast to assert.h

  • Property mode set to 100644
File size: 3.0 KB
RevLine 
[b87a5ed]1//
2// Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
[974906e2]7// InitializerNode.cc --
8//
[b87a5ed]9// Author : Rodolfo G. Esteves
10// Created On : Sat May 16 13:20:24 2015
[8e9cbb2]11// Last Modified By : Peter A. Buhr
[7880579]12// Last Modified On : Mon Aug 15 18:27:02 2016
13// Update Count : 20
[974906e2]14//
[b87a5ed]15
[51b73452]16#include <cassert>
[d9a0e76]17#include <iostream>
18using namespace std;
[51b73452]19
[bdd516a]20#include "ParseNode.h"
21#include "SynTree/Expression.h"
22#include "SynTree/Initializer.h"
23
[51b73452]24InitializerNode::InitializerNode( ExpressionNode *_expr, bool aggrp, ExpressionNode *des )
[974906e2]25 : expr( _expr ), aggregate( aggrp ), designator( des ), kids( 0 ), maybeConstructed( true ) {
[b87a5ed]26 if ( aggrp )
[7880579]27 kids = dynamic_cast< InitializerNode * >( get_next() );
[51b73452]28
[b87a5ed]29 if ( kids != 0 )
[1d4580a]30 set_last( 0 );
[51b73452]31}
32
33InitializerNode::InitializerNode( InitializerNode *init, bool aggrp, ExpressionNode *des )
[974906e2]34 : expr( 0 ), aggregate( aggrp ), designator( des ), kids( 0 ), maybeConstructed( true ) {
[b87a5ed]35 if ( init != 0 )
[1d4580a]36 set_last( init );
[51b73452]37
[b87a5ed]38 if ( aggrp )
[7880579]39 kids = dynamic_cast< InitializerNode * >( get_next() );
[51b73452]40
[b87a5ed]41 if ( kids != 0 )
42 set_next( 0 );
[51b73452]43}
44
45InitializerNode::~InitializerNode() {
[b87a5ed]46 delete expr;
[4f147cc]47 delete designator;
48 delete kids;
[51b73452]49}
50
51void InitializerNode::print( std::ostream &os, int indent ) const {
[59db689]52 os << std::string( indent, ' ' ) << "Initializer expression" << std::endl;
[51b73452]53}
54
55void InitializerNode::printOneLine( std::ostream &os ) const {
[b87a5ed]56 if ( ! aggregate ) {
57 if ( designator != 0 ) {
58 os << "designated by: (";
59 ExpressionNode *curdes = designator;
[a32b204]60 while ( curdes != 0) {
[b87a5ed]61 curdes->printOneLine(os);
[1d4580a]62 curdes = (ExpressionNode *)(curdes->get_next());
[b87a5ed]63 if ( curdes ) os << ", ";
64 } // while
65 os << ")";
66 } // if
67 if ( expr ) expr->printOneLine(os);
68 } else { // It's an aggregate
69 os << "[--";
70 if ( next_init() != 0 )
71 next_init()->printOneLine(os);
72 if (aggregate) os << "--]";
[17cd4eb]73 } // if
[b87a5ed]74
75 InitializerNode *moreInit;
[1d4580a]76 if ( get_next() != 0 && ((moreInit = dynamic_cast< InitializerNode * >( get_next() ) ) != 0) )
[b87a5ed]77 moreInit->printOneLine( os );
[51b73452]78}
79
80Initializer *InitializerNode::build() const {
[b87a5ed]81 // if ( get_expression() == 0 ) return 0; // XXX (?)
[51b73452]82
[b87a5ed]83 if ( aggregate ) {
[097e2b0]84 //assert( next_init() != 0 );
[51b73452]85
[7880579]86 std::list< Initializer * > initlist;
87 buildList< Initializer, InitializerNode >( next_init(), initlist );
[51b73452]88
[7880579]89 std::list< Expression * > designlist;
[d9a0e76]90
[b87a5ed]91 if ( designator != 0 ) {
[7880579]92 buildList< Expression, ExpressionNode >( designator, designlist );
[b87a5ed]93 } // if
[51b73452]94
[974906e2]95 return new ListInit( initlist, designlist, maybeConstructed );
[b87a5ed]96 } else {
[7880579]97 std::list< Expression * > designators;
[51b73452]98
[b87a5ed]99 if ( designator != 0 )
[7880579]100 buildList< Expression, ExpressionNode >( designator, designators );
[51b73452]101
[b87a5ed]102 if ( get_expression() != 0)
[7880579]103 return new SingleInit( maybeBuild< Expression >( get_expression() ), designators, maybeConstructed );
[b87a5ed]104 } // if
[51b73452]105
[b87a5ed]106 return 0;
[51b73452]107}
[b87a5ed]108
109// Local Variables: //
110// tab-width: 4 //
111// mode: c++ //
112// compile-command: "make install" //
113// End: //
Note: See TracBrowser for help on using the repository browser.