- Timestamp:
- Aug 11, 2017, 2:38:10 PM (7 years ago)
- 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:
- c3acf0aa
- Parents:
- c65a80b (diff), 2006db0 (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. - Location:
- src
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Common/Indenter.h
rc65a80b r06cafa4 5 5 // file "LICENCE" distributed with Cforall. 6 6 // 7 // utility.h --7 // Indenter.h -- 8 8 // 9 // Author : R ichard C. Bilson10 // Created On : Mon May 18 07:44:20 20159 // Author : Rob Schluntz 10 // Created On : Fri Jun 30 16:55:23 2017 11 11 // Last Modified By : Andrew Beach 12 // Last Modified On : Fri May 5 11:03:00 201713 // Update Count : 3212 // Last Modified On : Fri Aug 11 11:15:00 2017 13 // Update Count : 1 14 14 // 15 15 -
src/Parser/DeclarationNode.cc
rc65a80b r06cafa4 10 10 // Created On : Sat May 16 12:34:05 2015 11 11 // Last Modified By : Andrew Beach 12 // Last Modified On : Fri Jul 14 16:55:00 201713 // Update Count : 102 012 // Last Modified On : Thr Aug 10 17:02:00 2017 13 // Update Count : 1021 14 14 // 15 15 … … 275 275 return newnode; 276 276 } // DeclarationNode::newEnumConstant 277 278 DeclarationNode * DeclarationNode::newTreeStruct( Aggregate kind, const string * name, const string * parent, ExpressionNode * actuals, DeclarationNode * fields, bool body ) {279 assert( name );280 DeclarationNode * newnode = new DeclarationNode;281 newnode->type = new TypeData( TypeData::Aggregate );282 newnode->type->aggregate.kind = kind;283 newnode->type->aggregate.name = name;284 newnode->type->aggregate.actuals = actuals;285 newnode->type->aggregate.fields = fields;286 newnode->type->aggregate.body = body;287 newnode->type->aggregate.tagged = true;288 newnode->type->aggregate.parent = parent;289 return newnode;290 } // DeclarationNode::newTreeStruct291 277 292 278 DeclarationNode * DeclarationNode::newName( string * name ) { -
src/Parser/ParseNode.h
rc65a80b r06cafa4 9 9 // Author : Rodolfo G. Esteves 10 10 // Created On : Sat May 16 13:28:16 2015 11 // Last Modified By : Peter A. Buhr12 // Last Modified On : Thu Jul 27 12:08:08201713 // Update Count : 78 811 // Last Modified By : Andrew Beach 12 // Last Modified On : Thu Aug 10 16:54:00 2017 13 // Update Count : 789 14 14 // 15 15 … … 248 248 static DeclarationNode * newAsmStmt( StatementNode * stmt ); // gcc external asm statement 249 249 250 // Perhaps this would best fold into newAggragate.251 static DeclarationNode * newTreeStruct( Aggregate kind, const std::string * name, const std::string * parent, ExpressionNode * actuals, DeclarationNode * fields, bool body );252 253 250 DeclarationNode(); 254 251 ~DeclarationNode(); … … 335 332 336 333 static UniqueName anonymous; 337 338 // Temp to test TreeStruct339 const std::string * parent_name;340 334 }; // DeclarationNode 341 335 -
src/Parser/TypeData.cc
rc65a80b r06cafa4 10 10 // Created On : Sat May 16 15:12:51 2015 11 11 // Last Modified By : Andrew Beach 12 // Last Modified On : Wed Aug 9 13:50:00 201712 // Last Modified On : Fri Aug 11 10:50:00 2017 13 13 // Update Count : 567 14 14 // … … 63 63 aggregate.fields = nullptr; 64 64 aggregate.body = false; 65 aggregate.tagged = false;66 aggregate.parent = nullptr;67 65 break; 68 66 case AggregateInst: … … 123 121 delete aggregate.actuals; 124 122 delete aggregate.fields; 125 delete aggregate.parent;126 123 // delete aggregate; 127 124 break; … … 624 621 switch ( td->aggregate.kind ) { 625 622 case DeclarationNode::Struct: 626 if ( td->aggregate.tagged ) {627 at = new StructDecl( *td->aggregate.name, td->aggregate.parent, attributes, linkage );628 buildForall( td->aggregate.params, at->get_parameters() );629 break;630 }631 623 case DeclarationNode::Coroutine: 632 624 case DeclarationNode::Monitor: -
src/SynTree/Declaration.h
rc65a80b r06cafa4 10 10 // Created On : Mon May 18 07:44:20 2015 11 11 // Last Modified By : Andrew Beach 12 // Last Modified On : Wed Aug 9 14:45:00 201713 // Update Count : 12 612 // Last Modified On : Fri Aug 11 10:20:00 2017 13 // Update Count : 127 14 14 // 15 15 … … 269 269 typedef AggregateDecl Parent; 270 270 public: 271 StructDecl( const std::string &name, DeclarationNode::Aggregate kind = DeclarationNode::Struct, const std::list< Attribute * > & attributes = std::list< class Attribute * >(), LinkageSpec::Spec linkage = LinkageSpec::Cforall ) : Parent( name, attributes, linkage ), kind( kind ), tagged( false ), parent_name( "" ) {} 272 StructDecl( const std::string &name, const std::string *parent, const std::list< Attribute * > & attributes = std::list< class Attribute * >(), LinkageSpec::Spec linkage = LinkageSpec::Cforall ) : Parent( name, attributes, linkage ), kind( DeclarationNode::Struct ), tagged( true ), parent_name( parent ? *parent : "" ) {} 273 StructDecl( const StructDecl &other ) : Parent( other ) {} 271 StructDecl( const std::string &name, DeclarationNode::Aggregate kind = DeclarationNode::Struct, const std::list< Attribute * > & attributes = std::list< class Attribute * >(), LinkageSpec::Spec linkage = LinkageSpec::Cforall ) : Parent( name, attributes, linkage ), kind( kind ) {} 272 StructDecl( const StructDecl &other ) : Parent( other ), kind( other.kind ) {} 274 273 275 274 bool is_coroutine() { return kind == DeclarationNode::Coroutine; } … … 277 276 bool is_thread() { return kind == DeclarationNode::Thread; } 278 277 279 // Tagged/Tree Structure Excetion280 bool get_tagged() { return tagged; }281 void set_tagged( bool newValue ) { tagged = newValue; }282 bool has_parent() { return parent_name != ""; }283 std::string get_parentName() { return parent_name; }284 285 278 virtual StructDecl *clone() const { return new StructDecl( *this ); } 286 279 virtual void accept( Visitor &v ) { v.visit( this ); } … … 289 282 DeclarationNode::Aggregate kind; 290 283 virtual std::string typeString() const; 291 292 bool tagged;293 std::string parent_name;294 284 }; 295 285
Note: See TracChangeset
for help on using the changeset viewer.