Remove legacy string enum comparisons from InputState/Key/MouseButton, closes #306

Removed custom __eq__/__ne__ that allowed comparing enums to legacy string
names (e.g., Key.ESCAPE == "Escape"). Removed _legacy_names dicts and
to_legacy_string() functions. Kept from_legacy_string() in PyKey.cpp as
it's used by C++ event dispatch. Updated ~50 Python test/demo/cookbook
files to use enum members instead of string comparisons. Also updates
grid.position -> grid.pos in files that had both types of changes.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
John McCardle 2026-04-09 22:19:02 -04:00
commit 6d5e99a114
52 changed files with 372 additions and 533 deletions

View file

@ -79,7 +79,7 @@ perspective_names = ["Omniscient", "Player", "Enemy"]
# UI Setup
ui = visibility_demo.children
ui.append(grid)
grid.position = (50, 100)
grid.pos = (50, 100)
grid.size = (900, 600) # 30*30, 20*30
# Title
@ -138,49 +138,48 @@ def cycle_perspective():
# Key handlers
def handle_keys(key, state):
"""Handle keyboard input"""
if state == "end": return
key = key.lower()
if state == mcrfpy.InputState.RELEASED: return
# Player movement (WASD)
if key == "w":
if key == mcrfpy.Key.W:
move_entity(player, 0, -1)
elif key == "s":
elif key == mcrfpy.Key.S:
move_entity(player, 0, 1)
elif key == "a":
elif key == mcrfpy.Key.A:
move_entity(player, -1, 0)
elif key == "d":
elif key == mcrfpy.Key.D:
move_entity(player, 1, 0)
# Enemy movement (Arrows)
elif key == "up":
elif key == mcrfpy.Key.UP:
move_entity(enemy, 0, -1)
elif key == "down":
elif key == mcrfpy.Key.DOWN:
move_entity(enemy, 0, 1)
elif key == "left":
elif key == mcrfpy.Key.LEFT:
move_entity(enemy, -1, 0)
elif key == "right":
elif key == mcrfpy.Key.RIGHT:
move_entity(enemy, 1, 0)
# Tab to cycle perspective
elif key == "tab":
elif key == mcrfpy.Key.TAB:
cycle_perspective()
# Space to update visibility
elif key == "space":
elif key == mcrfpy.Key.SPACE:
player.update_visibility()
enemy.update_visibility()
print("Updated visibility for both entities")
# R to reset
elif key == "r":
elif key == mcrfpy.Key.R:
player.x, player.y = 5, 10
enemy.x, enemy.y = 25, 10
player.update_visibility()
enemy.update_visibility()
update_info()
print("Reset positions")
# Q to quit
elif key == "q":
elif key == mcrfpy.Key.Q:
print("Exiting...")
sys.exit(0)