// // Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo // // The contents of this file are covered under the licence agreement in the // file "LICENCE" distributed with Cforall. // // Initializer.cc -- // // Author : Richard C. Bilson // Created On : Mon May 18 07:44:20 2015 // Last Modified By : Rob Schluntz // Last Modified On : Wed Apr 06 16:15:32 2016 // Update Count : 28 // #include "Initializer.h" #include "Expression.h" #include "Statement.h" #include "Common/utility.h" Initializer::Initializer( bool maybeConstructed ) : maybeConstructed( maybeConstructed ) {} Initializer::~Initializer() {} std::string Initializer::designator_name( Expression *des ) { if ( NameExpr *n = dynamic_cast(des) ) return n->get_name(); else throw 0; } void Initializer::print( std::ostream &os, int indent ) {} SingleInit::SingleInit( Expression *v, const std::list< Expression *> &_designators, bool maybeConstructed ) : Initializer( maybeConstructed ), value ( v ), designators( _designators ) { } SingleInit::SingleInit( const SingleInit &other ) : Initializer(other), value ( maybeClone( other.value ) ) { cloneAll(other.designators, designators ); } SingleInit::~SingleInit() {} SingleInit *SingleInit::clone() const { return new SingleInit( *this); } void SingleInit::print( std::ostream &os, int indent ) { os << std::endl << std::string(indent, ' ' ) << "Simple Initializer: " << std::endl; value->print( os, indent+4 ); if ( ! designators.empty() ) { os << std::endl << std::string(indent + 2, ' ' ) << "designated by: " << std::endl; for ( std::list < Expression * >::iterator i = designators.begin(); i != designators.end(); i++ ) { ( *i )->print(os, indent + 4 ); } } // if } ListInit::ListInit( const std::list &_initializers, const std::list &_designators, bool maybeConstructed ) : Initializer( maybeConstructed), initializers( _initializers ), designators( _designators ) { } ListInit::~ListInit() {} ListInit *ListInit::clone() const { return new ListInit( *this ); } void ListInit::print( std::ostream &os, int indent ) { os << std::endl << std::string(indent, ' ') << "Compound initializer: "; if ( ! designators.empty() ) { os << std::string(indent + 2, ' ' ) << "designated by: ["; for ( std::list < Expression * >::iterator i = designators.begin(); i != designators.end(); i++ ) { ( *i )->print(os, indent + 4 ); } // for os << std::string(indent + 2, ' ' ) << "]"; } // if for ( std::list::iterator i = initializers.begin(); i != initializers.end(); i++ ) (*i)->print( os, indent + 2 ); } ConstructorInit::ConstructorInit( Statement * ctor, Statement * dtor, Initializer * init ) : Initializer( true ), ctor( ctor ), dtor( dtor ), init( init ) {} ConstructorInit::~ConstructorInit() { delete ctor; delete init; } ConstructorInit *ConstructorInit::clone() const { return new ConstructorInit( *this ); } void ConstructorInit::print( std::ostream &os, int indent ) { os << std::endl << std::string(indent, ' ') << "Constructor initializer: "; if ( ctor ) { os << " initially constructed with "; ctor->print( os, indent+2 ); } // if if ( dtor ) { os << " destructed with "; dtor->print( os, indent+2 ); } if ( init ) { os << " with fallback C-style initializer: "; init->print( os, indent+2 ); } } // Local Variables: // // tab-width: 4 // // mode: c++ // // compile-command: "make install" // // End: //