Changes in src/AST/Convert.cpp [f6cc734e:ae265b55]
- File:
-
- 1 edited
-
src/AST/Convert.cpp (modified) (93 diffs)
Legend:
- Unmodified
- Added
- Removed
-
src/AST/Convert.cpp
rf6cc734e rae265b55 518 518 } 519 519 520 const ast:: Stmt* visit( const ast::WithStmt * node ) override final {520 const ast::Decl * 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 return stmtPostamble( stmt, node ); 526 declPostamble( stmt, node ); 527 return nullptr; 527 528 } 528 529 … … 1050 1051 get<Expression>().accept1(node->expr), 1051 1052 inCache(node->deleteStmt) ? 1052 this->node:1053 get< BaseSyntaxNode>().accept1(node->deleteStmt)1053 strict_dynamic_cast<Declaration*>(this->node) : 1054 get<Declaration>().accept1(node->deleteStmt) 1054 1055 ) 1055 1056 ); … … 1366 1367 ast::Node * node = nullptr; 1367 1368 /// cache of nodes that might be referenced by readonly<> for de-duplication 1368 std::unordered_map< BaseSyntaxNode *, ast::Node * > cache = {};1369 std::unordered_map< const BaseSyntaxNode *, ast::Node * > cache = {}; 1369 1370 1370 1371 // Local Utilities: … … 1433 1434 to<std::vector>::from( make_labels( std::move( labels ) ) ) 1434 1435 1435 static ast::CV::Qualifiers cv( Type * ty ) { return { ty->get_qualifiers().val }; }1436 static ast::CV::Qualifiers cv( const Type * ty ) { return { ty->tq.val }; } 1436 1437 1437 1438 /// returns true and sets `node` if in cache 1438 bool inCache( BaseSyntaxNode * old ) {1439 bool inCache( const BaseSyntaxNode * old ) { 1439 1440 auto it = cache.find( old ); 1440 1441 if ( it == cache.end() ) return false; … … 1445 1446 // Now all the visit functions: 1446 1447 1447 virtual void visit( ObjectDecl * old ) override final {1448 virtual void visit( const ObjectDecl * old ) override final { 1448 1449 auto&& type = GET_ACCEPT_1(type, Type); 1449 1450 auto&& init = GET_ACCEPT_1(init, Init); … … 1476 1477 } 1477 1478 1478 virtual void visit( FunctionDecl * old ) override final {1479 virtual void visit( const FunctionDecl * old ) override final { 1479 1480 if ( inCache( old ) ) return; 1480 1481 auto decl = new ast::FunctionDecl{ … … 1509 1510 } 1510 1511 1511 virtual void visit( StructDecl * old ) override final {1512 virtual void visit( const StructDecl * old ) override final { 1512 1513 if ( inCache( old ) ) return; 1513 1514 auto decl = new ast::StructDecl( … … 1534 1535 } 1535 1536 1536 virtual void visit( UnionDecl * old ) override final {1537 virtual void visit( const UnionDecl * old ) override final { 1537 1538 if ( inCache( old ) ) return; 1538 1539 auto decl = new ast::UnionDecl( … … 1554 1555 } 1555 1556 1556 virtual void visit( EnumDecl * old ) override final {1557 virtual void visit( const EnumDecl * old ) override final { 1557 1558 if ( inCache( old ) ) return; 1558 1559 auto decl = new ast::EnumDecl( … … 1574 1575 } 1575 1576 1576 virtual void visit( TraitDecl * old ) override final {1577 virtual void visit( const TraitDecl * old ) override final { 1577 1578 if ( inCache( old ) ) return; 1578 1579 auto decl = new ast::TraitDecl( … … 1594 1595 } 1595 1596 1596 virtual void visit( TypeDecl * old ) override final {1597 virtual void visit( const TypeDecl * old ) override final { 1597 1598 if ( inCache( old ) ) return; 1598 1599 auto decl = new ast::TypeDecl{ … … 1614 1615 } 1615 1616 1616 virtual void visit( TypedefDecl * old ) override final {1617 virtual void visit( const TypedefDecl * old ) override final { 1617 1618 auto decl = new ast::TypedefDecl( 1618 1619 old->location, … … 1631 1632 } 1632 1633 1633 virtual void visit( AsmDecl * old ) override final {1634 virtual void visit( const AsmDecl * old ) override final { 1634 1635 auto decl = new ast::AsmDecl{ 1635 1636 old->location, … … 1643 1644 } 1644 1645 1645 virtual void visit( StaticAssertDecl * old ) override final {1646 virtual void visit( const StaticAssertDecl * old ) override final { 1646 1647 auto decl = new ast::StaticAssertDecl{ 1647 1648 old->location, … … 1656 1657 } 1657 1658 1658 virtual void visit( CompoundStmt * old ) override final {1659 virtual void visit( const CompoundStmt * old ) override final { 1659 1660 if ( inCache( old ) ) return; 1660 1661 auto stmt = new ast::CompoundStmt( … … 1668 1669 } 1669 1670 1670 virtual void visit( ExprStmt * old ) override final {1671 virtual void visit( const ExprStmt * old ) override final { 1671 1672 if ( inCache( old ) ) return; 1672 1673 this->node = new ast::ExprStmt( … … 1678 1679 } 1679 1680 1680 virtual void visit( AsmStmt * old ) override final {1681 virtual void visit( const AsmStmt * old ) override final { 1681 1682 if ( inCache( old ) ) return; 1682 1683 this->node = new ast::AsmStmt( … … 1693 1694 } 1694 1695 1695 virtual void visit( DirectiveStmt * old ) override final {1696 virtual void visit( const DirectiveStmt * old ) override final { 1696 1697 if ( inCache( old ) ) return; 1697 1698 this->node = new ast::DirectiveStmt( … … 1703 1704 } 1704 1705 1705 virtual void visit( IfStmt * old ) override final {1706 virtual void visit( const IfStmt * old ) override final { 1706 1707 if ( inCache( old ) ) return; 1707 1708 this->node = new ast::IfStmt( … … 1716 1717 } 1717 1718 1718 virtual void visit( SwitchStmt * old ) override final {1719 virtual void visit( const SwitchStmt * old ) override final { 1719 1720 if ( inCache( old ) ) return; 1720 1721 this->node = new ast::SwitchStmt( … … 1727 1728 } 1728 1729 1729 virtual void visit( CaseStmt * old ) override final {1730 virtual void visit( const CaseStmt * old ) override final { 1730 1731 if ( inCache( old ) ) return; 1731 1732 this->node = new ast::CaseStmt( … … 1738 1739 } 1739 1740 1740 virtual void visit( WhileStmt * old ) override final {1741 virtual void visit( const WhileStmt * old ) override final { 1741 1742 if ( inCache( old ) ) return; 1742 1743 this->node = new ast::WhileStmt( … … 1751 1752 } 1752 1753 1753 virtual void visit( ForStmt * old ) override final {1754 virtual void visit( const ForStmt * old ) override final { 1754 1755 if ( inCache( old ) ) return; 1755 1756 this->node = new ast::ForStmt( … … 1764 1765 } 1765 1766 1766 virtual void visit( BranchStmt * old ) override final {1767 virtual void visit( const BranchStmt * old ) override final { 1767 1768 if ( inCache( old ) ) return; 1768 1769 if (old->computedTarget) { … … 1801 1802 } 1802 1803 1803 virtual void visit( ReturnStmt * old ) override final {1804 virtual void visit( const ReturnStmt * old ) override final { 1804 1805 if ( inCache( old ) ) return; 1805 1806 this->node = new ast::ReturnStmt( … … 1811 1812 } 1812 1813 1813 virtual void visit( ThrowStmt * old ) override final {1814 virtual void visit( const ThrowStmt * old ) override final { 1814 1815 if ( inCache( old ) ) return; 1815 1816 ast::ExceptionKind kind; … … 1835 1836 } 1836 1837 1837 virtual void visit( TryStmt * old ) override final {1838 virtual void visit( const TryStmt * old ) override final { 1838 1839 if ( inCache( old ) ) return; 1839 1840 this->node = new ast::TryStmt( … … 1847 1848 } 1848 1849 1849 virtual void visit( CatchStmt * old ) override final {1850 virtual void visit( const CatchStmt * old ) override final { 1850 1851 if ( inCache( old ) ) return; 1851 1852 ast::ExceptionKind kind; … … 1872 1873 } 1873 1874 1874 virtual void visit( FinallyStmt * old ) override final {1875 virtual void visit( const FinallyStmt * old ) override final { 1875 1876 if ( inCache( old ) ) return; 1876 1877 this->node = new ast::FinallyStmt( … … 1882 1883 } 1883 1884 1884 virtual void visit( WaitForStmt * old ) override final {1885 virtual void visit( const WaitForStmt * old ) override final { 1885 1886 if ( inCache( old ) ) return; 1886 1887 ast::WaitForStmt * stmt = new ast::WaitForStmt( … … 1914 1915 } 1915 1916 1916 virtual void visit( WithStmt * old ) override final {1917 virtual void visit( const WithStmt * old ) override final { 1917 1918 if ( inCache( old ) ) return; 1918 1919 this->node = new ast::WithStmt( 1919 1920 old->location, 1920 1921 GET_ACCEPT_V(exprs, Expr), 1921 GET_ACCEPT_1(stmt, Stmt), 1922 GET_LABELS_V(old->labels) 1922 GET_ACCEPT_1(stmt, Stmt) 1923 1923 ); 1924 1924 cache.emplace( old, this->node ); 1925 1925 } 1926 1926 1927 virtual void visit( NullStmt * old ) override final {1927 virtual void visit( const NullStmt * old ) override final { 1928 1928 if ( inCache( old ) ) return; 1929 1929 this->node = new ast::NullStmt( … … 1934 1934 } 1935 1935 1936 virtual void visit( DeclStmt * old ) override final {1936 virtual void visit( const DeclStmt * old ) override final { 1937 1937 if ( inCache( old ) ) return; 1938 1938 this->node = new ast::DeclStmt( … … 1944 1944 } 1945 1945 1946 virtual void visit( ImplicitCtorDtorStmt * old ) override final {1946 virtual void visit( const ImplicitCtorDtorStmt * old ) override final { 1947 1947 if ( inCache( old ) ) return; 1948 1948 auto stmt = new ast::ImplicitCtorDtorStmt( … … 2001 2001 } 2002 2002 2003 ast::Expr * visitBaseExpr_SkipResultType( Expression * old, ast::Expr * nw) {2003 ast::Expr * visitBaseExpr_SkipResultType( const Expression * old, ast::Expr * nw) { 2004 2004 2005 2005 nw->env = convertTypeSubstitution(old->env); … … 2011 2011 } 2012 2012 2013 ast::Expr * visitBaseExpr( Expression * old, ast::Expr * nw) {2013 ast::Expr * visitBaseExpr( const Expression * old, ast::Expr * nw) { 2014 2014 2015 2015 nw->result = GET_ACCEPT_1(result, Type); … … 2017 2017 } 2018 2018 2019 virtual void visit( ApplicationExpr * old ) override final {2019 virtual void visit( const ApplicationExpr * old ) override final { 2020 2020 this->node = visitBaseExpr( old, 2021 2021 new ast::ApplicationExpr( … … 2027 2027 } 2028 2028 2029 virtual void visit( UntypedExpr * old ) override final {2029 virtual void visit( const UntypedExpr * old ) override final { 2030 2030 this->node = visitBaseExpr( old, 2031 2031 new ast::UntypedExpr( … … 2037 2037 } 2038 2038 2039 virtual void visit( NameExpr * old ) override final {2039 virtual void visit( const NameExpr * old ) override final { 2040 2040 this->node = visitBaseExpr( old, 2041 2041 new ast::NameExpr( … … 2046 2046 } 2047 2047 2048 virtual void visit( CastExpr * old ) override final {2048 virtual void visit( const CastExpr * old ) override final { 2049 2049 this->node = visitBaseExpr( old, 2050 2050 new ast::CastExpr( … … 2056 2056 } 2057 2057 2058 virtual void visit( KeywordCastExpr * old) override final {2058 virtual void visit( const KeywordCastExpr * old) override final { 2059 2059 ast::KeywordCastExpr::Target castTarget = ast::KeywordCastExpr::NUMBER_OF_TARGETS; 2060 2060 switch (old->target) { … … 2081 2081 } 2082 2082 2083 virtual void visit( VirtualCastExpr * old ) override final {2083 virtual void visit( const VirtualCastExpr * old ) override final { 2084 2084 this->node = visitBaseExpr_SkipResultType( old, 2085 2085 new ast::VirtualCastExpr( … … 2091 2091 } 2092 2092 2093 virtual void visit( AddressExpr * old ) override final {2093 virtual void visit( const AddressExpr * old ) override final { 2094 2094 this->node = visitBaseExpr( old, 2095 2095 new ast::AddressExpr( … … 2100 2100 } 2101 2101 2102 virtual void visit( LabelAddressExpr * old ) override final {2102 virtual void visit( const LabelAddressExpr * old ) override final { 2103 2103 this->node = visitBaseExpr( old, 2104 2104 new ast::LabelAddressExpr( … … 2109 2109 } 2110 2110 2111 virtual void visit( UntypedMemberExpr * old ) override final {2111 virtual void visit( const UntypedMemberExpr * old ) override final { 2112 2112 this->node = visitBaseExpr( old, 2113 2113 new ast::UntypedMemberExpr( … … 2119 2119 } 2120 2120 2121 virtual void visit( MemberExpr * old ) override final {2121 virtual void visit( const MemberExpr * old ) override final { 2122 2122 this->node = visitBaseExpr( old, 2123 2123 new ast::MemberExpr( 2124 2124 old->location, 2125 2125 GET_ACCEPT_1(member, DeclWithType), 2126 GET_ACCEPT_1(aggregate, Expr) 2127 ) 2128 ); 2129 } 2130 2131 virtual void visit( VariableExpr * old ) override final { 2126 GET_ACCEPT_1(aggregate, Expr), 2127 ast::MemberExpr::NoOpConstructionChosen 2128 ) 2129 ); 2130 } 2131 2132 virtual void visit( const VariableExpr * old ) override final { 2132 2133 auto expr = new ast::VariableExpr( 2133 2134 old->location … … 2140 2141 } 2141 2142 2142 virtual void visit( ConstantExpr * old ) override final {2143 virtual void visit( const ConstantExpr * old ) override final { 2143 2144 ast::ConstantExpr *rslt = new ast::ConstantExpr( 2144 2145 old->location, 2145 2146 GET_ACCEPT_1(result, Type), 2146 old->constant. get_value(),2147 old->constant.rep, 2147 2148 old->constant.ival 2148 2149 ); 2149 rslt->underlyer = getAccept1< ast::Type, Type* >( old->constant. get_type());2150 rslt->underlyer = getAccept1< ast::Type, Type* >( old->constant.type ); 2150 2151 this->node = visitBaseExpr( old, rslt ); 2151 2152 } 2152 2153 2153 virtual void visit( SizeofExpr * old ) override final {2154 virtual void visit( const SizeofExpr * old ) override final { 2154 2155 assert (old->expr || old->type); 2155 2156 assert (! (old->expr && old->type)); … … 2172 2173 } 2173 2174 2174 virtual void visit( AlignofExpr * old ) override final {2175 virtual void visit( const AlignofExpr * old ) override final { 2175 2176 assert (old->expr || old->type); 2176 2177 assert (! (old->expr && old->type)); … … 2193 2194 } 2194 2195 2195 virtual void visit( UntypedOffsetofExpr * old ) override final {2196 virtual void visit( const UntypedOffsetofExpr * old ) override final { 2196 2197 this->node = visitBaseExpr( old, 2197 2198 new ast::UntypedOffsetofExpr( … … 2203 2204 } 2204 2205 2205 virtual void visit( OffsetofExpr * old ) override final {2206 virtual void visit( const OffsetofExpr * old ) override final { 2206 2207 this->node = visitBaseExpr( old, 2207 2208 new ast::OffsetofExpr( … … 2213 2214 } 2214 2215 2215 virtual void visit( OffsetPackExpr * old ) override final {2216 virtual void visit( const OffsetPackExpr * old ) override final { 2216 2217 this->node = visitBaseExpr( old, 2217 2218 new ast::OffsetPackExpr( … … 2222 2223 } 2223 2224 2224 virtual void visit( LogicalExpr * old ) override final {2225 virtual void visit( const LogicalExpr * old ) override final { 2225 2226 this->node = visitBaseExpr( old, 2226 2227 new ast::LogicalExpr( … … 2235 2236 } 2236 2237 2237 virtual void visit( ConditionalExpr * old ) override final {2238 virtual void visit( const ConditionalExpr * old ) override final { 2238 2239 this->node = visitBaseExpr( old, 2239 2240 new ast::ConditionalExpr( … … 2246 2247 } 2247 2248 2248 virtual void visit( CommaExpr * old ) override final {2249 virtual void visit( const CommaExpr * old ) override final { 2249 2250 this->node = visitBaseExpr( old, 2250 2251 new ast::CommaExpr( … … 2256 2257 } 2257 2258 2258 virtual void visit( TypeExpr * old ) override final {2259 virtual void visit( const TypeExpr * old ) override final { 2259 2260 this->node = visitBaseExpr( old, 2260 2261 new ast::TypeExpr( … … 2265 2266 } 2266 2267 2267 virtual void visit( AsmExpr * old ) override final {2268 virtual void visit( const AsmExpr * old ) override final { 2268 2269 this->node = visitBaseExpr( old, 2269 2270 new ast::AsmExpr( … … 2276 2277 } 2277 2278 2278 virtual void visit( ImplicitCopyCtorExpr * old ) override final {2279 virtual void visit( const ImplicitCopyCtorExpr * old ) override final { 2279 2280 auto rslt = new ast::ImplicitCopyCtorExpr( 2280 2281 old->location, … … 2285 2286 } 2286 2287 2287 virtual void visit( ConstructorExpr * old ) override final {2288 virtual void visit( const ConstructorExpr * old ) override final { 2288 2289 this->node = visitBaseExpr( old, 2289 2290 new ast::ConstructorExpr( … … 2294 2295 } 2295 2296 2296 virtual void visit( CompoundLiteralExpr * old ) override final {2297 virtual void visit( const CompoundLiteralExpr * old ) override final { 2297 2298 this->node = visitBaseExpr_SkipResultType( old, 2298 2299 new ast::CompoundLiteralExpr( … … 2304 2305 } 2305 2306 2306 virtual void visit( RangeExpr * old ) override final {2307 virtual void visit( const RangeExpr * old ) override final { 2307 2308 this->node = visitBaseExpr( old, 2308 2309 new ast::RangeExpr( … … 2314 2315 } 2315 2316 2316 virtual void visit( UntypedTupleExpr * old ) override final {2317 virtual void visit( const UntypedTupleExpr * old ) override final { 2317 2318 this->node = visitBaseExpr( old, 2318 2319 new ast::UntypedTupleExpr( … … 2323 2324 } 2324 2325 2325 virtual void visit( TupleExpr * old ) override final {2326 virtual void visit( const TupleExpr * old ) override final { 2326 2327 this->node = visitBaseExpr( old, 2327 2328 new ast::TupleExpr( … … 2332 2333 } 2333 2334 2334 virtual void visit( TupleIndexExpr * old ) override final {2335 virtual void visit( const TupleIndexExpr * old ) override final { 2335 2336 this->node = visitBaseExpr( old, 2336 2337 new ast::TupleIndexExpr( … … 2342 2343 } 2343 2344 2344 virtual void visit( TupleAssignExpr * old ) override final {2345 virtual void visit( const TupleAssignExpr * old ) override final { 2345 2346 this->node = visitBaseExpr_SkipResultType( old, 2346 2347 new ast::TupleAssignExpr( … … 2352 2353 } 2353 2354 2354 virtual void visit( StmtExpr * old ) override final {2355 virtual void visit( const StmtExpr * old ) override final { 2355 2356 auto rslt = new ast::StmtExpr( 2356 2357 old->location, … … 2363 2364 } 2364 2365 2365 virtual void visit( UniqueExpr * old ) override final {2366 virtual void visit( const UniqueExpr * old ) override final { 2366 2367 auto rslt = new ast::UniqueExpr( 2367 2368 old->location, … … 2375 2376 } 2376 2377 2377 virtual void visit( UntypedInitExpr * old ) override final {2378 virtual void visit( const UntypedInitExpr * old ) override final { 2378 2379 std::deque<ast::InitAlternative> initAlts; 2379 2380 for (auto ia : old->initAlts) { … … 2392 2393 } 2393 2394 2394 virtual void visit( InitExpr * old ) override final {2395 virtual void visit( const InitExpr * old ) override final { 2395 2396 this->node = visitBaseExpr( old, 2396 2397 new ast::InitExpr( … … 2402 2403 } 2403 2404 2404 virtual void visit( DeletedExpr * old ) override final {2405 virtual void visit( const DeletedExpr * old ) override final { 2405 2406 this->node = visitBaseExpr( old, 2406 2407 new ast::DeletedExpr( … … 2408 2409 GET_ACCEPT_1(expr, Expr), 2409 2410 inCache(old->deleteStmt) ? 2410 this->node:2411 GET_ACCEPT_1(deleteStmt, Node)2412 ) 2413 ); 2414 } 2415 2416 virtual void visit( DefaultArgExpr * old ) override final {2411 strict_dynamic_cast<ast::Decl*>(this->node) : 2412 GET_ACCEPT_1(deleteStmt, Decl) 2413 ) 2414 ); 2415 } 2416 2417 virtual void visit( const DefaultArgExpr * old ) override final { 2417 2418 this->node = visitBaseExpr( old, 2418 2419 new ast::DefaultArgExpr( … … 2423 2424 } 2424 2425 2425 virtual void visit( GenericExpr * old ) override final {2426 virtual void visit( const GenericExpr * old ) override final { 2426 2427 std::vector<ast::GenericExpr::Association> associations; 2427 2428 for (auto association : old->associations) { … … 2440 2441 } 2441 2442 2442 void visitType( Type * old, ast::Type * type ) {2443 void visitType( const Type * old, ast::Type * type ) { 2443 2444 // Some types do this in their constructor so add a check. 2444 2445 if ( !old->attributes.empty() && type->attributes.empty() ) { … … 2448 2449 } 2449 2450 2450 virtual void visit( VoidType * old ) override final {2451 virtual void visit( const VoidType * old ) override final { 2451 2452 visitType( old, new ast::VoidType{ cv( old ) } ); 2452 2453 } 2453 2454 2454 virtual void visit( BasicType * old ) override final {2455 virtual void visit( const BasicType * old ) override final { 2455 2456 auto type = new ast::BasicType{ (ast::BasicType::Kind)(unsigned)old->kind, cv( old ) }; 2456 2457 // I believe this should always be a BasicType. … … 2461 2462 } 2462 2463 2463 virtual void visit( PointerType * old ) override final {2464 virtual void visit( const PointerType * old ) override final { 2464 2465 visitType( old, new ast::PointerType{ 2465 2466 GET_ACCEPT_1( base, Type ), … … 2471 2472 } 2472 2473 2473 virtual void visit( ArrayType * old ) override final {2474 virtual void visit( const ArrayType * old ) override final { 2474 2475 visitType( old, new ast::ArrayType{ 2475 2476 GET_ACCEPT_1( base, Type ), … … 2481 2482 } 2482 2483 2483 virtual void visit( ReferenceType * old ) override final {2484 virtual void visit( const ReferenceType * old ) override final { 2484 2485 visitType( old, new ast::ReferenceType{ 2485 2486 GET_ACCEPT_1( base, Type ), … … 2488 2489 } 2489 2490 2490 virtual void visit( QualifiedType * old ) override final {2491 virtual void visit( const QualifiedType * old ) override final { 2491 2492 visitType( old, new ast::QualifiedType{ 2492 2493 GET_ACCEPT_1( parent, Type ), … … 2496 2497 } 2497 2498 2498 virtual void visit( FunctionType * old ) override final {2499 virtual void visit( const FunctionType * old ) override final { 2499 2500 auto ty = new ast::FunctionType { 2500 2501 (ast::ArgumentFlag)old->isVarArgs, … … 2507 2508 } 2508 2509 2509 void postvisit( ReferenceToType * old, ast::ReferenceToType * ty ) {2510 void postvisit( const ReferenceToType * old, ast::ReferenceToType * ty ) { 2510 2511 ty->forall = GET_ACCEPT_V( forall, TypeDecl ); 2511 2512 ty->params = GET_ACCEPT_V( parameters, Expr ); … … 2514 2515 } 2515 2516 2516 virtual void visit( StructInstType * old ) override final {2517 virtual void visit( const StructInstType * old ) override final { 2517 2518 ast::StructInstType * ty; 2518 2519 if ( old->baseStruct ) { … … 2532 2533 } 2533 2534 2534 virtual void visit( UnionInstType * old ) override final {2535 virtual void visit( const UnionInstType * old ) override final { 2535 2536 ast::UnionInstType * ty; 2536 2537 if ( old->baseUnion ) { … … 2550 2551 } 2551 2552 2552 virtual void visit( EnumInstType * old ) override final {2553 virtual void visit( const EnumInstType * old ) override final { 2553 2554 ast::EnumInstType * ty; 2554 2555 if ( old->baseEnum ) { … … 2568 2569 } 2569 2570 2570 virtual void visit( TraitInstType * old ) override final {2571 virtual void visit( const TraitInstType * old ) override final { 2571 2572 ast::TraitInstType * ty; 2572 2573 if ( old->baseTrait ) { … … 2586 2587 } 2587 2588 2588 virtual void visit( TypeInstType * old ) override final {2589 virtual void visit( const TypeInstType * old ) override final { 2589 2590 ast::TypeInstType * ty; 2590 2591 if ( old->baseType ) { … … 2606 2607 } 2607 2608 2608 virtual void visit( TupleType * old ) override final {2609 virtual void visit( const TupleType * old ) override final { 2609 2610 visitType( old, new ast::TupleType{ 2610 2611 GET_ACCEPT_V( types, Type ), … … 2614 2615 } 2615 2616 2616 virtual void visit( TypeofType * old ) override final {2617 virtual void visit( const TypeofType * old ) override final { 2617 2618 visitType( old, new ast::TypeofType{ 2618 2619 GET_ACCEPT_1( expr, Expr ), … … 2622 2623 } 2623 2624 2624 virtual void visit( AttrType * ) override final {2625 virtual void visit( const AttrType * ) override final { 2625 2626 assertf( false, "AttrType deprecated in new AST." ); 2626 2627 } 2627 2628 2628 virtual void visit( VarArgsType * old ) override final {2629 virtual void visit( const VarArgsType * old ) override final { 2629 2630 visitType( old, new ast::VarArgsType{ cv( old ) } ); 2630 2631 } 2631 2632 2632 virtual void visit( ZeroType * old ) override final {2633 virtual void visit( const ZeroType * old ) override final { 2633 2634 visitType( old, new ast::ZeroType{ cv( old ) } ); 2634 2635 } 2635 2636 2636 virtual void visit( OneType * old ) override final {2637 virtual void visit( const OneType * old ) override final { 2637 2638 visitType( old, new ast::OneType{ cv( old ) } ); 2638 2639 } 2639 2640 2640 virtual void visit( GlobalScopeType * old ) override final {2641 virtual void visit( const GlobalScopeType * old ) override final { 2641 2642 visitType( old, new ast::GlobalScopeType{} ); 2642 2643 } 2643 2644 2644 virtual void visit( Designation * old ) override final {2645 virtual void visit( const Designation * old ) override final { 2645 2646 this->node = new ast::Designation( 2646 2647 old->location, … … 2649 2650 } 2650 2651 2651 virtual void visit( SingleInit * old ) override final {2652 virtual void visit( const SingleInit * old ) override final { 2652 2653 this->node = new ast::SingleInit( 2653 2654 old->location, … … 2657 2658 } 2658 2659 2659 virtual void visit( ListInit * old ) override final {2660 virtual void visit( const ListInit * old ) override final { 2660 2661 this->node = new ast::ListInit( 2661 2662 old->location, … … 2666 2667 } 2667 2668 2668 virtual void visit( ConstructorInit * old ) override final {2669 virtual void visit( const ConstructorInit * old ) override final { 2669 2670 this->node = new ast::ConstructorInit( 2670 2671 old->location, … … 2675 2676 } 2676 2677 2677 virtual void visit( Constant * ) override final {2678 virtual void visit( const Constant * ) override final { 2678 2679 // Handled in visit( ConstantEpxr * ). 2679 2680 // In the new tree, Constant fields are inlined into containing ConstantExpression. … … 2681 2682 } 2682 2683 2683 virtual void visit( Attribute * old ) override final {2684 virtual void visit( const Attribute * old ) override final { 2684 2685 this->node = new ast::Attribute( 2685 2686 old->name, … … 2688 2689 } 2689 2690 2690 virtual void visit( AttrExpr * ) override final {2691 virtual void visit( const AttrExpr * ) override final { 2691 2692 assertf( false, "AttrExpr deprecated in new AST." ); 2692 2693 }
Note:
See TracChangeset
for help on using the changeset viewer.