Introduction to Programming Languages
Table of contents
Introduction to Programming Languages
Syntax
Grammars in Practice
- Logic Grammars
- Syntax Directed Interpretation
- Syntax Directed Translation
- Syntax Directed Type Checking
- A recipy for writing a reusable grammar
Execution Environments
Functional Programming in Haskell
Pattern Matching
Types
Typing Disciplines
- Dynamically vs Statically Typed Languages
- Nominal vs Structural Typing Equivalence
- Safe vs Unsafe Typing
- Type Inference vs Type Annotations
Polymorphism
- What is Polymorphism
- Ad-Hoc Polymorphism
- Universal Polymorphism
- Overloading
- Coercion
- Parametric Polymorphism
- Subtype Polymorphism
The Lambda Calculus
High-Order Functions
- Definition and Examples
- Closures
- Partial Application
- Noticeable High-Order Functions
- Template Oriented Programming