Variations on a theme. A concordance of sorts. (This may result in some blog posts.)
picorogue.c
- C99. Reference implementation. The originalrogue
was written in C, as were its most significant descendants.picorogue.rb
- Ruby 2.6. Nearly line-by-line translation of the C. Not what is considered idiomatic Ruby today, but not too strange.picorogue.html
/picorogue-dom.js
- JavaScript executing in the browser. I believe I am using ES2015 features but no later. Because of the browser JS execution model, is somewhat differently structured than the C or Ruby. On the other hand, parts of it are literally copy-and-pasted from the C.
Program structure, especially the order of program elements (functions, constants, variables) is identical wherever possible. Game logic is limited to one file (necessary accoutrements, like Makefile
and the HTML for the JS version, don't count). Nonstandard dependencies are to be eschewed whenever possible.
The C and Ruby versions are unpleasant to operate because they must use standard buffered I/O (stdio). The original rogue
used curses
-- in fact, the two mutually influenced each other. I'm inclined to make ncurses an exception to the "no dependencies" rule and will likely pursue that before continuing.
Following are my original notes for this idea. The current implementation does not match this in all details.
- The Game consists of a tower of $FLOORS floors, numbered 1 through $FLOORS.
- Each floor consists of a $XMAXx$YMAX tile grid.
- Each tile is either blocked or clear.
- On one tile on each floor, an up staircase should be placed.
- Blocked tiles are placed on the floor according to a 'digging algorithm', subject to the following constraints:
- The tile the PC is placed on may not be blocked.
- The tile the staircase is placed on may not be blocked.
- It must be possible for the PC to move from the start location to the staircase.
- The player character (PC) is placed in a random tile on the floor.
- The up stairs are placed on a random tile on the floor.
- If the tile chosen happens to be in the same row or column as the PC, pick a new tile.
- Gameplay is divided into turns.
- Each turn starts with the player choosing an action and completes with the resolution of that action.
- The following actions are available:
- Move (north, east, south, west): Attempt to move one tile in a direction.
- Moving succeeds if the destination tile is clear, and fails if it is blocked.
- Attempting to move beyond the bounds of the map fails.
- Climb: Attempt to ascend stairs.
- Climbing succeeds if the current tile contains a staircase, and fails otherwise.
- Move (north, east, south, west): Attempt to move one tile in a direction.
- The turn counter is incremented regardless of whether an action succeeds or fails.
- When the PC climbs stairs, the next floor up is loaded and the PC is placed on a random tile as stated above.
- If the PC climbs stairs on floor 10, the player has won the game.
- The player is presented with a message indicating their success and the number of turns it took to win.
- The game world is displayed using ASCII characters.
- A blocked tile is '#'
- A clear tile is '.'
- The PC is '@'
- The up staircase is '<'
- Actions are issued using the keyboard.
- Up Arrow and k issue Move: North
- Down Arrow and j issue Move: South
- Left Arrow and h issue Move: West
- Right Arrow and l issue Move: East
- < issues Climb
- Aside from the current floor and PC position, the screen also shows the current floor number and turn count.
- A 'pursuing ghost' (monsters, evasion, simple pathfinding)
- Starvation (items, hunger clock)
- Time runs out (fog of war, turn clock)
- Savage beasts (monsters, line of sight, hit points, equipment)
- Traps (special tiles, 'look', timed events)
- Environmental conditions (special tiles, 'look', equipment)
- A single, mutable, preferably global game state
- Procedural style to the extent the language permits
- Floors should be generated on demand
- The design currently only requires storing one floor at once!
- The RNG should be seedable and deterministic -- same floors and start locations for a given seed