Changes in / [50eac1b:9909842]
- Location:
- src
- Files:
-
- 5 edited
-
Parser/LinkageSpec.cc (modified) (2 diffs)
-
Parser/LinkageSpec.h (modified) (2 diffs)
-
SymTab/IdTable.cc (modified) (5 diffs)
-
SymTab/Mangler.cc (modified) (5 diffs)
-
SymTab/Mangler.h (modified) (4 diffs)
Legend:
- Unmodified
- Added
- Removed
-
src/Parser/LinkageSpec.cc
r50eac1b r9909842 9 9 // Author : Rodolfo G. Esteves 10 10 // Created On : Sat May 16 13:22:09 2015 11 // Last Modified By : Rob Schluntz12 // Last Modified On : Wed Aug 19 15:53:05201513 // Update Count : 511 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Sat May 16 13:23:21 2015 13 // Update Count : 2 14 14 // 15 15 … … 79 79 } 80 80 81 82 bool LinkageSpec::isOverridable( Type t ) {83 switch ( t ) {84 case Intrinsic:85 case AutoGen:86 return true;87 case Cforall:88 case C:89 case Compiler:90 return false;91 }92 assert( false );93 return false;94 }95 96 81 bool LinkageSpec::isBuiltin( Type t ) { 97 82 switch ( t ) { -
src/Parser/LinkageSpec.h
r50eac1b r9909842 9 9 // Author : Rodolfo G. Esteves 10 10 // Created On : Sat May 16 13:24:28 2015 11 // Last Modified By : Rob Schluntz12 // Last Modified On : Tue Aug 18 14:11:55201513 // Update Count : 511 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Sat May 16 13:26:14 2015 13 // Update Count : 3 14 14 // 15 15 … … 34 34 static bool isGeneratable( Type ); 35 35 static bool isOverloadable( Type ); 36 static bool isOverridable( Type );37 36 static bool isBuiltin( Type ); 38 37 }; -
src/SymTab/IdTable.cc
r50eac1b r9909842 9 9 // Author : Richard C. Bilson 10 10 // Created On : Sun May 17 17:04:02 2015 11 // Last Modified By : Rob Schluntz12 // Last Modified On : Wed Oct 07 12:21:13 201513 // Update Count : 7311 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Sun May 17 17:07:43 2015 13 // Update Count : 3 14 14 // 15 15 … … 37 37 for ( InnerTableType::iterator inner = outer->second.begin(); inner != outer->second.end(); ++inner ) { 38 38 std::stack< DeclEntry >& entry = inner->second; 39 // xxx - should be while?40 39 if ( ! entry.empty() && entry.top().second == scopeLevel ) { 41 40 entry.pop(); … … 53 52 if ( decl->get_linkage() == LinkageSpec::C ) { 54 53 manglename = name; 55 } else if ( LinkageSpec::isOverridable( decl->get_linkage() ) ) {56 // mangle the name without including the appropriate suffix57 // this will make it so that overridable routines are placed58 // into the same "bucket" as their user defined versions.59 manglename = Mangler::mangle( decl, false );60 54 } else { 61 55 manglename = Mangler::mangle( decl ); … … 66 60 67 61 if ( it == declTable.end() ) { 68 // first time this name mangling has been defined69 62 declTable[ manglename ].push( DeclEntry( decl, scopeLevel ) ); 70 63 } else { 71 64 std::stack< DeclEntry >& entry = it->second; 72 65 if ( ! entry.empty() && entry.top().second == scopeLevel ) { 73 // if we're giving the same name mangling to things of 74 // different types then there is something wrong 75 Declaration *old = entry.top().first; 76 assert( (dynamic_cast<ObjectDecl*>( decl ) && dynamic_cast<ObjectDecl*>( old ) ) 77 || (dynamic_cast<FunctionDecl*>( decl ) && dynamic_cast<FunctionDecl*>( old ) ) ); 78 79 if ( LinkageSpec::isOverridable( old->get_linkage() ) ) { 80 // new definition shadows the autogenerated one, even at the same scope 81 declTable[ manglename ].push( DeclEntry( decl, scopeLevel ) ); 82 } else if ( decl->get_linkage() != LinkageSpec::C || ResolvExpr::typesCompatible( decl->get_type(), entry.top().first->get_type(), Indexer() ) ) { 83 // typesCompatible doesn't really do the right thing here. When checking compatibility of function types, 84 // we should ignore outermost pointer qualifiers, except _Atomic? 66 if ( decl->get_linkage() != LinkageSpec::C || ResolvExpr::typesCompatible( decl->get_type(), entry.top().first->get_type(), Indexer() ) ) { 85 67 FunctionDecl *newentry = dynamic_cast< FunctionDecl* >( decl ); 86 FunctionDecl *oldentry = dynamic_cast< FunctionDecl* >( old ); 87 if ( newentry && oldentry ) { 88 if ( newentry->get_statements() && oldentry->get_statements() ) { 89 throw SemanticError( "duplicate function definition for 1 ", decl ); 90 } // if 68 FunctionDecl *old = dynamic_cast< FunctionDecl* >( entry.top().first ); 69 if ( newentry && old && newentry->get_statements() && old->get_statements() ) { 70 throw SemanticError( "duplicate function definition for ", decl ); 91 71 } else { 92 // two objects with the same mangled name defined in the same scope.93 // both objects must be marked extern or both must be intrinsic for this to be okay94 // xxx - perhaps it's actually if either is intrinsic then this is okay?95 // might also need to be same storage class?96 72 ObjectDecl *newobj = dynamic_cast< ObjectDecl* >( decl ); 97 ObjectDecl *oldobj = dynamic_cast< ObjectDecl* >( old);98 if ( newobj->get_storageClass() != DeclarationNode::Extern && oldobj->get_storageClass() != DeclarationNode::Extern) {99 throw SemanticError( "duplicate definition for 3", decl );73 ObjectDecl *oldobj = dynamic_cast< ObjectDecl* >( entry.top().first ); 74 if ( newobj && oldobj && newobj->get_init() && oldobj->get_init() ) { 75 throw SemanticError( "duplicate definition for ", decl ); 100 76 } // if 101 77 } // if … … 104 80 } // if 105 81 } else { 106 // new scope level - shadow existing definition107 82 declTable[ manglename ].push( DeclEntry( decl, scopeLevel ) ); 108 83 } // if 109 84 } // if 110 // this ensures that no two declarations with the same unmangled name both have C linkage85 // ensure the set of routines with C linkage cannot be overloaded 111 86 for ( InnerTableType::iterator i = declTable.begin(); i != declTable.end(); ++i ) { 112 87 if ( ! i->second.empty() && i->second.top().first->get_linkage() == LinkageSpec::C && declTable.size() > 1 ) { -
src/SymTab/Mangler.cc
r50eac1b r9909842 9 9 // Author : Richard C. Bilson 10 10 // Created On : Sun May 17 21:40:29 2015 11 // Last Modified By : Rob Schluntz12 // Last Modified On : Wed Aug 19 15:52:24201513 // Update Count : 1911 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Mon Jun 8 15:12:12 2015 13 // Update Count : 8 14 14 // 15 15 … … 30 30 31 31 namespace SymTab { 32 Mangler::Mangler( bool mangleOverridable ) : nextVarNum( 0 ), isTopLevel( true ), mangleOverridable( mangleOverridable ) {32 Mangler::Mangler() : nextVarNum( 0 ), isTopLevel( true ) { 33 33 } 34 34 … … 41 41 nextVarNum = rhs.nextVarNum; 42 42 isTopLevel = rhs.isTopLevel; 43 mangleOverridable = rhs.mangleOverridable;44 43 } 45 44 … … 60 59 mangleName << "__"; 61 60 maybeAccept( declaration->get_type(), *this ); 62 if ( mangleOverridable && LinkageSpec::isOverridable( declaration->get_linkage() ) ) {63 // want to be able to override autogenerated and intrinsic routines,64 // so they need a different name mangling65 if ( declaration->get_linkage() == LinkageSpec::AutoGen ) {66 mangleName << "autogen__";67 } else if ( declaration->get_linkage() == LinkageSpec::Intrinsic ) {68 mangleName << "intrinsic__";69 } else {70 // if we add another kind of overridable function, this has to change71 assert( false );72 } // if73 }74 61 isTopLevel = wasTopLevel; 75 62 } … … 227 214 varNums[ (*i )->get_name() ] = std::pair< int, int >( nextVarNum++, (int )(*i )->get_kind() ); 228 215 for ( std::list< DeclarationWithType* >::iterator assert = (*i )->get_assertions().begin(); assert != (*i )->get_assertions().end(); ++assert ) { 229 Mangler sub_mangler ( mangleOverridable );216 Mangler sub_mangler; 230 217 sub_mangler.nextVarNum = nextVarNum; 231 218 sub_mangler.isTopLevel = false; -
src/SymTab/Mangler.h
r50eac1b r9909842 9 9 // Author : Richard C. Bilson 10 10 // Created On : Sun May 17 21:44:03 2015 11 // Last Modified By : Rob Schluntz12 // Last Modified On : Wed Aug 19 15:48:46201513 // Update Count : 1411 // Last Modified By : Peter A. Buhr 12 // Last Modified On : Mon Jun 8 14:47:14 2015 13 // Update Count : 5 14 14 // 15 15 … … 25 25 public: 26 26 template< typename SynTreeClass > 27 static std::string mangle( SynTreeClass *decl , bool mangleOverridable = true); // interface to clients27 static std::string mangle( SynTreeClass *decl ); // interface to clients 28 28 29 29 /// using Visitor::visit; … … 50 50 int nextVarNum; 51 51 bool isTopLevel; 52 bool mangleOverridable;53 52 54 Mangler( bool mangleOverridable);53 Mangler(); 55 54 Mangler( const Mangler & ); 56 55 … … 62 61 63 62 template< typename SynTreeClass > 64 std::string Mangler::mangle( SynTreeClass *decl , bool mangleOverridable) {65 Mangler mangler ( mangleOverridable );63 std::string Mangler::mangle( SynTreeClass *decl ) { 64 Mangler mangler; 66 65 maybeAccept( decl, mangler ); 67 66 return mangler.get_mangleName();
Note:
See TracChangeset
for help on using the changeset viewer.