Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/creack/rtv1
Basic raytracer in Go
https://github.com/creack/rtv1
Last synced: about 1 month ago
JSON representation
Basic raytracer in Go
- Host: GitHub
- URL: https://github.com/creack/rtv1
- Owner: creack
- License: mit
- Created: 2023-12-15T21:21:01.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2023-12-24T16:18:30.000Z (about 1 year ago)
- Last Synced: 2024-05-08T17:42:51.004Z (8 months ago)
- Language: Go
- Size: 2.44 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# RTv1 - Simple Raytracer
## Live Demo
[https://creack.github.io/rtv1](https://creack.github.io/rtv1)
## Window mode
```sh
go run go.creack.net/rtv1@latest
```## WASM
### One liner
```sh
env -i HOME=${HOME} PATH=${PATH} go run github.com/hajimehoshi/wasmserve@latest go.creack.net/rtv1@latest
```### Details
Install `wasmer`:
```sh
go install github.com/hajimehoshi/wasmserve@latest
```Clone this repo:
```sh
git clone https://github.com/creack/rtv1
cd rtv1
```Run:
```sh
env -i HOME=${HOME} PATH=${PATH} wasmserve .
```For development, `wasmer` exposes an endpoint to do live reload.
I recommend [reflex](https://github.com/cespare/reflex).
Install:
```sh
go install github.com/cespare/reflex@latest
```Then, with `wasmer` running:
```sh
reflex curl -v http://localhost:8080/_notify
```## Controls
TBD
## Docker
A Dockerfile is provided to build and run the WASM version.
### Build
```sh
docker build -t rtv1 .
```### Regular run
To run the image, make sure to have:
- `--rm` to avoid pollution
- `-it` so the app receives signals
- `-p` to expose the port 8080Any changes to the code will require to re-build the image.
```sh
docker run --rm -p 8080:8080 -it rtv1 wasmserve .
```You can then access the WASM page at the Docker ip on port 8080. If in doubt about the IP, it is likely localhost.
### Development run
For development, you can add `-v $(pwd):/app` to mount the local directory in the Docker container, the server will hot-reload when file changes.
```sh
docker run --rm -p 8080:8080 -it -v $(pwd):/app rtv1
```