Commit Graph

196 Commits

Author SHA1 Message Date
root b9edbee77d feat: instrument llmService to record calls via llmStatsService
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 13:22:11 +00:00
root 478ca06818 feat: add llmStatsService with SQLite persistence and aggregation
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 13:20:26 +00:00
root a6c92e7f99 feat: include retry count in openRouterClient CompletionSuccess
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 13:17:45 +00:00
root f3186f6020 feat: add model pricing config and cost calculation
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 13:15:57 +00:00
root 6712942436 fix: address code review — auth gating, subscription cleanup, debounce, npcBrainSystem
- Wire npcBrainSystem to RuntimeConstants (was using hardcoded shared imports)
- Add auth gating on admin-update-constant and admin-reset-defaults sockets
- Unsubscribe from previous tab's data sources on left-panel tab switch
- Use per-key debounce timers in AdminPanel to avoid dropped changes

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 02:42:51 +00:00
root e5715ec467 feat: wire all gameplay systems to RuntimeConstants
Replace direct constant imports with rc.get() calls in needsDecaySystem,
socialSystem, statModifierSystem, movementSystem, gatheringSystem,
craftingSystem, buildingSystem, and SocketServer. All system functions
now accept a RuntimeConstants parameter, enabling live-tuning of game
constants via the admin panel.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 02:35:39 +00:00
root e2670b0c34 feat: add admin auth and log streaming socket handlers
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 02:23:46 +00:00
root ff53096d94 feat: wire LogService into LLM layer for error/warning logging
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 02:22:20 +00:00
root 191770acbe feat: wire LogService into network layer
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 02:21:08 +00:00
root 0d8573e11f feat: wire LogService + RuntimeConstants into GameLoop
Replace direct constant imports (TICK_RATE, BROADCAST_EVERY_N_TICKS,
ENERGY_DECAY_PER_TICK, DAY_NIGHT_RATIO) with RuntimeConstants lookups.
Add LogService for autosave logging and tick overrun detection.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 02:19:55 +00:00
root 0d93574e76 feat: add RuntimeConstants service with get/update/reset
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 02:17:50 +00:00
root f8cb83481e feat: add LogService with ring buffer and subscriber push
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 02:17:48 +00:00
root 377b24d225 fix: clean up raw JSON backstories on load from save
Backstories stored as raw JSON (containing desires) are now parsed
on deserialization to extract just the backstory text.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 01:43:47 +00:00
root 034f799431 feat: multi-tile trees with treesnstone tileset and trunk bridging
Replace single-tile tree rendering with 6 multi-tile tree variants using
the treesnstone.png tileset. Each tree is 3 tiles wide with canopy tiles
on the decorations layer (above characters) and ground/shadow tiles on
the trunkDecorations layer (below characters). Add trunk bridge tiles
(tile 41) behind transparent canopy areas to connect canopy to ground
visually, fixing floating canopy appearance.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 01:22:47 +00:00
root a8f27a869d fix: emit desire_fulfilled events, populate LLM context, fix category scoring
- desireFulfillmentSystem records memory events when desires are fulfilled
- desireGeneratorSystem populates recentEvents and recentInventions template vars
- industrySystem own_item_category scoring now checks recipe output category

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 00:14:35 +00:00
root f3591e68d7 feat: industrySystem scores recipes by desire match
Adds scoreCraftableRecipes helper that scores recipes based on NPC
desires (priority * 10 for own_item match). Falls back to first
available when no desires match.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 00:07:09 +00:00
root c548d0ac05 test: add desire lifecycle integration test
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 00:04:30 +00:00
root 7ef9636307 feat: wire desire systems into GameLoop and spawner
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 00:02:40 +00:00
root 733cdfb20f feat: send desires to client via state serializer
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-10 00:00:20 +00:00
root a63ff776de feat: persist desires component in entity serializer
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 23:59:47 +00:00
root cf5558ce0f feat: pass NPC desires into invention prompts
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 23:59:29 +00:00
root 808ffc06c6 feat: add desire generator system for periodic and event-driven desire creation
Factory-function system that generates new desires via LLM based on
periodic stat-based probability checks and external event triggers.
Tracks pending entities to prevent duplicate in-flight requests.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 23:55:29 +00:00
root 5835206171 feat: add combined backstory + desires LLM generator
Add backstoryAndDesires and desireGeneration templates. Rewrite
backstoryGenerator with getWorldContext, validateDesire, and
generateBackstoryAndDesires helpers while keeping legacy generateBackstory
for backward compatibility. Add comprehensive tests (22 cases).

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 23:50:51 +00:00
root 979a318651 refactor: reframe LLM templates from medieval to frontier settlement
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 23:47:21 +00:00
root f94a6363aa feat: add desire fulfillment system with criteria checks
Checks NPC desires against world state every 100 ticks and removes
fulfilled ones. Supports own_item, own_item_category, structure_exists,
relationship_tier, recipe_exists criteria. building_exists and custom
always return false (deferred).

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 23:44:46 +00:00
root d3706c90b8 feat: add desireConfig with tuning values
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 23:42:04 +00:00
root ee7f22c2c3 feat: ensure default stockpiles on load, use full stat names in backstory prompts
- Add ensureDefaultStockpiles() to handle saves from before stockpile spawning
- Switch backstory prompt stat formatting from abbreviations (STR, DEX) to
  full names (strength, dexterity) for better LLM comprehension
- Add prior design/plan docs for LLM fallback and NPC sleep system

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 22:05:14 +00:00
root 1da03c46f3 refactor: extract findNearestStockpile helper in npcBrainSystem
Deduplicates stockpile-finding logic that was repeated in the dropoff
preservation block and the target selection block.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 21:55:26 +00:00
root a84b93bfd3 feat: gatheringSystem uses carry capacity for dropoff decision
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 21:52:15 +00:00
root 18b011fbf5 fix: preserve dropoff goal in npcBrainSystem and add carry capacity priority
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 21:50:48 +00:00
root a9c1cd55d6 feat: add getCarryCapacity stat helper
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 21:49:29 +00:00
root 1bfb9c581c feat: add getTotalItemCount inventory helper
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 21:48:46 +00:00
root 219f02d7d6 test: add integration test for stat-driven invention prompt
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 20:37:25 +00:00
root 36fdf1b3c1 fix: prevent race condition with global pendingItemIds set
Two NPCs could invent the same item if both LLM requests
returned before either registered. The pendingItemIds set
blocks the second registration.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 20:36:02 +00:00
root 0851cea047 feat: track token usage from OpenRouter API responses
Captures prompt_tokens and completion_tokens from API response.
Stores in 100-entry ring buffer, logs per-call summary. Adds
tokenUsage() accessor to LlmService interface.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 20:33:16 +00:00
root 6a3f9dd614 feat: stat-driven invention selection via revised LLM prompt
Prompt now includes full 10-stat block with readable names and
scale context. Instructs LLM to consider 3 ideas and pick the
best match for the NPC's personality. Known items list includes
both seed and invented items for better duplicate prevention.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 20:29:04 +00:00
root b8b2a870fa feat: parse reasoning field from invention LLM response
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 20:26:56 +00:00
root 28cd79a5c7 fix: re-register inventions into registries on save load
Inventions loaded from DB were only added to the timeline, not
the item/recipe registries. This allowed duplicate inventions
after server restarts since the validation check was empty.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 20:21:32 +00:00
root 34aca29082 fix: sleep emoji, invention history race condition, and gathering stuck state
- Add persistent 💤 emoji over sleeping NPCs (tracks sprite position)
- Buffer history events (inventions, narration, stockpile) in SocketClient
  to fix race condition where data arrived before GameScene handlers registered
- Fix NPCs getting stuck on 'gather' goal: tree trunks are both obstacles
  and resource tiles, so pathfinding always failed. Now findNearestResource
  returns adjacent walkable tiles for non-walkable resources, and
  gatheringSystem checks adjacent tiles. Added wander fallback when
  pathfinding to any gather target fails.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 18:57:50 +00:00
root 3294879bab fix: address code review findings for sleep system
- Fix NpcInfoPanel activity label: rest→sleep (functional bug)
- Remove unnecessary array spread in mapGenerator reserved set
- Remove unused SLEEP_NIGHT_END constant

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 18:02:04 +00:00
root b67d491b9d feat: update thought system to recognize sleeping NPCs
Skip sleeping NPCs in the thought generation loop and update
describeState to output 'sleeping' when currentGoal is 'sleep'.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 17:59:03 +00:00
root 65ee23c5be refactor: remove rest POIs from map generation, persistence, and client rendering
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 17:58:02 +00:00
root b76ce16cba feat(server): protect sleeping NPCs from social interactions (empathy < 7 exception)
Sleeping NPCs are now shielded from social interaction initiation unless
the approaching NPC has low empathy (< 7, i.e. rude). Sleeping NPCs also
cannot initiate social interactions themselves.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 17:55:13 +00:00
root 812e30a222 feat(server): implement sleep-in-place behavior in npcBrainSystem with day/night awareness
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 17:52:46 +00:00
root b9fcd49794 feat(server): add sleep-aware energy recovery and hunger slowdown to needsDecaySystem
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 17:49:26 +00:00
root fa4f0ce44d feat(shared): add sleep system constants and replace rest with sleep goal type
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 17:47:53 +00:00
root e32f121fc9 fix(server): guard against missing relationship components
Add null checks for relationship components before processing
social outcomes to prevent crashes when entities lack relationships.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 17:19:09 +00:00
root 700dddc845 chore(llm): wire llmService destroy into GameLoop shutdown
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 16:05:28 +00:00
root f685625dec feat(llm): add periodic usage logging and destroy cleanup
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 16:04:41 +00:00
root 1acfc78e13 refactor(llm): remove isDailyLimitReached from downstream consumers
The LlmService interface no longer exposes isDailyLimitReached — model
switching is handled internally. Remove all checks in thoughtSystem,
inventionSystem, narrationService, and thoughtGenerator. Update mocks
in test files to match the new interface and remove obsolete daily-limit
test cases.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-09 16:03:09 +00:00