Changeset 1ee0a4da for src/main.cc


Ignore:
Timestamp:
Oct 3, 2023, 10:58:40 AM (9 months ago)
Author:
Andrew Beach <ajbeach@…>
Branches:
master
Children:
cf34e82
Parents:
46f9f02
Message:

Translated the box pass to the new AST. This includes direct as possible translations of the existing passes are two fix in passes which correct AST problems the direct translation causes. Outside the box pass there have already been many changes, ad there is another in Instantiate Generics, which disconnects designators instead of leaving them connected to the original polymorphic type, which breaks the invarants once the fields are removed in the Eraser sub-pass. There was also a change that was made and un-made in one commit. If translate from the new-AST to the old-AST part way you must, where possible, sort the TypeEnvKey? values by string comparison. However, it now passes over that so it would be just extra complexity and run time, so I removed it. I stand at the exit from a great woods, just shy of a year from when I entered it. It has been a difficult and tiring journey. The path has been long and at times comically winding; but most often it was invisible, hidden under an impenetrable canopy and I spend days looking for it. All for a short jog forward before getting lost again. In front of me is another woods. It looks smaller, but I can't see the other side. Anyways, time to keep walking.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/main.cc

    r46f9f02 r1ee0a4da  
    419419
    420420                PASS( "Convert L-Value", GenPoly::convertLvalue, transUnit );
     421                DUMP( bboxp, std::move( transUnit ) );
     422                PASS( "Box", GenPoly::box, transUnit );
    421423
    422424                translationUnit = convert( std::move( transUnit ) );
    423 
    424                 DUMP( bboxp, translationUnit );
    425                 PASS( "Box", GenPoly::box, translationUnit );
    426425
    427426                PASS( "Link-Once", CodeGen::translateLinkOnce, translationUnit );
Note: See TracChangeset for help on using the changeset viewer.