Premium Only Content
Compiler From Scratch: Phase 1 - Tokenizer Generator 009: Generating DFA State code
Streamed on 2024-09-13 (https://www.twitch.tv/thediscouragerofhesitancy)
Zero Dependencies Programming!
I have to confess to cheating ... I did some work on the compiler off-stream. I created an asset pipeline for managing Code Snippets ... large chunks of text that are the same no matter what. These Code Snippets can be divided into chunks with a line of "...", so I can write a chunk, then emit custom code, and move on to the next chunk. The other thing was I refactored TxtBuf and ChrRef to remove the circular dependency that would necessarily exist if I use ChrRef in a TxtBuf::Iterator. And now I have a TxtBuff::Iterator. But that was all the cheating, I swear! Everything else we do on-stream.
Today was starting to emit DFAStates into our Tokenizer. Each DFAState has a list of Transitions and each Transition contains a list of conditions to check, and where the next DFAState is if those conditions are met. All the code emitted today was into simple methods, one per DFAState.
But a lot of the complexity we will face will come in the form of the PerformanceSwitches I am putting in. Whenever I come to a decision that I think will impact performance I am emitting code for each of those decisions, wrapped in a #ifdef/#endif so we can change some defines in our build and test the alternatives. There is some overlap between some of the options I've thought up, so we are going to be emitting way more code than we will end up with. As we go we will confirm correctness of each PerformanceSwitch, but we won't profile until things are working end-to-end and we have a large body of text to test against ... maybe JSON? So, if this stage of development seems a little slow, remember, I am generating 96 (currently) permutations of the way this code could be written.
-
30:58
SouthernbelleReacts
2 days ago $6.77 earnedWe Didn’t Expect That Ending… ‘Welcome to Derry’ S1 E1 Reaction
24.4K8 -
13:51
True Crime | Unsolved Cases | Mysterious Stories
5 days ago $16.11 earned7 Real Life Heroes Caught on Camera (Remastered Audio)
40.7K10 -
LIVE
Total Horse Channel
14 hours ago2025 IRCHA Derby & Horse Show - November 1st
142 watching -
4:19
PistonPop-TV
6 days ago $7.18 earnedThe 4E-FTE: Toyota’s Smallest Turbo Monster
36.6K -
43:07
WanderingWithWine
6 days ago $4.01 earned5 Dreamy Italian Houses You Can Own Now! Homes for Sale in Italy
27.5K9 -
LIVE
Spartan
23 hours agoFirst playthrough of First Berserker Khazan
136 watching -
28:01
Living Your Wellness Life
2 days agoTrain Your Hormones
23K1 -
43:28
The Heidi St. John Podcast
1 day agoFan Mail Friday: Faith Over Fear and Finding Strength in Every Season
13.7K -
1:05:30
SGT Report
1 day agoTHE HORRIBLE TRUTH ABOUT EVERYTHING -- Harley Schlanger
56.3K95 -
11:04
Blackstone Griddles
19 hours agoCountry Fried Steaks on the Blackstone Griddle
96.9K14