Changeset 3e91c6f9 for src/GenPoly/InstantiateGeneric.cpp
- Timestamp:
- Mar 13, 2025, 9:26:17 AM (4 weeks ago)
- Branches:
- master
- Children:
- 8b639f9
- Parents:
- 3bd9508 (diff), 594671a (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. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
TabularUnified src/GenPoly/InstantiateGeneric.cpp ¶
r3bd9508 r3e91c6f9 10 10 // Created On : Tue Aug 16 10:51:00 2022 11 11 // Last Modified By : Andrew Beach 12 // Last Modified On : Mon Oct 31 16:48:00 202213 // Update Count : 112 // Last Modified On : Wed Mar 12 15:18:00 2025 13 // Update Count : 2 14 14 // 15 15 … … 159 159 } 160 160 161 /// Get the scrubbed type of a declaration (see scrubTypeVars functions). 162 ast::TypeExpr const * scrubTypeDecl( 163 CodeLocation const & location, ast::TypeDecl const * typeDecl ) { 164 switch ( typeDecl->kind ) { 165 // Erase any incomplete dtype to `void` (`T *` -> `void *`). 166 case ast::TypeDecl::Dtype: 167 return new ast::TypeExpr( location, new ast::VoidType() ); 168 // Erase any ftype to `void (*)(void)`. 169 case ast::TypeDecl::Ftype: 170 return new ast::TypeExpr( location, new ast::FunctionType() ); 171 // Remaining cases are not supported. 172 case ast::TypeDecl::Ttype: 173 assertf( false, "Ttype parameters are not currently allowed as parameters to generic types." ); 174 break; 175 default: 176 assertf( false, "Unhandled type parameter kind" ); 177 break; 178 } 179 } 180 161 181 /// Makes substitutions of params into baseParams; returns dtypeStatic if 162 182 /// there is a concrete instantiation based only on {d,f}type-to-void … … 190 210 gt |= GenericType::concrete; 191 211 } 192 } else switch ( (*baseParam)->kind ) { 193 case ast::TypeDecl::Dtype: 194 // Here, pretend that any incomplete dtype is `void`. 195 out.emplace_back( new ast::TypeExpr( paramExpr->location, 196 new ast::VoidType() ) ); 197 break; 198 case ast::TypeDecl::Ftype: 199 // Here, pretend that any ftype is `void (*)(void)`. 200 out.emplace_back( new ast::TypeExpr( paramExpr->location, 201 new ast::FunctionType() ) ); 202 break; 203 case ast::TypeDecl::Ttype: 204 assertf( false, "Ttype parameters are not currently allowed as parameters to generic types." ); 205 break; 206 default: 207 assertf( false, "Unhandled type parameter kind" ); 208 break; 212 } else { 213 out.emplace_back( scrubTypeDecl( paramExpr->location, *baseParam ) ); 209 214 } 210 215 } … … 443 448 instantiations(), dtypeStatics(), typeNamer("_conc_") {} 444 449 450 ast::StructDecl const * previsit( ast::StructDecl const * ); 451 ast::UnionDecl const * previsit( ast::UnionDecl const * ); 452 445 453 ast::Type const * postvisit( ast::StructInstType const * inst ); 446 454 ast::Type const * postvisit( ast::UnionInstType const * inst ); … … 481 489 482 490 template<typename AggrDecl> 491 AggrDecl const * fixAggrDecl( AggrDecl const * decl ); 492 493 template<typename AggrDecl> 483 494 ast::Type const * fixInstType( ast::SueInstType<AggrDecl> const * inst ); 484 495 … … 489 500 ast::vector<ast::TypeExpr> const & typeSubs ); 490 501 }; 502 503 ast::StructDecl const * GenericInstantiator::previsit( ast::StructDecl const * decl ) { 504 return fixAggrDecl( decl ); 505 } 506 507 ast::UnionDecl const * GenericInstantiator::previsit( ast::UnionDecl const * decl ) { 508 return fixAggrDecl( decl ); 509 } 510 511 template<typename AggrDecl> 512 AggrDecl const * GenericInstantiator::fixAggrDecl( AggrDecl const * decl ) { 513 // This function and stripDtypeParams handle declarations before their 514 // first use (required to be in the previsit for types with a self use). 515 if ( decl->params.empty() || !isDtypeStatic( decl->params ) ) { 516 return decl; 517 } 518 519 ast::vector<ast::TypeExpr> typeSubs; 520 for ( auto const & param : decl->params ) { 521 assert( !param->isComplete() ); 522 typeSubs.emplace_back( scrubTypeDecl( param->location, param ) ); 523 } 524 525 assert( decl->unique() ); 526 auto mutDecl = ast::mutate( decl ); 527 stripDtypeParams( mutDecl, mutDecl->params, typeSubs ); 528 529 return mutDecl; 530 } 491 531 492 532 ast::Type const * GenericInstantiator::postvisit( … … 531 571 case GenericType::dtypeStatic: 532 572 { 573 // This call to stripDtypeParams is used when a forward declaration 574 // has allowed an instance to appear before the full declaration. 533 575 auto mutInst = ast::mutate( inst ); 534 576 assert( mutInst->base->unique() );
Note: See TracChangeset
for help on using the changeset viewer.