fix(mystery): wait verb routes to encounters; chip list reflects dynamic items
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -19,6 +19,13 @@ describe('computeChips — sample world', () => {
|
||||
expect(chips.find((c) => c.kind === 'item' && c.command === 'take letter')).toBeTruthy()
|
||||
})
|
||||
|
||||
it('removes TAKE chip after item is taken', () => {
|
||||
let s = initialStateFor(world)
|
||||
s = dispatch(s, { kind: 'verb-target', verb: 'take', target: { canonical: 'letter', raw: 'letter' } }, world).state
|
||||
const chips = computeChips(s, world)
|
||||
expect(chips.find((c) => c.command === 'take letter')).toBeUndefined()
|
||||
})
|
||||
|
||||
it('adds an encounter verb chip when an encounter is active', () => {
|
||||
let s = initialStateFor(world)
|
||||
s = dispatch(s, { kind: 'go', direction: 'n' }, world).state
|
||||
|
||||
+4
-2
@@ -1,5 +1,6 @@
|
||||
import type { World } from '../world/types'
|
||||
import type { GameState, Direction } from '../engine/types'
|
||||
import { getItemsInRoom } from '../engine/dispatcher'
|
||||
|
||||
export type ChipKind = 'direction' | 'item' | 'encounter' | 'meta'
|
||||
|
||||
@@ -33,10 +34,11 @@ export function computeChips(state: GameState, world: World): Chip[] {
|
||||
}
|
||||
}
|
||||
|
||||
// Item chips: TAKE for visible items.
|
||||
for (const itemId of room.items) {
|
||||
// Item chips: TAKE for visible items (dynamic list excludes taken items).
|
||||
for (const itemId of getItemsInRoom(state, world, state.location)) {
|
||||
const item = world.items[itemId]
|
||||
if (!item || !item.takeable) continue
|
||||
if (state.inventory.find((inst) => inst.id === itemId)) continue // already held
|
||||
out.push({
|
||||
kind: 'item',
|
||||
label: `TAKE ${item.names[0]?.toUpperCase() ?? itemId.toUpperCase()}`,
|
||||
|
||||
Reference in New Issue
Block a user