New ARTIQ compiler, third iteration
Go to file
2021-11-24 18:18:47 +08:00
nac3artiq Merge remote-tracking branch 'origin/master' into symbol_resolver_typevar 2021-11-24 18:18:47 +08:00
nac3ast fix clippy warnings 2021-11-06 23:00:18 +08:00
nac3core Merge remote-tracking branch 'origin/master' into symbol_resolver_typevar 2021-11-24 18:18:47 +08:00
nac3parser typo 2021-11-06 14:14:40 +08:00
nac3standalone Constant Default Parameter Support (#98) 2021-11-23 07:32:09 +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: switch to nixpkgs 21.11 release 2021-11-23 11:22:08 +08:00
flake.nix flake: switch to nixpkgs 21.11 release 2021-11-23 11:22:08 +08:00
llvm-future-riscv-abi.diff llvm: switch RISC-V ABI when FPU is present 2021-11-11 23:42:32 +08:00
llvm-restrict-targets.diff typo 2021-11-11 23:44:14 +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)