Crafting Interpreters
94 points
by tosh
10 hours ago
| 8 comments
| craftinginterpreters.com
| HN
azhenley
7 hours ago
[-]
The two most popular discussions of this fantastic book:

2020 with 777 points: https://news.ycombinator.com/item?id=22788738

2024 with 607 points: https://news.ycombinator.com/item?id=40950235

reply
kunley
47 minutes ago
[-]
Part of a 2nd half of this book translated to Go became a skeleton for the BCL configuration language https://github.com/wkhere/bcl
reply
rohitpaulk
6 hours ago
[-]
In case anyone finds it useful, we (CodeCrafters) built a coding challenge as a companion to this book. The official repository for the book made this very easy to do since it has tests for each individual chapter.

Link: https://app.codecrafters.io/courses/interpreter/overview

reply
mi_lk
1 hour ago
[-]
Not sure why this ad (access needs paid membership) is the top comment
reply
keyle
4 hours ago
[-]
It's a great book, I bought the paper version first, but man it was too big and heavy for my liking, ended up buying a digital copy; much more practical for notes and search...

although I keep getting lost somewhere in the mountain :)

I also recommend munificent's other book about game programming patterns. Both are fun to read.

reply
Nora23
6 hours ago
[-]
One of the best resources for learning compiler design. The web version being free is incredibly generous.
reply
chrysoprace
5 hours ago
[-]
I've found this book to be a good way to learn a new language, because it forces you to do a bit of reading about various language features and patterns to create equivalent implementations. For languages that lack some of the features in Java, it can be tricky to learn how to apply similar patterns, but that's half the fun (for me).
reply
acedTrex
5 hours ago
[-]
I have bought the print version of this 3 seperate times to give as a gift, its excellent.
reply
stevefan1999
7 hours ago
[-]
Really I would love to know how parse context sensitive stuff like typedef which will have "switched" syntax for some tokens. Would like to know things like "hoisting" in C++, where you can you the class and struct after the code inside the function too, but I just find it hard to describe them in rigorous formal language and grammar.

Hacky solution for PEG such as adding a context stack requires careful management of the entry/exit point, but the more fundamental problem is that you still can't "switch" syntax, or you have to add all possible syntax combination depending on the numbers of such stacks. I believe persistent data structure and transactional data structure would help but I just couldn't find a formalism for that.

reply
remexre
6 hours ago
[-]
https://en.wikipedia.org/wiki/Lexer_hack

Make your parser call back into your lexer, so it can pass state to it; make the set of type names available to it.

reply