Premium Only Content
Compiler From Scratch: Phase 1 - Tokenizer Generator 014: Regex code gen/testing, starting lazy eval
Streamed on 2024-10-18 (https://www.twitch.tv/thediscouragerofhesitancy)
Zero Dependencies Programming!
Last week we had debugged the NFA/DFA not picking up the "ANY" operator correctly and fixed it up through the DFA. I didn't like the way it printed out in the DFA table or DFA graphviz plot, so I fixed that first thing. That was followed up with a small refactor of function names left over from last week's output improvements. Just a couple of small, easy tasks to get warmed up.
After that it was time to do code generation for the ANY operator, which was easier than expected. It was basically putting "true" inside the if condition. A little debugging around the Regex for strings and it was good to go. After that I generated code for the StartOfLine and EndOfLine anchors. The main effort was two functions added to the ChrRef, then that function was called from the tokenizer. Since the anchor operators don't consume a character there was a bit of fiddling to suppress the "munch" function call in these cases. Just a bit more finagling around detecting the end of input and all was well.
I tested a couple of possible error cases with the new processing in place. One turned out to be fine, the other caused a crash as expected (unterminated string at the end of input). This was noted in the TODO for future attention.
And finally it was time to start building out the lazy tokenizer processing. There were a few opportunities to refactor/cleanup other code as we went through this exercise. The high-level methods for doing the lazy processing are put together well enough to compile, but there are still changes needed to get the whole thing working end-to-end, mostly in the helper functions. We'll pick up there next week.
-
5:41:25
GritsGG
5 hours ago#1 Most Warzone Wins 3953+!
20.3K2 -
LIVE
Spartan
1 hour agoGetting to DLC Boss on Stellar Blade (Hard Mode), then moving on to something else.
32 watching -
LIVE
a12cat34dog
3 hours agoTHIS GAME IS SO OLD :: Half-Life (1998) :: FINISHING IT TODAY [FIRST TIME PLAYING] {18+}
131 watching -
10:23
Forrest Galante
12 hours agoAsking an Indian Billionaire Why He Is Saving 1 Million Animals
88.9K30 -
2:27:17
LexTronic
2 hours agoEditing Photos from DreakHack
1211 -
LIVE
DoldrumDan
2 hours agoSEKIRO DAY 18 FIRST PLAYTHROUGH - DAY 37 NEW LIFE
19 watching -
23:30
Lady Decade
23 hours ago $21.88 earnedYakuza Kiwami 3 is Causing Outrage !
50.5K13 -
LIVE
Lofi Girl
3 years agolofi hip hop radio 📚 - beats to relax/study to
135 watching -
2:48:38
Pepkilla
3 hours agoArc Raiders First Try Send HALLLPPPP
3521 -
3:24:29
SpartakusLIVE
5 hours agoARC Raiders Solos - FRIENDLY or TOXIC?!
205K8