619
|
1 |
|
|
2 |
Curated list of awesome resources on Compilers, Interpreters and Runtimes
|
|
3 |
http://aalhour.com/awesome-compilers
|
|
4 |
https://github.com/aalhour/awesome-compilers
|
|
5 |
|
|
6 |
----------------
|
|
7 |
|
599
|
8 |
Thinking Forth (Book to read)
|
|
9 |
=================
|
|
10 |
|
618
|
11 |
=================
|
|
12 |
opinionated functional programming language compiling to the JVM
|
|
13 |
https://flix.github.io/#/research/
|
|
14 |
https://flix.github.io/#/principles/
|
599
|
15 |
|
618
|
16 |
|
|
17 |
=================
|
|
18 |
General tail call elimination on the JVM
|
|
19 |
|
|
20 |
http://cs.au.dk/~magnusm/papers/cc18/paper.pdf
|
|
21 |
|
|
22 |
=================
|
|
23 |
incremental approach to compiler construction
|
|
24 |
http://scheme2006.cs.uchicago.edu/11-ghuloum.pdf
|
|
25 |
|
|
26 |
=================
|
550
|
27 |
Compiler courses
|
|
28 |
http://www.cse.chalmers.se/edu/year/2017/course/TDA283/lectures/
|
|
29 |
http://www.cs.columbia.edu/~sedwards/classes/2017/4115-fall/index.html
|
|
30 |
http://www.cs.dartmouth.edu/~mckeeman/cs48/index.html
|
553
|
31 |
http://www.cl.cam.ac.uk/teaching/1718/CompConstr/materials.html
|
555
|
32 |
|
|
33 |
|
|
34 |
http://spivey.oriel.ox.ac.uk/corner/Welcome_to_Spivey%27s_Corner
|
|
35 |
http://spivey.oriel.ox.ac.uk/corner/Compilers_(The_Farewell_Tour)
|
|
36 |
http://spivey.oriel.ox.ac.uk/wiki2/files/compilers/book.pdf
|
|
37 |
http://spivey.oriel.ox.ac.uk/corner/Programming_Languages
|
|
38 |
|
556
|
39 |
http://www.cs.cornell.edu/courses/cs3110/2015fa/index.php#Assignments
|
|
40 |
Magnus
|
|
41 |
http://www.cse.chalmers.se/edu/course/TDA283/
|
|
42 |
Pfenning
|
|
43 |
https://www.cs.cmu.edu/~fp/courses/15411-f14/
|
|
44 |
https://www.cs.cmu.edu/~fp/courses/15411-f13/lectures/
|
|
45 |
https://www.cs.cmu.edu/~fp/courses/15411-f14/lectures/
|
550
|
46 |
===============================
|
570
|
47 |
Compiler book links
|
|
48 |
https://www.reddit.com/r/ProgrammingLanguages/comments/9k2hfd/introduction_to_compilers_and_language_design/
|
|
49 |
|
|
50 |
http://www.craftinginterpreters.com
|
|
51 |
|
|
52 |
Book about SSA
|
|
53 |
http://ssabook.gforge.inria.fr/latest/book-full.pdf
|
|
54 |
|
|
55 |
http://cs.lmu.edu/~ray/notes/ir/
|
|
56 |
===============================
|
556
|
57 |
Selfhosting Lisp compiler for Lua
|
|
58 |
|
|
59 |
https://github.com/sctb/lumen
|
|
60 |
============================
|
595
|
61 |
Basic as a DSL in Scala
|
|
62 |
https://github.com/fogus/baysick/blob/master/src/main/scala/fogus/baysick/Baysick.scala
|
556
|
63 |
|
597
|
64 |
|
|
65 |
============================
|
|
66 |
Arihmetic with regexes
|
|
67 |
|
|
68 |
http://www.drregex.com/2018/11/how-to-match-b-c-where-abc-beast-reborn.html
|
595
|
69 |
============================
|
|
70 |
Static analysis lecture notes
|
|
71 |
https://cs.au.dk/~amoeller/spa/spa.pdf
|
|
72 |
|
|
73 |
============================
|
550
|
74 |
|
|
75 |
Pictures from the Starting Forth book
|
546
|
76 |
|
|
77 |
https://www.forth.com/starting-forth/2-stack-manipulation-operators-arithmetic/
|
|
78 |
|
|
79 |
--------------------------------
|
550
|
80 |
Java Byte Code for SCALA
|
|
81 |
https://www.toptal.com/scala/scala-bytecode-and-the-jvm
|
546
|
82 |
|
550
|
83 |
------------------
|
546
|
84 |
Yeti - ML for the JVM
|
|
85 |
https://mth.github.io/yeti/
|
|
86 |
http://dot.planet.ee/yeti/intro.html
|
|
87 |
|
550
|
88 |
------------------
|
|
89 |
Ocaml for LLVM
|
|
90 |
https://github.com/artagnon/rhine-ml
|
|
91 |
|
|
92 |
---------------
|
|
93 |
Type inference
|
|
94 |
http://www.calebh.io/Type-Inference-by-Solving-Constraints/
|
|
95 |
|
|
96 |
|
546
|
97 |
|
|
98 |
JVM languages
|
|
99 |
https://en.wikipedia.org/wiki/List_of_JVM_languages
|
|
100 |
https://www.codeproject.com/Articles/50377/Create-Your-Own-Programming-Language
|
|
101 |
|
|
102 |
|
|
103 |
Scheme
|
|
104 |
https://wespiser.com/writings/wyas/home.html
|
|
105 |
http://peter.michaux.ca/index#Scheme
|
|
106 |
|
|
107 |
|
|
108 |
|
476
|
109 |
assmebly (calculator RPN)
|
|
110 |
|
|
111 |
https://dere.github.io/2017-02-12/beginners-assembly-part1/
|
|
112 |
|
|
113 |
|
477
|
114 |
webassembly
|
|
115 |
https://sourceware.org/ml/binutils/2017-03/msg00044.html
|
|
116 |
https://hacks.mozilla.org/2017/02/a-cartoon-intro-to-webassembly/
|
495
|
117 |
https://webassembly.github.io/spec/
|
477
|
118 |
|
|
119 |
webassembly explorer
|
|
120 |
https://mbebenita.github.io/WasmExplorer/
|
|
121 |
|
495
|
122 |
ARM
|
|
123 |
https://azeria-labs.com/writing-arm-assembly-part-1/
|
477
|
124 |
|
495
|
125 |
JVM
|
|
126 |
https://www.toptal.com/scala/scala-bytecode-and-the-jvm
|
|
127 |
|
|
128 |
Growing a compiler
|
|
129 |
http://www.cs.dartmouth.edu/~mckeeman/cs48/mxcom/gem/html/GrowingCompiler.html
|
477
|
130 |
|
|
131 |
free books
|
|
132 |
https://github.com/vhf/free-programming-books/blob/master/free-programming-books.md
|
495
|
133 |
https://john.cs.olemiss.edu/~hcc/csci658/notes/Free_Prog_Lang_Textbooks.html
|
|
134 |
|
|
135 |
MIPS
|
|
136 |
http://courses.missouristate.edu/kenvollmar/mars/
|
|
137 |
|
|
138 |
PEG
|
|
139 |
|
|
140 |
https://github.com/taocpp/PEGTL
|
|
141 |
|
|
142 |
|
|
143 |
Parser
|
|
144 |
https://www.reddit.com/r/programming/comments/615hoz/how_to_write_a_recursive_descent_parser/
|
|
145 |
https://www.reddit.com/r/ProgrammingLanguages/comments/60gmgc/writing_a_recursive_descent_expression_parser/
|
|
146 |
http://www.craftinginterpreters.com/parsing-expressions.html
|
|
147 |
|
|
148 |
|
|
149 |
small languages
|
|
150 |
https://github.com/Michael2109/cobalt
|
|
151 |
http://www.red-lang.org/p/about.html
|
|
152 |
http://craftinginterpreters.com/contents.html
|
|
153 |
https://michaelhaywoodblog.wordpress.com
|
|
154 |
https://ruslanspivak.com/lsbasi-part1/
|
|
155 |
http://selfie.cs.uni-salzburg.at
|
550
|
156 |
https://academy.realm.io/posts/tryswift-samuel-giddins-building-tiny-compiler-swift-ios/
|
|
157 |
https://legacy.gitbook.com/book/luxlang/the-lux-programming-language/details
|
|
158 |
https://github.com/rhysd/gocaml
|
|
159 |
https://github.com/aalhour/awesome-compilers#educational-and-toy-projects
|
|
160 |
https://rsms.me/hue-intro
|
495
|
161 |
|
|
162 |
|
|
163 |
automata
|
|
164 |
https://www7.in.tum.de/um/courses/auto/ws1314/script/autonotes.pdf
|
|
165 |
|
|
166 |
Reges helpers
|
|
167 |
https://regex101.com
|
|
168 |
http://www.regular-expressions.info/tutorial.html
|
|
169 |
|
|
170 |
|
|
171 |
Regex performance benchmark
|
|
172 |
https://rust-leipzig.github.io/regex/2017/03/28/comparison-of-regex-engines/
|
|
173 |
https://github.com/k-takata/Onigmo
|
|
174 |
|
|
175 |
Sulzmann
|
|
176 |
https://github.com/pippijn/dreml/
|
|
177 |
|
|
178 |
|
|
179 |
Scala parser
|
|
180 |
http://enear.github.io/2016/03/31/parser-combinators/
|
|
181 |
|
|
182 |
|
|
183 |
ANTLR megatutorial
|
|
184 |
https://tomassetti.me/antlr-mega-tutorial/
|
|
185 |
|
|
186 |
From regex to LLVM
|
|
187 |
https://www.youtube.com/watch?v=Ukqb6nMjFyk
|
|
188 |
|
|
189 |
|
|
190 |
|
|
191 |
|
|
192 |
Static code analysis
|
550
|
193 |
https://medium.com/@Coder_HarryLee/videos-about-static-code-analysis-7654b40f9a3b
|
|
194 |
|
|
195 |
|
|
196 |
Brainfuck compiler
|
|
197 |
https://github.com/PurpleMyst/bf_compiler
|
|
198 |
https://www.reddit.com/r/programming/comments/8371tk/a_brainfuck_to_llvm_ir_compiler_written_in_python/
|
|
199 |
http://www.wilfred.me.uk/blog/2015/02/21/my-first-llvm-compiler/
|
|
200 |
|
|
201 |
===============================
|
|
202 |
A simple recursive regular expression matcher written in Scala.
|
|
203 |
https://github.com/marconilanna/RegexMatcher
|
|
204 |
|
|
205 |
===============================
|
|
206 |
A neat little tool to build presentations using the Scala REPL
|
|
207 |
https://github.com/marconilanna/REPLesent
|
|
208 |
|
|
209 |
|
|
210 |
======================
|
|
211 |
Minimal Static Single Assignment Form
|
|
212 |
Max Wagner and Denis Lohner
|
|
213 |
|
|
214 |
This formalization is an extension to "Verified Construction of Static Single
|
|
215 |
Assignment Form". In their work, the authors have shown that Braun et al.'s
|
|
216 |
static single assignment (SSA) construction algorithm produces minimal SSA form
|
|
217 |
for input programs with a reducible control flow graph (CFG). However Braun et
|
|
218 |
al. also proposed an extension to their algorithm that they claim produces
|
|
219 |
minimal SSA form even for irreducible CFGs.
|
|
220 |
In this formalization we support that claim by giving a mechanized proof.
|
|
221 |
|
|
222 |
As the extension of Braun et al.'s algorithm aims for removing so-called
|
|
223 |
redundant strongly connected components of phi functions, we show that this
|
|
224 |
suffices to guarantee minimality according to Cytron et al..
|
|
225 |
|
|
226 |
https://www.isa-afp.org/entries/Minimal_SSA.shtml
|
|
227 |
|
|
228 |
|
553
|
229 |
=========================
|
|
230 |
How Clang compiles a function
|
|
231 |
https://blog.regehr.org/archives/1605 |