-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathREADME.md.liquid
48 lines (35 loc) · 1.82 KB
/
README.md.liquid
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# {{project-name}}
An auto splitter for {{ process_name | remove: ".exe" | replace: "-", " " | replace: "_", " " | capitalize }}.
## Compilation
This auto splitter is written in Rust. In order to compile it, you need to
install the Rust compiler: [Install Rust](https://www.rust-lang.org/tools/install).
Afterwards install the WebAssembly target:
```sh
rustup target add {% if use_wasi %}wasm32-wasip1{% else %}wasm32-unknown-unknown{% endif %} --toolchain {{toolchain}}
```
The auto splitter can now be compiled:
```sh
cargo b --release
```
The auto splitter is then available at:
```
target/{% if use_wasi %}wasm32-wasip1{% else %}wasm32-unknown-unknown{% endif %}/release/{{project-name | replace: "-", "_" }}.wasm
```
Make sure to look into the [API documentation](https://livesplit.org/asr/asr/) for the `asr` crate.
## Development
You can use the [debugger](https://github.com/LiveSplit/asr-debugger) while
developing the auto splitter to more easily see the log messages, statistics,
dump memory, step through the code and more.
The repository comes with preconfigured Visual Studio Code tasks. During
development it is recommended to use the `Debug Auto Splitter` launch action to
run the `asr-debugger`. You need to install the `CodeLLDB` extension to run it.
You can then use the `Build Auto Splitter (Debug)` task to manually build the
auto splitter. This will automatically hot reload the auto splitter in the
`asr-debugger`.
Alternatively you can install the [`cargo
watch`](https://github.com/watchexec/cargo-watch?tab=readme-ov-file#install)
subcommand and run the `Watch Auto Splitter` task for it to automatically build
when you save your changes.
The debugger is able to step through the code. You can set breakpoints in VSCode
and it should stop there when the breakpoint is hit. Inspecting variables may
not work all the time.