Changes in src/AST/Convert.cpp [e67991f:f6cc734e]
- File:
-
- 1 edited
-
src/AST/Convert.cpp (modified) (95 diffs)
Legend:
- Unmodified
- Added
- Removed
-
src/AST/Convert.cpp
re67991f rf6cc734e 518 518 } 519 519 520 const ast:: Decl* visit( const ast::WithStmt * node ) override final {520 const ast::Stmt * visit( const ast::WithStmt * node ) override final { 521 521 if ( inCache( node ) ) return nullptr; 522 522 auto stmt = new WithStmt( … … 524 524 get<Statement>().accept1( node->stmt ) 525 525 ); 526 declPostamble( stmt, node ); 527 return nullptr; 526 return stmtPostamble( stmt, node ); 528 527 } 529 528 … … 608 607 609 608 tgt->result = get<Type>().accept1(src->result); 609 // Unconditionally use a clone of the result type. 610 // We know this will leak some objects: much of the immediate conversion result. 611 // In some cases, using the conversion result directly gives unintended object sharing. 612 // A parameter (ObjectDecl, a child of a FunctionType) is shared by the weak-ref cache. 613 // But tgt->result must be fully owned privately by tgt. 614 // Applying these conservative copies here means 615 // - weak references point at the declaration's copy, not these expr.result copies (good) 616 // - we copy more objects than really needed (bad, tolerated) 617 if (tgt->result) { 618 tgt->result = tgt->result->clone(); 619 } 610 620 return visitBaseExpr_skipResultType(src, tgt); 611 621 } … … 1040 1050 get<Expression>().accept1(node->expr), 1041 1051 inCache(node->deleteStmt) ? 1042 strict_dynamic_cast<Declaration*>(this->node):1043 get< Declaration>().accept1(node->deleteStmt)1052 this->node : 1053 get<BaseSyntaxNode>().accept1(node->deleteStmt) 1044 1054 ) 1045 1055 ); … … 1356 1366 ast::Node * node = nullptr; 1357 1367 /// cache of nodes that might be referenced by readonly<> for de-duplication 1358 std::unordered_map< constBaseSyntaxNode *, ast::Node * > cache = {};1368 std::unordered_map< BaseSyntaxNode *, ast::Node * > cache = {}; 1359 1369 1360 1370 // Local Utilities: … … 1423 1433 to<std::vector>::from( make_labels( std::move( labels ) ) ) 1424 1434 1425 static ast::CV::Qualifiers cv( const Type * ty ) { return { ty->tq.val }; }1435 static ast::CV::Qualifiers cv( Type * ty ) { return { ty->get_qualifiers().val }; } 1426 1436 1427 1437 /// returns true and sets `node` if in cache 1428 bool inCache( constBaseSyntaxNode * old ) {1438 bool inCache( BaseSyntaxNode * old ) { 1429 1439 auto it = cache.find( old ); 1430 1440 if ( it == cache.end() ) return false; … … 1435 1445 // Now all the visit functions: 1436 1446 1437 virtual void visit( constObjectDecl * old ) override final {1447 virtual void visit( ObjectDecl * old ) override final { 1438 1448 auto&& type = GET_ACCEPT_1(type, Type); 1439 1449 auto&& init = GET_ACCEPT_1(init, Init); … … 1466 1476 } 1467 1477 1468 virtual void visit( constFunctionDecl * old ) override final {1478 virtual void visit( FunctionDecl * old ) override final { 1469 1479 if ( inCache( old ) ) return; 1470 1480 auto decl = new ast::FunctionDecl{ … … 1499 1509 } 1500 1510 1501 virtual void visit( constStructDecl * old ) override final {1511 virtual void visit( StructDecl * old ) override final { 1502 1512 if ( inCache( old ) ) return; 1503 1513 auto decl = new ast::StructDecl( … … 1524 1534 } 1525 1535 1526 virtual void visit( constUnionDecl * old ) override final {1536 virtual void visit( UnionDecl * old ) override final { 1527 1537 if ( inCache( old ) ) return; 1528 1538 auto decl = new ast::UnionDecl( … … 1544 1554 } 1545 1555 1546 virtual void visit( constEnumDecl * old ) override final {1556 virtual void visit( EnumDecl * old ) override final { 1547 1557 if ( inCache( old ) ) return; 1548 1558 auto decl = new ast::EnumDecl( … … 1564 1574 } 1565 1575 1566 virtual void visit( constTraitDecl * old ) override final {1576 virtual void visit( TraitDecl * old ) override final { 1567 1577 if ( inCache( old ) ) return; 1568 1578 auto decl = new ast::TraitDecl( … … 1584 1594 } 1585 1595 1586 virtual void visit( constTypeDecl * old ) override final {1596 virtual void visit( TypeDecl * old ) override final { 1587 1597 if ( inCache( old ) ) return; 1588 1598 auto decl = new ast::TypeDecl{ … … 1604 1614 } 1605 1615 1606 virtual void visit( constTypedefDecl * old ) override final {1616 virtual void visit( TypedefDecl * old ) override final { 1607 1617 auto decl = new ast::TypedefDecl( 1608 1618 old->location, … … 1621 1631 } 1622 1632 1623 virtual void visit( constAsmDecl * old ) override final {1633 virtual void visit( AsmDecl * old ) override final { 1624 1634 auto decl = new ast::AsmDecl{ 1625 1635 old->location, … … 1633 1643 } 1634 1644 1635 virtual void visit( constStaticAssertDecl * old ) override final {1645 virtual void visit( StaticAssertDecl * old ) override final { 1636 1646 auto decl = new ast::StaticAssertDecl{ 1637 1647 old->location, … … 1646 1656 } 1647 1657 1648 virtual void visit( constCompoundStmt * old ) override final {1658 virtual void visit( CompoundStmt * old ) override final { 1649 1659 if ( inCache( old ) ) return; 1650 1660 auto stmt = new ast::CompoundStmt( … … 1658 1668 } 1659 1669 1660 virtual void visit( constExprStmt * old ) override final {1670 virtual void visit( ExprStmt * old ) override final { 1661 1671 if ( inCache( old ) ) return; 1662 1672 this->node = new ast::ExprStmt( … … 1668 1678 } 1669 1679 1670 virtual void visit( constAsmStmt * old ) override final {1680 virtual void visit( AsmStmt * old ) override final { 1671 1681 if ( inCache( old ) ) return; 1672 1682 this->node = new ast::AsmStmt( … … 1683 1693 } 1684 1694 1685 virtual void visit( constDirectiveStmt * old ) override final {1695 virtual void visit( DirectiveStmt * old ) override final { 1686 1696 if ( inCache( old ) ) return; 1687 1697 this->node = new ast::DirectiveStmt( … … 1693 1703 } 1694 1704 1695 virtual void visit( constIfStmt * old ) override final {1705 virtual void visit( IfStmt * old ) override final { 1696 1706 if ( inCache( old ) ) return; 1697 1707 this->node = new ast::IfStmt( … … 1706 1716 } 1707 1717 1708 virtual void visit( constSwitchStmt * old ) override final {1718 virtual void visit( SwitchStmt * old ) override final { 1709 1719 if ( inCache( old ) ) return; 1710 1720 this->node = new ast::SwitchStmt( … … 1717 1727 } 1718 1728 1719 virtual void visit( constCaseStmt * old ) override final {1729 virtual void visit( CaseStmt * old ) override final { 1720 1730 if ( inCache( old ) ) return; 1721 1731 this->node = new ast::CaseStmt( … … 1728 1738 } 1729 1739 1730 virtual void visit( constWhileStmt * old ) override final {1740 virtual void visit( WhileStmt * old ) override final { 1731 1741 if ( inCache( old ) ) return; 1732 1742 this->node = new ast::WhileStmt( … … 1741 1751 } 1742 1752 1743 virtual void visit( constForStmt * old ) override final {1753 virtual void visit( ForStmt * old ) override final { 1744 1754 if ( inCache( old ) ) return; 1745 1755 this->node = new ast::ForStmt( … … 1754 1764 } 1755 1765 1756 virtual void visit( constBranchStmt * old ) override final {1766 virtual void visit( BranchStmt * old ) override final { 1757 1767 if ( inCache( old ) ) return; 1758 1768 if (old->computedTarget) { … … 1791 1801 } 1792 1802 1793 virtual void visit( constReturnStmt * old ) override final {1803 virtual void visit( ReturnStmt * old ) override final { 1794 1804 if ( inCache( old ) ) return; 1795 1805 this->node = new ast::ReturnStmt( … … 1801 1811 } 1802 1812 1803 virtual void visit( constThrowStmt * old ) override final {1813 virtual void visit( ThrowStmt * old ) override final { 1804 1814 if ( inCache( old ) ) return; 1805 1815 ast::ExceptionKind kind; … … 1825 1835 } 1826 1836 1827 virtual void visit( constTryStmt * old ) override final {1837 virtual void visit( TryStmt * old ) override final { 1828 1838 if ( inCache( old ) ) return; 1829 1839 this->node = new ast::TryStmt( … … 1837 1847 } 1838 1848 1839 virtual void visit( constCatchStmt * old ) override final {1849 virtual void visit( CatchStmt * old ) override final { 1840 1850 if ( inCache( old ) ) return; 1841 1851 ast::ExceptionKind kind; … … 1862 1872 } 1863 1873 1864 virtual void visit( constFinallyStmt * old ) override final {1874 virtual void visit( FinallyStmt * old ) override final { 1865 1875 if ( inCache( old ) ) return; 1866 1876 this->node = new ast::FinallyStmt( … … 1872 1882 } 1873 1883 1874 virtual void visit( constWaitForStmt * old ) override final {1884 virtual void visit( WaitForStmt * old ) override final { 1875 1885 if ( inCache( old ) ) return; 1876 1886 ast::WaitForStmt * stmt = new ast::WaitForStmt( … … 1904 1914 } 1905 1915 1906 virtual void visit( constWithStmt * old ) override final {1916 virtual void visit( WithStmt * old ) override final { 1907 1917 if ( inCache( old ) ) return; 1908 1918 this->node = new ast::WithStmt( 1909 1919 old->location, 1910 1920 GET_ACCEPT_V(exprs, Expr), 1911 GET_ACCEPT_1(stmt, Stmt) 1921 GET_ACCEPT_1(stmt, Stmt), 1922 GET_LABELS_V(old->labels) 1912 1923 ); 1913 1924 cache.emplace( old, this->node ); 1914 1925 } 1915 1926 1916 virtual void visit( constNullStmt * old ) override final {1927 virtual void visit( NullStmt * old ) override final { 1917 1928 if ( inCache( old ) ) return; 1918 1929 this->node = new ast::NullStmt( … … 1923 1934 } 1924 1935 1925 virtual void visit( constDeclStmt * old ) override final {1936 virtual void visit( DeclStmt * old ) override final { 1926 1937 if ( inCache( old ) ) return; 1927 1938 this->node = new ast::DeclStmt( … … 1933 1944 } 1934 1945 1935 virtual void visit( constImplicitCtorDtorStmt * old ) override final {1946 virtual void visit( ImplicitCtorDtorStmt * old ) override final { 1936 1947 if ( inCache( old ) ) return; 1937 1948 auto stmt = new ast::ImplicitCtorDtorStmt( … … 1990 2001 } 1991 2002 1992 ast::Expr * visitBaseExpr_SkipResultType( constExpression * old, ast::Expr * nw) {2003 ast::Expr * visitBaseExpr_SkipResultType(Expression * old, ast::Expr * nw) { 1993 2004 1994 2005 nw->env = convertTypeSubstitution(old->env); … … 2000 2011 } 2001 2012 2002 ast::Expr * visitBaseExpr( constExpression * old, ast::Expr * nw) {2013 ast::Expr * visitBaseExpr(Expression * old, ast::Expr * nw) { 2003 2014 2004 2015 nw->result = GET_ACCEPT_1(result, Type); … … 2006 2017 } 2007 2018 2008 virtual void visit( constApplicationExpr * old ) override final {2019 virtual void visit( ApplicationExpr * old ) override final { 2009 2020 this->node = visitBaseExpr( old, 2010 2021 new ast::ApplicationExpr( … … 2016 2027 } 2017 2028 2018 virtual void visit( constUntypedExpr * old ) override final {2029 virtual void visit( UntypedExpr * old ) override final { 2019 2030 this->node = visitBaseExpr( old, 2020 2031 new ast::UntypedExpr( … … 2026 2037 } 2027 2038 2028 virtual void visit( constNameExpr * old ) override final {2039 virtual void visit( NameExpr * old ) override final { 2029 2040 this->node = visitBaseExpr( old, 2030 2041 new ast::NameExpr( … … 2035 2046 } 2036 2047 2037 virtual void visit( constCastExpr * old ) override final {2048 virtual void visit( CastExpr * old ) override final { 2038 2049 this->node = visitBaseExpr( old, 2039 2050 new ast::CastExpr( … … 2045 2056 } 2046 2057 2047 virtual void visit( constKeywordCastExpr * old) override final {2058 virtual void visit( KeywordCastExpr * old) override final { 2048 2059 ast::KeywordCastExpr::Target castTarget = ast::KeywordCastExpr::NUMBER_OF_TARGETS; 2049 2060 switch (old->target) { … … 2070 2081 } 2071 2082 2072 virtual void visit( constVirtualCastExpr * old ) override final {2083 virtual void visit( VirtualCastExpr * old ) override final { 2073 2084 this->node = visitBaseExpr_SkipResultType( old, 2074 2085 new ast::VirtualCastExpr( … … 2080 2091 } 2081 2092 2082 virtual void visit( constAddressExpr * old ) override final {2093 virtual void visit( AddressExpr * old ) override final { 2083 2094 this->node = visitBaseExpr( old, 2084 2095 new ast::AddressExpr( … … 2089 2100 } 2090 2101 2091 virtual void visit( constLabelAddressExpr * old ) override final {2102 virtual void visit( LabelAddressExpr * old ) override final { 2092 2103 this->node = visitBaseExpr( old, 2093 2104 new ast::LabelAddressExpr( … … 2098 2109 } 2099 2110 2100 virtual void visit( constUntypedMemberExpr * old ) override final {2111 virtual void visit( UntypedMemberExpr * old ) override final { 2101 2112 this->node = visitBaseExpr( old, 2102 2113 new ast::UntypedMemberExpr( … … 2108 2119 } 2109 2120 2110 virtual void visit( constMemberExpr * old ) override final {2121 virtual void visit( MemberExpr * old ) override final { 2111 2122 this->node = visitBaseExpr( old, 2112 2123 new ast::MemberExpr( … … 2118 2129 } 2119 2130 2120 virtual void visit( constVariableExpr * old ) override final {2131 virtual void visit( VariableExpr * old ) override final { 2121 2132 auto expr = new ast::VariableExpr( 2122 2133 old->location … … 2129 2140 } 2130 2141 2131 virtual void visit( constConstantExpr * old ) override final {2142 virtual void visit( ConstantExpr * old ) override final { 2132 2143 ast::ConstantExpr *rslt = new ast::ConstantExpr( 2133 2144 old->location, 2134 2145 GET_ACCEPT_1(result, Type), 2135 old->constant. rep,2146 old->constant.get_value(), 2136 2147 old->constant.ival 2137 2148 ); 2138 rslt->underlyer = getAccept1< ast::Type, Type* >( old->constant. type);2149 rslt->underlyer = getAccept1< ast::Type, Type* >( old->constant.get_type() ); 2139 2150 this->node = visitBaseExpr( old, rslt ); 2140 2151 } 2141 2152 2142 virtual void visit( constSizeofExpr * old ) override final {2153 virtual void visit( SizeofExpr * old ) override final { 2143 2154 assert (old->expr || old->type); 2144 2155 assert (! (old->expr && old->type)); … … 2161 2172 } 2162 2173 2163 virtual void visit( constAlignofExpr * old ) override final {2174 virtual void visit( AlignofExpr * old ) override final { 2164 2175 assert (old->expr || old->type); 2165 2176 assert (! (old->expr && old->type)); … … 2182 2193 } 2183 2194 2184 virtual void visit( constUntypedOffsetofExpr * old ) override final {2195 virtual void visit( UntypedOffsetofExpr * old ) override final { 2185 2196 this->node = visitBaseExpr( old, 2186 2197 new ast::UntypedOffsetofExpr( … … 2192 2203 } 2193 2204 2194 virtual void visit( constOffsetofExpr * old ) override final {2205 virtual void visit( OffsetofExpr * old ) override final { 2195 2206 this->node = visitBaseExpr( old, 2196 2207 new ast::OffsetofExpr( … … 2202 2213 } 2203 2214 2204 virtual void visit( constOffsetPackExpr * old ) override final {2215 virtual void visit( OffsetPackExpr * old ) override final { 2205 2216 this->node = visitBaseExpr( old, 2206 2217 new ast::OffsetPackExpr( … … 2211 2222 } 2212 2223 2213 virtual void visit( constLogicalExpr * old ) override final {2224 virtual void visit( LogicalExpr * old ) override final { 2214 2225 this->node = visitBaseExpr( old, 2215 2226 new ast::LogicalExpr( … … 2224 2235 } 2225 2236 2226 virtual void visit( constConditionalExpr * old ) override final {2237 virtual void visit( ConditionalExpr * old ) override final { 2227 2238 this->node = visitBaseExpr( old, 2228 2239 new ast::ConditionalExpr( … … 2235 2246 } 2236 2247 2237 virtual void visit( constCommaExpr * old ) override final {2248 virtual void visit( CommaExpr * old ) override final { 2238 2249 this->node = visitBaseExpr( old, 2239 2250 new ast::CommaExpr( … … 2245 2256 } 2246 2257 2247 virtual void visit( constTypeExpr * old ) override final {2258 virtual void visit( TypeExpr * old ) override final { 2248 2259 this->node = visitBaseExpr( old, 2249 2260 new ast::TypeExpr( … … 2254 2265 } 2255 2266 2256 virtual void visit( constAsmExpr * old ) override final {2267 virtual void visit( AsmExpr * old ) override final { 2257 2268 this->node = visitBaseExpr( old, 2258 2269 new ast::AsmExpr( … … 2265 2276 } 2266 2277 2267 virtual void visit( constImplicitCopyCtorExpr * old ) override final {2278 virtual void visit( ImplicitCopyCtorExpr * old ) override final { 2268 2279 auto rslt = new ast::ImplicitCopyCtorExpr( 2269 2280 old->location, … … 2274 2285 } 2275 2286 2276 virtual void visit( constConstructorExpr * old ) override final {2287 virtual void visit( ConstructorExpr * old ) override final { 2277 2288 this->node = visitBaseExpr( old, 2278 2289 new ast::ConstructorExpr( … … 2283 2294 } 2284 2295 2285 virtual void visit( constCompoundLiteralExpr * old ) override final {2296 virtual void visit( CompoundLiteralExpr * old ) override final { 2286 2297 this->node = visitBaseExpr_SkipResultType( old, 2287 2298 new ast::CompoundLiteralExpr( … … 2293 2304 } 2294 2305 2295 virtual void visit( constRangeExpr * old ) override final {2306 virtual void visit( RangeExpr * old ) override final { 2296 2307 this->node = visitBaseExpr( old, 2297 2308 new ast::RangeExpr( … … 2303 2314 } 2304 2315 2305 virtual void visit( constUntypedTupleExpr * old ) override final {2316 virtual void visit( UntypedTupleExpr * old ) override final { 2306 2317 this->node = visitBaseExpr( old, 2307 2318 new ast::UntypedTupleExpr( … … 2312 2323 } 2313 2324 2314 virtual void visit( constTupleExpr * old ) override final {2325 virtual void visit( TupleExpr * old ) override final { 2315 2326 this->node = visitBaseExpr( old, 2316 2327 new ast::TupleExpr( … … 2321 2332 } 2322 2333 2323 virtual void visit( constTupleIndexExpr * old ) override final {2334 virtual void visit( TupleIndexExpr * old ) override final { 2324 2335 this->node = visitBaseExpr( old, 2325 2336 new ast::TupleIndexExpr( … … 2331 2342 } 2332 2343 2333 virtual void visit( constTupleAssignExpr * old ) override final {2344 virtual void visit( TupleAssignExpr * old ) override final { 2334 2345 this->node = visitBaseExpr_SkipResultType( old, 2335 2346 new ast::TupleAssignExpr( … … 2341 2352 } 2342 2353 2343 virtual void visit( constStmtExpr * old ) override final {2354 virtual void visit( StmtExpr * old ) override final { 2344 2355 auto rslt = new ast::StmtExpr( 2345 2356 old->location, … … 2352 2363 } 2353 2364 2354 virtual void visit( constUniqueExpr * old ) override final {2365 virtual void visit( UniqueExpr * old ) override final { 2355 2366 auto rslt = new ast::UniqueExpr( 2356 2367 old->location, … … 2364 2375 } 2365 2376 2366 virtual void visit( constUntypedInitExpr * old ) override final {2377 virtual void visit( UntypedInitExpr * old ) override final { 2367 2378 std::deque<ast::InitAlternative> initAlts; 2368 2379 for (auto ia : old->initAlts) { … … 2381 2392 } 2382 2393 2383 virtual void visit( constInitExpr * old ) override final {2394 virtual void visit( InitExpr * old ) override final { 2384 2395 this->node = visitBaseExpr( old, 2385 2396 new ast::InitExpr( … … 2391 2402 } 2392 2403 2393 virtual void visit( constDeletedExpr * old ) override final {2404 virtual void visit( DeletedExpr * old ) override final { 2394 2405 this->node = visitBaseExpr( old, 2395 2406 new ast::DeletedExpr( … … 2397 2408 GET_ACCEPT_1(expr, Expr), 2398 2409 inCache(old->deleteStmt) ? 2399 strict_dynamic_cast<ast::Decl*>(this->node):2400 GET_ACCEPT_1(deleteStmt, Decl)2401 ) 2402 ); 2403 } 2404 2405 virtual void visit( constDefaultArgExpr * old ) override final {2410 this->node : 2411 GET_ACCEPT_1(deleteStmt, Node) 2412 ) 2413 ); 2414 } 2415 2416 virtual void visit( DefaultArgExpr * old ) override final { 2406 2417 this->node = visitBaseExpr( old, 2407 2418 new ast::DefaultArgExpr( … … 2412 2423 } 2413 2424 2414 virtual void visit( constGenericExpr * old ) override final {2425 virtual void visit( GenericExpr * old ) override final { 2415 2426 std::vector<ast::GenericExpr::Association> associations; 2416 2427 for (auto association : old->associations) { … … 2429 2440 } 2430 2441 2431 void visitType( constType * old, ast::Type * type ) {2442 void visitType( Type * old, ast::Type * type ) { 2432 2443 // Some types do this in their constructor so add a check. 2433 2444 if ( !old->attributes.empty() && type->attributes.empty() ) { … … 2437 2448 } 2438 2449 2439 virtual void visit( constVoidType * old ) override final {2450 virtual void visit( VoidType * old ) override final { 2440 2451 visitType( old, new ast::VoidType{ cv( old ) } ); 2441 2452 } 2442 2453 2443 virtual void visit( constBasicType * old ) override final {2454 virtual void visit( BasicType * old ) override final { 2444 2455 auto type = new ast::BasicType{ (ast::BasicType::Kind)(unsigned)old->kind, cv( old ) }; 2445 2456 // I believe this should always be a BasicType. … … 2450 2461 } 2451 2462 2452 virtual void visit( constPointerType * old ) override final {2463 virtual void visit( PointerType * old ) override final { 2453 2464 visitType( old, new ast::PointerType{ 2454 2465 GET_ACCEPT_1( base, Type ), … … 2460 2471 } 2461 2472 2462 virtual void visit( constArrayType * old ) override final {2473 virtual void visit( ArrayType * old ) override final { 2463 2474 visitType( old, new ast::ArrayType{ 2464 2475 GET_ACCEPT_1( base, Type ), … … 2470 2481 } 2471 2482 2472 virtual void visit( constReferenceType * old ) override final {2483 virtual void visit( ReferenceType * old ) override final { 2473 2484 visitType( old, new ast::ReferenceType{ 2474 2485 GET_ACCEPT_1( base, Type ), … … 2477 2488 } 2478 2489 2479 virtual void visit( constQualifiedType * old ) override final {2490 virtual void visit( QualifiedType * old ) override final { 2480 2491 visitType( old, new ast::QualifiedType{ 2481 2492 GET_ACCEPT_1( parent, Type ), … … 2485 2496 } 2486 2497 2487 virtual void visit( constFunctionType * old ) override final {2498 virtual void visit( FunctionType * old ) override final { 2488 2499 auto ty = new ast::FunctionType { 2489 2500 (ast::ArgumentFlag)old->isVarArgs, … … 2496 2507 } 2497 2508 2498 void postvisit( constReferenceToType * old, ast::ReferenceToType * ty ) {2509 void postvisit( ReferenceToType * old, ast::ReferenceToType * ty ) { 2499 2510 ty->forall = GET_ACCEPT_V( forall, TypeDecl ); 2500 2511 ty->params = GET_ACCEPT_V( parameters, Expr ); … … 2503 2514 } 2504 2515 2505 virtual void visit( constStructInstType * old ) override final {2516 virtual void visit( StructInstType * old ) override final { 2506 2517 ast::StructInstType * ty; 2507 2518 if ( old->baseStruct ) { … … 2521 2532 } 2522 2533 2523 virtual void visit( constUnionInstType * old ) override final {2534 virtual void visit( UnionInstType * old ) override final { 2524 2535 ast::UnionInstType * ty; 2525 2536 if ( old->baseUnion ) { … … 2539 2550 } 2540 2551 2541 virtual void visit( constEnumInstType * old ) override final {2552 virtual void visit( EnumInstType * old ) override final { 2542 2553 ast::EnumInstType * ty; 2543 2554 if ( old->baseEnum ) { … … 2557 2568 } 2558 2569 2559 virtual void visit( constTraitInstType * old ) override final {2570 virtual void visit( TraitInstType * old ) override final { 2560 2571 ast::TraitInstType * ty; 2561 2572 if ( old->baseTrait ) { … … 2575 2586 } 2576 2587 2577 virtual void visit( constTypeInstType * old ) override final {2588 virtual void visit( TypeInstType * old ) override final { 2578 2589 ast::TypeInstType * ty; 2579 2590 if ( old->baseType ) { … … 2595 2606 } 2596 2607 2597 virtual void visit( constTupleType * old ) override final {2608 virtual void visit( TupleType * old ) override final { 2598 2609 visitType( old, new ast::TupleType{ 2599 2610 GET_ACCEPT_V( types, Type ), … … 2603 2614 } 2604 2615 2605 virtual void visit( constTypeofType * old ) override final {2616 virtual void visit( TypeofType * old ) override final { 2606 2617 visitType( old, new ast::TypeofType{ 2607 2618 GET_ACCEPT_1( expr, Expr ), … … 2611 2622 } 2612 2623 2613 virtual void visit( constAttrType * ) override final {2624 virtual void visit( AttrType * ) override final { 2614 2625 assertf( false, "AttrType deprecated in new AST." ); 2615 2626 } 2616 2627 2617 virtual void visit( constVarArgsType * old ) override final {2628 virtual void visit( VarArgsType * old ) override final { 2618 2629 visitType( old, new ast::VarArgsType{ cv( old ) } ); 2619 2630 } 2620 2631 2621 virtual void visit( constZeroType * old ) override final {2632 virtual void visit( ZeroType * old ) override final { 2622 2633 visitType( old, new ast::ZeroType{ cv( old ) } ); 2623 2634 } 2624 2635 2625 virtual void visit( constOneType * old ) override final {2636 virtual void visit( OneType * old ) override final { 2626 2637 visitType( old, new ast::OneType{ cv( old ) } ); 2627 2638 } 2628 2639 2629 virtual void visit( constGlobalScopeType * old ) override final {2640 virtual void visit( GlobalScopeType * old ) override final { 2630 2641 visitType( old, new ast::GlobalScopeType{} ); 2631 2642 } 2632 2643 2633 virtual void visit( constDesignation * old ) override final {2644 virtual void visit( Designation * old ) override final { 2634 2645 this->node = new ast::Designation( 2635 2646 old->location, … … 2638 2649 } 2639 2650 2640 virtual void visit( constSingleInit * old ) override final {2651 virtual void visit( SingleInit * old ) override final { 2641 2652 this->node = new ast::SingleInit( 2642 2653 old->location, … … 2646 2657 } 2647 2658 2648 virtual void visit( constListInit * old ) override final {2659 virtual void visit( ListInit * old ) override final { 2649 2660 this->node = new ast::ListInit( 2650 2661 old->location, … … 2655 2666 } 2656 2667 2657 virtual void visit( constConstructorInit * old ) override final {2668 virtual void visit( ConstructorInit * old ) override final { 2658 2669 this->node = new ast::ConstructorInit( 2659 2670 old->location, … … 2664 2675 } 2665 2676 2666 virtual void visit( constConstant * ) override final {2677 virtual void visit( Constant * ) override final { 2667 2678 // Handled in visit( ConstantEpxr * ). 2668 2679 // In the new tree, Constant fields are inlined into containing ConstantExpression. … … 2670 2681 } 2671 2682 2672 virtual void visit( constAttribute * old ) override final {2683 virtual void visit( Attribute * old ) override final { 2673 2684 this->node = new ast::Attribute( 2674 2685 old->name, … … 2677 2688 } 2678 2689 2679 virtual void visit( constAttrExpr * ) override final {2690 virtual void visit( AttrExpr * ) override final { 2680 2691 assertf( false, "AttrExpr deprecated in new AST." ); 2681 2692 }
Note:
See TracChangeset
for help on using the changeset viewer.