generated from GarandPLG/rust-flake-template
Add detailed War in Tunnels README
This commit is contained in:
@@ -1,3 +1,96 @@
|
|||||||
# rust-flake-template
|
# War in Tunnels
|
||||||
|
|
||||||
Basic flake for rust development and production.
|
**War in Tunnels** – to terminalowa gra typu RTS (real‑time strategy) rozgrywająca się pod ziemią. Gra wykorzystuje bibliotekę **ratatui** do budowy interfejsu tekstowego oraz **rodio** do odtwarzania ścieżek dźwiękowych. Projekt jest skonfigurowany jako **Nix Flake**, co ułatwia zarządzanie zależnościami, budowanie wersji produkcyjnej oraz deweloperskiej.
|
||||||
|
|
||||||
|
## Funkcjonalności
|
||||||
|
|
||||||
|
- Tekstowy interfejs użytkownika z podziałem na menu, podgląd mapy i panel boczny.
|
||||||
|
- Różne tryby gry (np. Last‑Man‑Standing).
|
||||||
|
- Skalowanie mapy i poziom przybliżenia UI.
|
||||||
|
- Wsparcie dla kilku zestawów perków.
|
||||||
|
- Konfigurowalne zasoby startowe (drewno, żelazo) oraz limit jednostek.
|
||||||
|
- System punktów doświadczenia i limitu punktów umiejętności.
|
||||||
|
- Odtwarzanie ścieżek dźwiękowych (możliwość wyciszenia lub wyłączenia).
|
||||||
|
|
||||||
|
## Wymagania
|
||||||
|
|
||||||
|
- **Nix** (z obsługą Flake) – do budowania i uruchamiania projektu.
|
||||||
|
- **Rust** 2024 edition – używany wewnątrz środowiska Nix (fenix toolchain).
|
||||||
|
- Biblioteki systemowe: `alsa-lib` (dla obsługi dźwięku).
|
||||||
|
|
||||||
|
## Budowanie i uruchamianie
|
||||||
|
|
||||||
|
Projekt udostępnia dwa profile Flake:
|
||||||
|
|
||||||
|
- **default** – wersja produkcyjna (z optymalizacjami).
|
||||||
|
- **develop** – wersja deweloperska z dodatkowymi zależnościami i nie‑zoptymalizowanym kodem.
|
||||||
|
|
||||||
|
### Przykładowe polecenia
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Budowanie wersji produkcyjnej
|
||||||
|
nix build
|
||||||
|
|
||||||
|
# Uruchomienie wersji produkcyjnej
|
||||||
|
nix run
|
||||||
|
|
||||||
|
# Budowanie wersji deweloperskiej
|
||||||
|
nix build .#develop
|
||||||
|
|
||||||
|
# Uruchomienie wersji deweloperskiej
|
||||||
|
nix run .#develop
|
||||||
|
```
|
||||||
|
|
||||||
|
W środowisku deweloperskim dostępny jest także **shell** z pre‑konfigurowanymi zmiennymi:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
nix develop
|
||||||
|
```
|
||||||
|
|
||||||
|
Po wejściu do powłoki pojawi się informacja o wersji oraz dostępne komendy.
|
||||||
|
|
||||||
|
## Opcje wiersza poleceń (CLI)
|
||||||
|
|
||||||
|
Gra korzysta z biblioteki **clap** – wszystkie opcje są dostępne jako flagi. Poniżej najważniejsze:
|
||||||
|
|
||||||
|
| Skrót | Flaga | Domyślna wartość | Opis |
|
||||||
|
|-------|-------|------------------|------|
|
||||||
|
| `-v` | `--view` | `MainMenu` | Określa początkowy widok UI. |
|
||||||
|
| `-u` | `--username` | `Player` | Nazwa gracza wyświetlana w interfejsie. |
|
||||||
|
| `-g` | `--game-mode` | `LastManStanding` | Tryb rozgrywki. |
|
||||||
|
| `-W` | `--map-width` | `42` | Szerokość generowanej mapy (36‑108). |
|
||||||
|
| `-H` | `--map-height` | `11` | Wysokość mapy (11‑39). |
|
||||||
|
| `-z` | `--zoom-level` | `Default` | Poziom przybliżenia UI. |
|
||||||
|
| `-p` | `--perk-deck` | `Silesian` | Zestaw perków. |
|
||||||
|
| `-w` | `--starting-wood` | `50` | Początkowa ilość drewna (1‑150). |
|
||||||
|
| `-i` | `--starting-iron` | `25` | Początkowa ilość żelaza (1‑150). |
|
||||||
|
| `-L` | `--supply-limit` | `99` | Limit jednostek na mapie (49‑149). |
|
||||||
|
| `-x` | `--xp-modifier` | `1.0` | Mnożnik doświadczenia (0.5‑2.0). |
|
||||||
|
| `-P` | `--skill-points-limit` | `120` | Górny limit punktów umiejętności (90‑690). |
|
||||||
|
| `-S` | `--soundtrack` | `Default` | Wybór ścieżki dźwiękowej. |
|
||||||
|
| `-D` | `--disable-audio` | `false` | Wyłącza odtwarzanie dźwięku. |
|
||||||
|
| `-m` | `--mute` | `false` | Wycisza odtwarzany dźwięk. |
|
||||||
|
| `-l` | `--log` | `false` | Włącza logowanie do pliku. |
|
||||||
|
|
||||||
|
Aby wyświetlić pomoc, uruchom:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cargo run -- -h
|
||||||
|
```
|
||||||
|
|
||||||
|
## Struktura projektu
|
||||||
|
|
||||||
|
- `src/main.rs` – punkt wejścia, inicjalizuje terminal, wątki i główną pętlę aplikacji.
|
||||||
|
- `src/lib.rs` – eksportuje moduły aplikacji i CLI.
|
||||||
|
- `src/app/` – logika gry, stany, widoki i obsługa klawiszy.
|
||||||
|
- `src/cli.rs` – definicja opcji CLI.
|
||||||
|
- `Cargo.toml` – zależności Rust (ratatui, clap, log, simplelog, rodio, once_cell).
|
||||||
|
- `flake.nix` – opis flake, zależności Nix, profile build i develop.
|
||||||
|
|
||||||
|
## Dźwięk
|
||||||
|
|
||||||
|
Ścieżki dźwiękowe znajdują się w folderze `soundtracks`. Biblioteka **rodio** odtwarza je w oddzielnym wątku. Dostępne flagi pozwalają wybrać konkretną ścieżkę, wyciszyć lub całkowicie wyłączyć dźwięk.
|
||||||
|
|
||||||
|
## Logowanie
|
||||||
|
|
||||||
|
Gdy flaga `--log` jest włączona, aplikacja zapisuje logi do pliku przy użyciu **simplelog**. Domyślnie logowanie jest wyłączone.
|
||||||
|
|||||||
Reference in New Issue
Block a user