Files
OpenFrontIO/.claude/skills/run-openfront/setup.sh
T
Evan 3de5fb4204 Move map metadata into info.json and generate map TypeScript from it (#4227)
**Add approved & assigned issue number here:**

N/A — maintainer refactor.

## Description:

Makes each map's `info.json` the single source of truth for map metadata
— adding a map is now a folder with `image.png` + `info.json`, a
`gen-maps` run, and an en.json display name.

**info.json / manifest.json carry full map metadata.** Every
`map-generator/assets/maps/<map>/info.json` declares `id` (the
`GameMapType` enum key), `name` (the enum value — wire format, unchanged
for all 94 maps), `translation_key`, `categories`, and
`multiplayer_frequency` (the public-playlist weight that used to be the
`FREQUENCY` record in MapPlaylist.ts). The generator validates
everything and mirrors it into `resources/maps/<map>/manifest.json`. 23
stale info.json `name` values were normalized to the canonical enum
value; enum values are byte-identical, so replays and stored game
configs are unaffected.

**The generator emits the TypeScript and discovers maps itself.** New
`map-generator/codegen.go` generates `src/core/game/Maps.gen.ts`
(`GameMapType`, `GameMapName`, `mapCategories`, `mapTranslationKeys`,
`multiplayerFrequency` — now a full `Record<GameMapName, number>`,
killing the old `Partial`) on every run; `Game.ts` re-exports it. The
hardcoded map registry in `main.go` is gone — maps are auto-discovered
from the `assets/maps` / `assets/test_maps` directories. MapConsistency
tests fail with a "run `npm run gen-maps`" message if info.json,
manifest.json, and Maps.gen.ts drift. The tracked
`map-generator/map-generator` binary is rebuilt to match.

**New categories: continents + world/cosmic/tournament/other,
multi-category support.** `continental`/`regional`/`fantasy`/`arcade`
are replaced by `featured`, `world`, `europe`, `asia`, `north_america`,
`africa`, `south_america`, `oceania`, `antarctica`, `cosmic`,
`tournament`, and `other`. Maps can list multiple categories, so
straddlers (Black Sea, Bosphorus, Caucasus, Between Two Seas, Bering
Sea/Strait, Mena, Strait of Gibraltar, Hawaii, Arctic) appear under both
regions. Featured is itself a category (same 7 maps as before).
MapPlaylist keeps its arcade exclusion via an explicit set.

**Map picker UI.** Two tabs: **Featured** (default — featured maps plus
a Favorites section when maps are starred) and **All** (one prominent
collapsible bar per category with a map count, collapsed by default).
The selected map is prepended to the featured grid when it lives
elsewhere. `getMapName()` resolves through the generated
`mapTranslationKeys`, which also fixes tourney maps never resolving a
valid translation key.

## Please complete the following:

- [ ] I have added screenshots for all UI updates (maintainer change —
picker described above)
- [x] I process any text displayed to the user through translateText()
and I've added it to the en.json file
- [x] I have added relevant tests to the test directory

## Please put your Discord username so you can be contacted if a bug or
regression is found:

evanpelle

🤖 Generated with [Claude Code](https://claude.com/claude-code)

---------

Co-authored-by: Claude Fable 5 <noreply@anthropic.com>
2026-06-11 19:36:53 -07:00

44 lines
1.8 KiB
Bash
Executable File

#!/usr/bin/env bash
# One-time per-machine setup for headless-Chromium driving of OpenFront.
# No sudo needed: Playwright's chromium is downloaded with a platform
# override, and its missing system libraries are extracted locally from
# .deb packages.
set -euo pipefail
CACHE="${OPENFRONT_RUN_CACHE:-$HOME/.cache/openfront-run}"
mkdir -p "$CACHE/debs" "$CACHE/fonts" "$CACHE/fc-cache"
# 1. Playwright (not a project dependency; --no-save keeps package.json clean)
npm ls playwright > /dev/null 2>&1 || npm install --no-save playwright
# 2. Chromium headless shell. Playwright refuses to download on Ubuntu 26.04
# ("does not support chromium on ubuntu26.04-x64"); the ubuntu24.04 build
# is ABI-compatible, so override the host platform.
PLAYWRIGHT_HOST_PLATFORM_OVERRIDE=ubuntu24.04-x64 npx playwright install chromium
# 3. Shared libraries the headless shell needs that a minimal host lacks
# (found via: ldd chrome-headless-shell | grep "not found").
(
cd "$CACHE/debs"
apt-get download \
libnspr4 libnss3 libasound2t64 libatk1.0-0t64 libatk-bridge2.0-0t64 \
libatspi2.0-0t64 libgbm1 libx11-6 libxcb1 libxcomposite1 libxdamage1 \
libxext6 libxfixes3 libxrandr2 libxau6 libxdmcp6 libxi6 libxrender1 \
libxres1 fonts-dejavu-core
for f in *.deb; do dpkg -x "$f" "$CACHE/extracted"; done
)
# 4. Fonts. This host has no /etc/fonts at all, and Skia FATALs without a
# fontconfig (SkFontMgr_FontConfigInterface.cpp "Not implemented").
cp "$CACHE/extracted/usr/share/fonts/truetype/dejavu/"*.ttf "$CACHE/fonts/"
cat > "$CACHE/fonts.conf" << CONF
<?xml version="1.0"?>
<!DOCTYPE fontconfig SYSTEM "fonts.dtd">
<fontconfig>
<dir>$CACHE/fonts</dir>
<cachedir>$CACHE/fc-cache</cachedir>
</fontconfig>
CONF
echo "setup complete: $CACHE"