koopa 0.0.3

Library for generating/parsing/optimizing Koopa IR.
Documentation
# Koopa

[<img alt="github" src="https://img.shields.io/badge/github-pku--minic/koopa-8da0cb?style=for-the-badge&labelColor=555555&logo=github" height="20">](https://github.com/pku-minic/koopa)
[<img alt="crates.io" src="https://img.shields.io/crates/v/koopa.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20">](https://crates.io/crates/koopa)
[<img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-koopa-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo=" height="20">](https://docs.rs/koopa)
[<img alt="build status" src="https://img.shields.io/github/workflow/status/pku-minic/koopa/Build%20and%20Test/master?style=for-the-badge" height="20">](https://github.com/pku-minic/koopa/actions?query=branch%3Amaster)

Library for generating/parsing/optimizing Koopa IR.

Koopa IR is the next generation of education-oriented intermediate representation designed for compiler courses at Peking University.

## Usage

```toml
[dependencies]
koopa = "0.0.3"
```

## Koopa IR

Here is a "Hello, world!" program in Koopa IR:

```koopa
// `putchar` function in libc.
decl @putchar(i32): i32

// A helper function for printing strings (integer arrays).
fun @putstr(@arr: *i32) {
%entry:
  jump %loop_entry(@arr)

%loop_entry(%ptr: *i32):
  %cur = load %ptr
  br %cur, %loop_body, %end

%loop_body:
  call @putchar(%cur)
  %next = getptr %ptr, 1
  jump %loop_entry(%next)

%end:
  ret
}

// String "Hello, world!\n\0".
global @str = alloc [i32, 15], {
  72, 101, 108, 108, 111, 44, 32, 119, 111, 114, 108, 100, 33, 10, 0
}

// `main` function, the entry point of the program.
fun @main(): i32 {
%entry:
  %str = getelemptr @str, 0
  call @putstr(%str)
  ret 0
}
```

Koopa IR is a strongly-typed, SSA form based intermediate representation. It's simple but powerful enough to support compilation of code into machine instructions, or some advanced optimizations of it.

For more details, see [the document of Koopa IR](https://github.com/pku-minic/next-gen-ir-proposal/blob/master/ir/llvm-like/README.md) (Chinese).

## Examples

See the [`examples` directory](examples), which contains three examples:

* [`opt`](examples/opt): a simple Koopa IR optimizer.
* [`brainfuck`](examples/brainfuck): a brainfuck to Koopa IR compiler.
* [`interpreter`](examples/interpreter): a simple Koopa IR interpreter.

## References

Koopa IR library is heavily influenced by [LLVM](https://llvm.org/) and [Cranelift](https://wasmtime.dev/).

## Changelog

See [CHANGELOG.md](CHANGELOG.md).

## License

Copyright (C) 2010-2021 MaxXing. License GPLv3.