550
|
1 |
Compiler courses
|
|
2 |
http://www.cse.chalmers.se/edu/year/2017/course/TDA283/lectures/
|
|
3 |
http://www.cs.columbia.edu/~sedwards/classes/2017/4115-fall/index.html
|
|
4 |
http://www.cs.dartmouth.edu/~mckeeman/cs48/index.html
|
553
|
5 |
http://www.cl.cam.ac.uk/teaching/1718/CompConstr/materials.html
|
555
|
6 |
|
|
7 |
|
|
8 |
http://spivey.oriel.ox.ac.uk/corner/Welcome_to_Spivey%27s_Corner
|
|
9 |
http://spivey.oriel.ox.ac.uk/corner/Compilers_(The_Farewell_Tour)
|
|
10 |
http://spivey.oriel.ox.ac.uk/wiki2/files/compilers/book.pdf
|
|
11 |
http://spivey.oriel.ox.ac.uk/corner/Programming_Languages
|
|
12 |
|
550
|
13 |
===============================
|
|
14 |
|
|
15 |
Pictures from the Starting Forth book
|
546
|
16 |
|
|
17 |
https://www.forth.com/starting-forth/2-stack-manipulation-operators-arithmetic/
|
|
18 |
|
|
19 |
--------------------------------
|
550
|
20 |
Java Byte Code for SCALA
|
|
21 |
https://www.toptal.com/scala/scala-bytecode-and-the-jvm
|
546
|
22 |
|
550
|
23 |
------------------
|
546
|
24 |
Yeti - ML for the JVM
|
|
25 |
https://mth.github.io/yeti/
|
|
26 |
http://dot.planet.ee/yeti/intro.html
|
|
27 |
|
550
|
28 |
------------------
|
|
29 |
Ocaml for LLVM
|
|
30 |
https://github.com/artagnon/rhine-ml
|
|
31 |
|
|
32 |
---------------
|
|
33 |
Type inference
|
|
34 |
http://www.calebh.io/Type-Inference-by-Solving-Constraints/
|
|
35 |
|
|
36 |
|
546
|
37 |
|
|
38 |
JVM languages
|
|
39 |
https://en.wikipedia.org/wiki/List_of_JVM_languages
|
|
40 |
https://www.codeproject.com/Articles/50377/Create-Your-Own-Programming-Language
|
|
41 |
|
|
42 |
|
|
43 |
Scheme
|
|
44 |
https://wespiser.com/writings/wyas/home.html
|
|
45 |
http://peter.michaux.ca/index#Scheme
|
|
46 |
|
|
47 |
|
|
48 |
|
476
|
49 |
assmebly (calculator RPN)
|
|
50 |
|
|
51 |
https://dere.github.io/2017-02-12/beginners-assembly-part1/
|
|
52 |
|
|
53 |
|
477
|
54 |
webassembly
|
|
55 |
https://sourceware.org/ml/binutils/2017-03/msg00044.html
|
|
56 |
https://hacks.mozilla.org/2017/02/a-cartoon-intro-to-webassembly/
|
495
|
57 |
https://webassembly.github.io/spec/
|
477
|
58 |
|
|
59 |
webassembly explorer
|
|
60 |
https://mbebenita.github.io/WasmExplorer/
|
|
61 |
|
495
|
62 |
ARM
|
|
63 |
https://azeria-labs.com/writing-arm-assembly-part-1/
|
477
|
64 |
|
495
|
65 |
JVM
|
|
66 |
https://www.toptal.com/scala/scala-bytecode-and-the-jvm
|
|
67 |
|
|
68 |
Growing a compiler
|
|
69 |
http://www.cs.dartmouth.edu/~mckeeman/cs48/mxcom/gem/html/GrowingCompiler.html
|
477
|
70 |
|
|
71 |
free books
|
|
72 |
https://github.com/vhf/free-programming-books/blob/master/free-programming-books.md
|
495
|
73 |
https://john.cs.olemiss.edu/~hcc/csci658/notes/Free_Prog_Lang_Textbooks.html
|
|
74 |
|
|
75 |
MIPS
|
|
76 |
http://courses.missouristate.edu/kenvollmar/mars/
|
|
77 |
|
|
78 |
PEG
|
|
79 |
|
|
80 |
https://github.com/taocpp/PEGTL
|
|
81 |
|
|
82 |
|
|
83 |
Parser
|
|
84 |
https://www.reddit.com/r/programming/comments/615hoz/how_to_write_a_recursive_descent_parser/
|
|
85 |
https://www.reddit.com/r/ProgrammingLanguages/comments/60gmgc/writing_a_recursive_descent_expression_parser/
|
|
86 |
http://www.craftinginterpreters.com/parsing-expressions.html
|
|
87 |
|
|
88 |
|
|
89 |
small languages
|
|
90 |
https://github.com/Michael2109/cobalt
|
|
91 |
http://www.red-lang.org/p/about.html
|
|
92 |
http://craftinginterpreters.com/contents.html
|
|
93 |
https://michaelhaywoodblog.wordpress.com
|
|
94 |
https://ruslanspivak.com/lsbasi-part1/
|
|
95 |
http://selfie.cs.uni-salzburg.at
|
550
|
96 |
https://academy.realm.io/posts/tryswift-samuel-giddins-building-tiny-compiler-swift-ios/
|
|
97 |
https://legacy.gitbook.com/book/luxlang/the-lux-programming-language/details
|
|
98 |
https://github.com/rhysd/gocaml
|
|
99 |
https://github.com/aalhour/awesome-compilers#educational-and-toy-projects
|
|
100 |
https://rsms.me/hue-intro
|
495
|
101 |
|
|
102 |
|
|
103 |
automata
|
|
104 |
https://www7.in.tum.de/um/courses/auto/ws1314/script/autonotes.pdf
|
|
105 |
|
|
106 |
Reges helpers
|
|
107 |
https://regex101.com
|
|
108 |
http://www.regular-expressions.info/tutorial.html
|
|
109 |
|
|
110 |
|
|
111 |
Regex performance benchmark
|
|
112 |
https://rust-leipzig.github.io/regex/2017/03/28/comparison-of-regex-engines/
|
|
113 |
https://github.com/k-takata/Onigmo
|
|
114 |
|
|
115 |
Sulzmann
|
|
116 |
https://github.com/pippijn/dreml/
|
|
117 |
|
|
118 |
|
|
119 |
Scala parser
|
|
120 |
http://enear.github.io/2016/03/31/parser-combinators/
|
|
121 |
|
|
122 |
|
|
123 |
ANTLR megatutorial
|
|
124 |
https://tomassetti.me/antlr-mega-tutorial/
|
|
125 |
|
|
126 |
From regex to LLVM
|
|
127 |
https://www.youtube.com/watch?v=Ukqb6nMjFyk
|
|
128 |
|
|
129 |
|
|
130 |
|
|
131 |
|
|
132 |
Static code analysis
|
550
|
133 |
https://medium.com/@Coder_HarryLee/videos-about-static-code-analysis-7654b40f9a3b
|
|
134 |
|
|
135 |
|
|
136 |
Brainfuck compiler
|
|
137 |
https://github.com/PurpleMyst/bf_compiler
|
|
138 |
https://www.reddit.com/r/programming/comments/8371tk/a_brainfuck_to_llvm_ir_compiler_written_in_python/
|
|
139 |
http://www.wilfred.me.uk/blog/2015/02/21/my-first-llvm-compiler/
|
|
140 |
|
|
141 |
===============================
|
|
142 |
A simple recursive regular expression matcher written in Scala.
|
|
143 |
https://github.com/marconilanna/RegexMatcher
|
|
144 |
|
|
145 |
===============================
|
|
146 |
A neat little tool to build presentations using the Scala REPL
|
|
147 |
https://github.com/marconilanna/REPLesent
|
|
148 |
|
|
149 |
|
|
150 |
======================
|
|
151 |
Minimal Static Single Assignment Form
|
|
152 |
Max Wagner and Denis Lohner
|
|
153 |
|
|
154 |
This formalization is an extension to "Verified Construction of Static Single
|
|
155 |
Assignment Form". In their work, the authors have shown that Braun et al.'s
|
|
156 |
static single assignment (SSA) construction algorithm produces minimal SSA form
|
|
157 |
for input programs with a reducible control flow graph (CFG). However Braun et
|
|
158 |
al. also proposed an extension to their algorithm that they claim produces
|
|
159 |
minimal SSA form even for irreducible CFGs.
|
|
160 |
In this formalization we support that claim by giving a mechanized proof.
|
|
161 |
|
|
162 |
As the extension of Braun et al.'s algorithm aims for removing so-called
|
|
163 |
redundant strongly connected components of phi functions, we show that this
|
|
164 |
suffices to guarantee minimality according to Cytron et al..
|
|
165 |
|
|
166 |
https://www.isa-afp.org/entries/Minimal_SSA.shtml
|
|
167 |
|
|
168 |
|
553
|
169 |
=========================
|
|
170 |
How Clang compiles a function
|
|
171 |
https://blog.regehr.org/archives/1605 |