source: translator/SynTree/Initializer.cc@ 643a2e1

ADT aaron-thesis arm-eh ast-experimental cleanup-dtors ctor deferred_resn demangler enum forall-pointer-decay gc_noraii jacob/cs343-translation jenkins-sandbox memory new-ast new-ast-unique-expr new-env no_list persistent-indexer pthread-emulation qualifiedEnum resolv-new string with_gc
Last change on this file since 643a2e1 was d9a0e76, checked in by Peter A. Buhr <pabuhr@…>, 11 years ago

remove Parser.old, add -XCFA to driver, copy ptrdiff_t from stddef.h in preclude, remove casts from initialization constants, adjust formatting

  • Property mode set to 100644
File size: 2.3 KB
RevLine 
[51b73452]1#include "Initializer.h"
2#include "Expression.h"
3#include "utility.h"
4
5
[d9a0e76]6Initializer::Initializer() {}
[51b73452]7
[d9a0e76]8Initializer::~Initializer() {}
[51b73452]9
10std::string Initializer::designator_name( Expression *des ) {
[d9a0e76]11 if ( NameExpr *n = dynamic_cast<NameExpr *>(des) )
[51b73452]12 return n->get_name();
13 else
14 throw 0;
15}
16
[d9a0e76]17void Initializer::print( std::ostream &os, int indent ) {}
[51b73452]18
[d9a0e76]19SingleInit::SingleInit( Expression *v, std::list< Expression *> &_designators ) : value ( v ), designators( _designators ) {
[51b73452]20}
21
[d9a0e76]22SingleInit::SingleInit( const SingleInit &other ) : value ( other.value ) {
[51b73452]23 cloneAll(other.designators, designators );
24}
25
[d9a0e76]26SingleInit::~SingleInit() {}
[51b73452]27
28SingleInit *SingleInit::clone() const { return new SingleInit( *this); }
29
[d9a0e76]30void SingleInit::print( std::ostream &os, int indent ) {
[51b73452]31 os << std::endl << std::string(indent, ' ' ) << "Simple Initializer: ";
32 value->print( os, indent+2 );
33
[d9a0e76]34 if ( ! designators.empty() ) {
35 os << std::endl << std::string(indent + 2, ' ' ) << "designated by: " ;
36 for ( std::list < Expression * >::iterator i = designators.begin(); i != designators.end(); i++ )
37 ( *i )->print(os, indent + 4 );
38 }
[51b73452]39}
40
[d9a0e76]41MemberInit::MemberInit( Expression *_value, std::string _member ) : member ( _member ), value ( _value ) {}
[51b73452]42
[d9a0e76]43MemberInit::~MemberInit() {}
[51b73452]44
[d9a0e76]45MemberInit * MemberInit::clone() const {
[51b73452]46 return new MemberInit( *this );
47}
48
[d9a0e76]49void MemberInit::print( std::ostream &os, int indent ) {
[51b73452]50 os << "Member Initializer";
51 value->print( os, indent+2 );
52}
53
54ListInit::ListInit( std::list<Initializer*> &_initializers, std::list<Expression *> &_designators )
[d9a0e76]55 : initializers( _initializers ), designators( _designators ) {
[51b73452]56}
57
[d9a0e76]58ListInit::~ListInit() {}
[51b73452]59
[d9a0e76]60ListInit *ListInit::clone() const {
[51b73452]61 return new ListInit( *this );
62}
63
[d9a0e76]64void ListInit::print( std::ostream &os, int indent ) {
[51b73452]65 os << std::endl << std::string(indent, ' ') << "Compound initializer: ";
[d9a0e76]66 if ( ! designators.empty() ) {
[51b73452]67 os << std::string(indent + 2, ' ' ) << "designated by: [";
68 for ( std::list < Expression * >::iterator i = designators.begin();
69 i != designators.end(); i++ ) {
70 ( *i )->print(os, indent + 4 );
71 }
72
73 os << std::string(indent + 2, ' ' ) << "]";
74 }
75
76 for( std::list<Initializer *>::iterator i = initializers.begin(); i != initializers.end(); i++ )
77 (*i)->print( os, indent + 2 );
78}
Note: See TracBrowser for help on using the repository browser.