A redesign of 'WordGrid' in Rust & WebAssembly, eventually featuring both single- & multi- player.
Find a file
2024-12-21 13:08:51 -08:00
resources Add dictionary 2023-07-24 19:50:40 -07:00
server feat: WIP multiplayer support 2024-12-21 13:08:51 -08:00
ui feat: WIP multiplayer support 2024-12-21 13:08:51 -08:00
wasm feat: WIP multiplayer support 2024-12-21 13:08:51 -08:00
wordgrid feat: WIP multiplayer support 2024-12-21 13:08:51 -08:00
.gitignore feat: Change API for multiplayer direction 2024-10-15 14:35:22 -07:00
Cargo.toml feat: WIP multiplayer support 2024-12-21 13:08:51 -08:00
LICENSE Add LICENSE and fields to Cargo.toml 2023-08-20 16:28:42 -07:00
Makefile Adjust Makefile so 'make' builds all 2023-10-13 21:16:16 -07:00
README.md Add link to playable version 2024-02-11 12:11:50 -08:00

README

This repository contains the code for 'WordGrid', a (currently) single-player browser game where you use letter tiles to form words.

Game logic resides in src/ as Rust code, which gets compiled into WebAssembly.

UI logic resides in ui/src/, which gets bundled by Parcel into the web application.

If you want to try it now, I host a version at https://joeltherrien.ca/wordgrid

Setup

  1. Clone this repository.
  2. If not already installed, install the Rust wasm32-unknown-unknown target with rustup target add wasm32-unknown-unknown.
  3. In the base project directory, run make build-all to build both the Rust wasm project (gets stored in pkg/) and the final bundled web files (gets stored in ui/dist/).
  4. Place the files in ui/dist/ onto a web server and access them.

During development, you'll often want to serve the UI component in serve mode that auto-updates when you make a change. In the ui/ directory you can run npm run start. Note that Parcel doesn't always detect changes to the compiled Rust code, so if you recompile the Rust code with changes you should delete ui/.parcel-cache/ and ui/dist/ or else the UI may continue to use older WASM.

Future Plans

I intend on building a multiplayer component to this game, where the Rust code will form a webserver for connecting players and the UI will make server calls instead of calling web assembly.