l1_ir 0.0.13

L1 Intermediate Representation
Documentation
l1_ir-0.0.13 has been yanked.

L1IR

Crates.IO Build Documentation

Intermediate Representation of LSTS L1 Language

Types

  • Literal Strings
  • Tuples
  • Functions

Global AST Nodes

  • Function Definitions
  • Program Expressions

Expression AST Nodes

  • Literal Introduction
  • Tuple Introduction
  • Variable Reference
  • Function Reference
  • Function Application
  • Pattern Match
  • Program Failure, Immediate Exit with possible Message

L1IR's unique contribution is that it does not presume to know everything about literal strings. Types, by definition, are represented as an amalgam of Unicode Characters instead of fixed length bitstrings. This is advantageous to languages like L1 that define their own operators from scratch, but still desire to have an efficient runtime.

Things not in the AST directly

  • If Expression (use a pattern)
  • Struct Types (use a tuple)
  • Tagged Enum Types (use tagged tuples)
  • Field/Index Access (use a pattern)
  • Polymorphic Functions (monomorphic definitions only)
  • Stateful Closures (use a tuple with custom calling convention)
  • Let Bindings (use a pattern, bound variables stick around until end of scope)
  • Jumps or Loops (this is an IR for Functional Programming)
  • Integers (use unary encoding "000"==3)