| ▲ | pratikdeoghare 4 hours ago | |||||||||||||
There is one in golang regular expressions https://swtch.com/~rsc/regexp/regexp2.html I guess that is why you say re.Compile. | ||||||||||||||
| ▲ | rhdunn 4 hours ago | parent | next [-] | |||||||||||||
That goes back to Ken Thompson's NFA regex interpreter from 1968 [1], [2], [3]. Note: that whole regex series by Russ Cox [4] is great. [1] https://dl.acm.org/doi/10.1145/363347.363387 -- Programming Techniques: Regular expression search algorithm [2] https://swtch.com/~rsc/regexp/regexp1.html -- Regular Expression Matching Can Be Simple And Fast [3] https://swtch.com/~rsc/regexp/regexp2.html -- Regular Expression Matching: the Virtual Machine Approach [4] https://swtch.com/~rsc/regexp/ -- Implementing Regular Expressions | ||||||||||||||
| ||||||||||||||
| ▲ | pjc50 4 hours ago | parent | prev | next [-] | |||||||||||||
All regular expressions are deterministic final automata https://en.wikipedia.org/wiki/Deterministic_finite_automaton (finally, a use for my CS course); the extent to which that counts as a virtual machine varies. Some of the regex syntaxes extend it in ways which don't fit in a DFA and do count as a VM; Perl-compatible RE used to be popular (e.g. in Exim). | ||||||||||||||
| ||||||||||||||
| ▲ | sureglymop 4 hours ago | parent | prev [-] | |||||||||||||
Interesting. Not that surprising that it works like this. But isn't it a little surprising that things like regexes, printf syntax and other DSLs aren't mostly handled and parsed at compile time in 2026? | ||||||||||||||
| ||||||||||||||