We will cover:
-
Lexing and parsing; LALR parser generators.
-
Abstract syntax trees; operations on trees; compiler as
sequence of phases operating on abstract syntax trees.
-
Static Analysis; data flow and control flow analyses; type checking.
-
Code generation; java bytecode.
As homeworks, we will be doing some of the labs from the text.
These use java, eclipse and some other tools:
-
ant (comes with eclipse)
-
flex (a scanner generator, similar to lex)
-
cup (an LALR parser generator, similar to yacc)
-
jasmin (an assembler for java virtual machine language)
If you prefer not to use eclipse, you can install apache ant and run ant directly from the command line.
data:image/s3,"s3://crabby-images/81d7a/81d7ad88cdca4e91d222810ec15a56553e3ad411" alt="Previous page"
data:image/s3,"s3://crabby-images/dca5f/dca5f68c0838adb3c3d675abf6853f95ceacd588" alt="Contents"
data:image/s3,"s3://crabby-images/c3a0f/c3a0f52c42c118c819b6dbf19e2a441b34e82af5" alt="Next page"