New ARTIQ compiler, third iteration
Go to file
2021-12-13 10:44:33 +08:00
llvm remove a small amount of LLVM bloat 2021-12-08 17:41:34 +08:00
nac3artiq remove a small amount of LLVM bloat 2021-12-08 17:41:34 +08:00
nac3ast fix clippy warnings 2021-11-06 23:00:18 +08:00
nac3core nac3core: use official implementation for len 2021-12-13 10:44:33 +08:00
nac3parser nac3parser: modify parser to handle negative integer edge cases 2021-12-03 16:35:58 +08:00
nac3standalone nac3standalone: add output_long 2021-12-13 10:44:33 +08:00
runkernel runkernel: improve print_int debug functions 2021-11-19 12:39:57 +08:00
.gitignore nac3embedded: basic source extraction 2020-12-18 23:45:09 +08:00
Cargo.lock nac3artiq: embed linker script, put intermediate objects in temp dir 2021-11-06 13:04:00 +08:00
Cargo.toml integrate nac3parser 2021-11-03 17:11:00 +08:00
flake.lock flake: update nixpkgs and work around openssh cross compilation breakage. Closes #123 2021-12-08 21:21:37 +08:00
flake.nix flake: update nixpkgs and work around openssh cross compilation breakage. Closes #123 2021-12-08 21:21:37 +08:00
README.md README: update 2021-11-03 17:22:14 +08:00

NAC3 compiler

This repository contains:

  • nac3ast: Python abstract syntax tree definition (based on RustPython).
  • nac3parser: Python parser (based on RustPython).
  • nac3core: Core compiler library, containing type-checking and code generation.
  • nac3standalone: Standalone compiler tool (core language only).
  • nac3artiq: Integration with ARTIQ and implementation of ARTIQ-specific extensions to the core language.
  • runkernel: Simple program that runs compiled ARTIQ kernels on the host and displays RTIO operations. Useful for testing without hardware.

The core compiler knows nothing about symbol resolution, host variables etc. nac3artiq and nac3standalone provide (implement) the symbol resolver to the core compiler for resolving the type and value for unknown symbols. The core compiler only type checks classes and functions requested by nac3artiq/nac3standalone (the API should allow the caller to specify which methods should be compiled). After type checking, the compiler analyses the set of functions/classes that are used and performs code generation.

value could be integer values, boolean values, bytes (for memcpy), function ID (full name + concrete type)