erg/doc/JA/dev_guide/embedding.md
2023-11-06 23:43:27 +09:00

106 lines
3.4 KiB
Markdown

# Ergコンパイラのアプリケーションへの組み込み
[![badge](https://img.shields.io/endpoint.svg?url=https%3A%2F%2Fgezf7g7pd5.execute-api.ap-northeast-1.amazonaws.com%2Fdefault%2Fsource_up_to_date%3Fowner%3Derg-lang%26repos%3Derg%26ref%3Dmain%26path%3Ddoc/EN/dev_guide/embedding.md%26commit_hash%3D94185d534afe909d112381b53d60895389d02f95)](https://gezf7g7pd5.execute-api.ap-northeast-1.amazonaws.com/default/source_up_to_date?owner=erg-lang&repos=erg&ref=main&path=doc/EN/dev_guide/embedding.md&commit_hash=94185d534afe909d112381b53d60895389d02f95)
貴方のアプリケーションへErgを組み込むことは簡単です。
```toml
[dependencies]
erg = "0.5.12" # choose latest version
```
```rust
use erg::DummyVM;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut vm = DummyVM::default();
let _res: String = vm.eval("print! \"Hello, world!\"")?;
Ok(())
}
```
実行にはPythonが必要です。
ランタイムと接続されないコンパイラ単体のバージョンもあります。
```toml
[dependencies]
erg_compiler = "0.5.12" # choose latest version
```
```rust
use erg_compiler::Compiler;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut compiler = Compiler::default();
let code = compiler.compile("print! \"Hello, world!\"", "exec")?;
code.dump_as_pyc("o.pyc", None)?;
Ok(())
}
```
`Compiler``CodeObj`という構造体を出力します。これは一般的にはあまり役に立たないので、Pythonのスクリプトを出力する`Transpiler`を使うのも良いでしょう。
```rust
use erg_compiler::Transpiler;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut transpiler = Transpiler::default();
let script = transpiler.transpile("print! \"Hello, world!\"", "exec")?;
println!("{}", script.code);
Ok(())
}
```
その他にも、HIR(高レベル中間表現)を出力する`HIRBuilder`や、AST(抽象構文木)を出力する`ASTBuilder`もあります。
```rust
use erg_compiler::HIRBuilder;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut builder = HIRBuilder::default();
let artifact = builder.build("print! \"Hello, world!\"", "exec")?;
println!("HIR: {}", artifact.object);
Ok(())
}
```
モジュールの依存解決も行いたい場合は`PackageBuilder`を使います。
```rust
use erg_compiler::PackageBuilder;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut builder = PackageBuilder::default();
let artifact = builder.build("print! \"Hello, world!\"", "exec")?;
println!("HIR: {}", artifact.object);
Ok(())
}
```
```rust
use erg_compiler::ASTBuilder;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut builder = ASTBuilder::default();
let ast = builder.build("print! \"Hello, world!\"")?;
println!("{}", ast);
Ok(())
}
```
構文解析以降の意味解析を行う構造体は、`ContextProvider`というトレイトを実装しています。モジュール内の変数情報を得ることなどができます。
```rust
use erg_compiler::Transpiler;
use erg_compiler::context::ContextProvider;
fn main() -> Result<(), Box<dyn std::error::Error>> {
let mut transpiler = Transpiler::default();
let script = transpiler.transpile("i = 0", "exec")?;
println!("{}", script.code);
let typ = transpiler.get_var_info("i").0.t;
println!("{typ}");
Ok(())
}
```