Skip to content
CJ Kucera edited this page Jun 4, 2024 · 35 revisions

AnimalWell.sav is a monolithic file containing “global” state info (figurines, etc), individual save slots, and game options all wrapped up into one. It has a fixed size of 479,360 bytes (at least at time of writing), so any given bit of information can be hardcoded with an index, if you're looking to look something up.

Note that the best source of information about the save file are the hex editor patterns out in the main area of the github repo. The most-canonical version is likely to be the 010 Editor Template, but the ImHex Pattern should be good as well. This document will strive to be reasonably complete and offer some more in-depth documentation about the various bits of data, but the editor templates are likely to be a bit more complete and well-proofread.

Unknowns/TODO

  • Waveform puzzle

Header Info

The first u32 of the file is a version field – was 2 at one point during prerelease, and as of writing is 9. Probably worth checking this if you're writing any tools.

The next u32 (at 0x04) holds the achievements that have been earned. It's not known if merely setting these values in the save will cause the achievements to be applied to your Steam account. The bitfield is structured like so:

  • 0x000001 - (unused? Marked as "Platinum" on the 010 Template)
  • 0x000002 - EXPLORER (Find the map)
  • 0x000004 - SECRET EGG (Find a secret egg)
  • 0x000008 - EGG ENJOYER (Find 8 secret eggs)
  • 0x000010 - EGG HOBBYIST (Find 16 secret eggs)
  • 0x000020 - EGG LORD (Find 32 secret eggs)
  • 0x000040 - EGG WELL (Find all secret eggs)
  • 0x000080 - SECRET RABBIT (Find a secret rabbit)
  • 0x000100 - CHAMELEON (Find the V. flame)
  • 0x000200 - GHOST (Find the P. flame)
  • 0x000400 - SEAHORSE (Find the B. flame)
  • 0x000800 - OSTRICH (Find the G. flame)
  • 0x001000 - CANDLE BRIGHT (Light all candles)
  • 0x002000 - MANTICORE (Release the Manticore)
  • 0x004000 - SNEAK (Sneak up on a squirrel)
  • 0x008000 - GOOD ENDING (Get crushed by a chinchilla)
  • 0x010000 - BACK AND FORTH FOREVER (Find a new way to get around)
  • 0x020000 - BUBBLE ECSTASY (Pop 1000 bubbles)
  • 0x040000 - TRAVEL FLUTE (Find another way to get around)
  • 0x080000 - WALK THE DOG (Find a different way to get around)
  • 0x100000 - EXIT (Leave the well)

The next u32 (at 0x08) is the "Frame Seed." This is a counter which starts when the game is booted and ends when the last flame disappears in the intro, and is presumably used in various RNG seeds throughout the game. Probably the most noticeable effect is that this value determines which Bunny Mural segment will be shown to the user. That will be the Frame Seed modulo 50. So, changing this value 50 times should let you see all segments in a singleplayer session.

The next u8 (at 0xC) is the last-active save slot (0, 1, or 2), used by the main menu “continue” option.

The next u8 (at 0xD) is an XOR-based checksum of the entire file. If the checksum doesn't match, the game will spawn a Manticore friend to help you play with your internal organs more efficiently. Fortunately it's simple to compute: simply start with 0, and walk through the file XORing each byte into the previous result (making sure to skip any existing checksum byte in the file). Sample code to “fix” the checksum on a file on-disk can be found here: https://gist.github.com/apocalyptech/8f8815c06bde9cd46d5170e1548c1e66

The next u8 (at 0xE) is used during the game runtime, to indicate whether an invalid hash was seen. It's not actually used from the savefile.

The next u32 (at 0x10) is a bitfield containing global unlocks, including the various figurines in the game:

  • 0x000001 - StopWatch
  • 0x000002 - Pedometer
  • 0x000004 - Pink Phone
  • 0x000008 - Souvenir Cup
  • 0x000010 - Origami Figurines
  • 0x000020 - Rabbit Figurine (Two Rabbits)
  • 0x000040 - Owl Figurine
  • 0x000080 - Cat Figurine
  • 0x000100 - Fish Figurine
  • 0x000200 - Donkey Figurine
  • 0x000400 - "DecoRabbit" Figurine
  • 0x000800 - mama cha
  • 0x001000 - Giraffe Figurine
  • 0x002000 - Incense Burner
  • 0x004000 - Peacock Figurine
  • 0x008000 - Otter Figurine
  • 0x010000 - Duck Figurine
  • 0x020000 - (unused)
  • 0x040000 - "PedometerWChest" (not sure what this one means)
  • 0x080000 - (unused)

The rest of the header is either unknown or padding.

Slot Data

Each save slot has a static offset in the file, and each slot is structured identically. The offsets are:

  • 0x00018 - Slot 1
  • 0x27028 - Slot 2
  • 0x4E038 - Slot 3

Each slot is exactly 159,760 bytes. The game options start immediately after, at 0x75048.

NOTE: When I mention any file indexes from here on out in the “Slot Data” section, they'll be relative to the save slot. So if I say something's at 0x108, that means that for slot 1 it lives at 0x120, for slot 2 it lives at 0x27130, etc.

General Info

  • Load Screen timestamp: 0x0 from the slot start
    • Two bytes for the year, and then one each for month, day, hour, minute, and second.
  • Step Count: u32 at 0x108 from the slot start
  • Total Firecrackers Picked Up: u16 at 0x1A2 from the slot start
  • Total Bubbles Popped: u16 at 0x1A4 from the slot start
  • Times saved: u16 at 0x1A8 from the slot start
  • Keys in inventory: u8 at 0x1B1 from the slot start
  • Matches in inventory: u8 at 0x1B2 from the slot start
  • Firecrackers in inventory: u8 at 0x1B3 from the slot start
    • Note that merely adding firecrackers to your inventory will not allow you to use firecrackers as an item; you will need to unlock them via the Equipment bitfield as well.

Times Died: 0x1E4 - u16

  • The skulls in the B.B. Wand / Souvenir Cup / Smiley Code / Skull room dynamically change depending on this value; don't need to look for those separately.

Health

Health (number of hearts) is stored as a u8 at 0x1B4 from the slot start. Any health above the player's current "base" health will show up as temporary blue hearts.

Gold hearts can be acquired from the Groundhog if the system clock is set to Groundhog Day (February 2), and the number of gold hearts is stored as a u8 at 0x1B5 from the slot start.

The game also keeps track of the last year in which a gold heart was redeemed from the groundhog. This value is stored as a u16 at 0x1B6 from the slot start.

Time In Game

Time in the game is measured in "ticks," and stored as a u32. The game runs at 60fps, so the unit is not milliseconds. Don't try to just plug it into a usual date-handling library without accounting for that first!

There are technically two fields for time spent in game. The first is stored at 0x1BC from the start of the slot, and describes only the in-game tick count, discounting any paused time. This doesn't seem to be used for anything obvious to the player. The second value, at 0x1C0 from the start of the save slot, also includes time spent in pause menus, and this is what the game uses for the speedrunning figurines, and what gets shown on the "load game" screen.

Spawnpoint

The user's spawnpoint is stored as a pair of u32 values, at 0x1D4 from the start of the slot, with the X value first, and Y value second. Note that the upper-left room on the map is coordinate (2, 4). If there is a phone in the room specified, the player will spawn next to the phone -- otherwise, they will spawn in the most upper-left corner available.

Spawning outside the map boundaries just gives you a featureless black screen and an inability to do anything but access the Esc pause menu, alas.

Map Data

Cranks

Crank data is stored at 0x8 from the slot start, as a list of 23 u16 values. The min/max values haven't yet been catalogued, but you can see the hex editor templates for the specific room mappings for all 23.

Chest Bitfields

Chest-opening status is encoded as a 128-bit value starting at 0x120 from the start of the slot. These have not been fully mapped yet, but known room coordinates can be seen in the hex editor templates. It looks like only the first 101 bits are used in this field.

Squirrel-Frightening Bitfields

I suspect (but don't know for sure yet) that all squirrels are near this point in the data, in a single large bitfield. 0 means the squirrel is happily eating a nut, 1 means you scared it away. (Note: I assume that these go to 1 when you steal a nut, too. Have not tested that, though!)

0x19C

  • 0x20: The first squirrel you see in the game

Ghost-Frightening Bitfields

I suspect (but don't know for sure yet) that all ghosts are near this point in the data, in a single large bitfield. 0 means the ghost is ready to give you a fright, 1 means you scared it away. (Note: I do not yet know how this interacts with lighting candles.) These values should get set back to 0 if you die, though once again I don't know how that interacts with candles.

0x1E7

  • 0x01 - The ghost “blocking” the way to the map pickup and exit to the larger map, at the beginning.
  • 0x04 - The ghost you're intended to frighten off first, after picking up fireworks for the first time.

Doors

There are five categories of openable doors/walls in the game:

  1. "Regular" doors which are opened via button presses, water reservoir puzzles, or other environmental puzzles.
  2. "Unlockable" doors which are opened using the "generic" keys you can store in your inventory.
  3. Moveable walls which are stored in the same kind of structure as the Unlockable Doors
  4. Egg Chamber Doors
  5. Other "special" doors like the House, Office, and Closet doors, whose states are actually controlled via "quest" flags, rather than a dedicated door structure.

Regular Door Bitfields (Buttons/Reservoirs/Puzzles)

The first category of doors are the ones opened by puzzles, be they buttons, water reservoirs, or other such things. These are stored in a 128-bit bitfield starting at 0x130 from the start of the slot data. These haven't been entirely mapped out yet, but you can get many room mappings from the hex editor patterns. It looks like only the first 94 bits are used in this field.

Note that the door state is completely independent from the button/puzzle states. You can toggle the doors to be open without having any of the buttons pressed down, and the doors will stay open.

Unlockable Doors and Moveable Walls

Unlockable Doors (of the sort which are unlocked via "generic" inventory keys) and moveable walls are stored using very similar data structures in the game, which the hex editor patterns call TileID. Each TileID structure consists of:

  • Room Y coordinate: u8
  • Room X coordinate: u8
  • Tile Y coordinate: u8
  • Tile X coordinate: u8 (but only the bottom six bits)
  • Map Layer: The top two bits of the Tile X coordinate

Note that the data stores the Y coordinates first, instead of X.

In practice, all known instances of TileID structures in the game have used map layer 0, but the engine does check for those top two bits, specifically looking for layer 1.

Additionally, the game stores the "next index" for the array, used by the engine to know where to write the next bit of data, but this index is stored rather far away from the arrays themselves, and uses a different byte width between the Doors and Walls arrays.

Unlockable Doors are stored starting at 0x88 from the slot start, and the "next index" is stored as a u16 at 0x1AA from the slot start. There are 16 TileID entries available. There are only six "valid" lockable door entries in the game, which are listed here with coordinates in the more-normal x, y order, rather than the y, x order they are stored in:

  • Room (7, 4), Tile (9, 5), Layer 0
  • Room (15, 8), Tile (38, 6), Layer 0
  • Room (16, 10), Tile (4, 5), Layer 0
  • Room (14, 13), Tile (6, 16), Layer 0
  • Room (14, 15), Tile (27, 6), Layer 0
  • Room (14, 15), Tile (32, 6), Layer 0

Moveable Walls are stored starting at 0xC8 from the slot start, and the "next index" is stored as a u8 at 0x1B8 from the slot start. There are 16 TileID entries available. Interestingly, there are technically 17 moveable walls in the game (three of which are only available via cheating), and the game's bounds checks for this data structure are not good. Triggering the 17th wall opening will cause the engine to repeatedly increment the "next index" and write the new value over a large chunk of savegame data. As of 2024-06-04, that has not yet been fixed.

The 14 "valid" moveable wall entries are:

  • Room (2, 5), Tile (2, 1), Layer 0
  • Room (15, 5), Tile (6, 3), Layer 0
  • Room (6, 6), Tile (16, 14), Layer 0
  • Room (7, 6), Tile (16, 1), Layer 0
  • Room (7, 6), Tile (5, 14), Layer 0
  • Room (13, 7), Tile (29, 1), Layer 0
  • Room (10, 8), Tile (16, 17), Layer 0
  • Room (2, 9), Tile (1, 6), Layer 0
  • Room (9, 10), Tile (39, 6), Layer 0
  • Room (8, 11), Tile (33, 19), Layer 0
  • Room (13, 11), Tile (39, 17), Layer 0
  • Room (6, 13), Tile (36, 7), Layer 0
  • Room (2, 19), Tile (9, 7), Layer 0
  • Room (2, 19), Tile (31, 7), Layer 0

The 3 "illegal" entries which could potentially fill up the array and cause an overflow if not removed, are:

  • Room (12, 4), Tile (29, 4), Layer 0
  • Room (3, 7), Tile (5, 3), Layer 0
  • Room (13, 13), Tile (11, 8), Layer 0

Egg Chamber Doors

The four doors in the egg chamber get their own 8-bit field at 0x1B9 from the start of the slot data. These doors will automatically open when you have the requisite number of eggs, but they can also be set to open via this bitfield. The first four bits control the doors, in order -- the other four are unused (as far as we know).

Buttons

There are four colors of buttons in the game:

  • Yellow buttons stay pressed down when pressed once
  • Purple buttons will pop back up without constant pressure (until all buttons in the relevant puzzle have been pushed down at the same time, at which time they'll stay down)
  • Green buttons control fans, instead of doors
  • Pink buttons control moveable walls, instead of doors

The button states are technically independent of the doors/walls that they're associated with, but if you set the correct buttons to be pressed down, the associated door will open up automatically when you next enter the room (even the ones controlled by purple buttons). Not all of these have been exhaustively mapped, but you can get room mappings for many by looking at the hex editor patterns.

These are all stored in bitfields, and grouped by their colors.

  • Yellow buttons are a 192-bit field starting at 0x140 from the start of the slot, and seem to use 134 of those bits.
  • Purple buttons are a 64-bit field starting at 0x160 from the start of the slot, and seem to use 27 of those bits.
  • Green buttons are a 64-bit field starting at 0x168 from the start of the slot, and seem to use just 7 of those bits.
  • Pink buttons are a 16-bit field starting at 0x1AC from the start of the slot, and ten of those are used by the game. See the section on moveable walls for some caveats about hitting all of these, since the moveable-wall section can overflow and corrupt saves!
    • 0x001 - Illegal Bunny 1
    • 0x002 - Spike Bunny
    • 0x004 - Floor is Lava Bunny
    • 0x008 - Illegal Bunny 2
    • 0x010 - Map Number Bunny
    • 0x020 - Elevator Dog Wheel
    • 0x040 - Chinchilla Bunny
    • 0x080 - Bulb Bunny
    • 0x100 - Illegal Bunny 3
    • 0x200 - Lower Portal Nexus

Water Reservoirs

The fill levels for the water reservoir puzzles are stored at 0x10C from the slot start as an array of 16 u8 values. The values are 0 when empty and 80 (decimal) when filled.

Even though there is room for 16 of them, there are only five in the game, stored in this order:

  • Room (7, 11)
  • Room (5, 15)
  • Three in Room (2,17)

Picked-Fruit Bitfields

Fruit only respawns in the game when your character dies, so the savegame keeps track of exactly which fruit has been picked. This is done via a 128-bit field starting at 0x170 from the start of the slot data. These have not been fully mapped, but you can get many room mappings from the hex editor patterns. It looks like 115 of the bits are actually in-use.

Firecracker Bitfields

Like fruit, firecrackers only respawn in the game when your character dies, so the savegame keeps track of those, too. This is done via a 64-bit field starting at 0x180 from the start of the slot data. These have not been fully mapped, but you can get many room mappings from the hex editor patterns. It looks like all 64 bits are used.

Detonators/Explosions

Detonators and the explosive charges they set off are technically stored in two separate bitfields in the game data. Setting them to enabled will result in the appropriate wall-destroying effect in game, but clearing out the fields will not recover destroyed walls; that would have to be done via the destruction map, instead.

The explosive statuses are stored in a 32-bit field starting at 0x190 from the start of the slot data. Only 10 bits are actually used in there. See the hex editor patterns for room mappings.

The detonator statuses are stored in a 32-bit field starting at 0x194 from the start of the slot data. Only 9 bits are actually used in there. See the hex editor patterns for room mappings.

Frightened Squirrels

Frightened-squirrel state is stored as a 16-bit field at 0x19C from the start of the slot data. See the hex editor pattern for specific room mappings. Only 13 of the bits are actually used.

Caged Cats / Mother Lynx

The 16-bit bitfield which controls which cat cages are open, and whether the Wheel cage is open (in Mother Lynx's lair) is at 0x19E from the start of the slot data. There are only five bits actually used in the field:

  • 0x01: Caged Cat 1 at 16,18
  • 0x02: Caged Cat 2 at 16,18
  • 0x04: Caged Cat 3 at 16,18
  • 0x08: Caged Cat 1 at 14,19
  • 0x10: Caged Cat 2 at 14,19
  • 0x20: Wheel Cage

Character/Collectibles Data

Equipment Bitfield

The unlocked equipment avilable to the user is stored as a u16 bitfield at 0x1DC from the start of the slot data. The available masks are:

  • 0x02: Firecrackers
  • 0x04: Animal Flute
  • 0x08: Lantern
  • 0x10: Top
  • 0x20: Disc (Note: if you give this to yourself without also setting the relevant quest statuses, you can find yourself with ghost dog hunting you down)
  • 0x40: B. Wand
  • 0x80: Yoyo
  • 0x100: Slink
  • 0x200: Remote
  • 0x400: Ball
  • 0x800: Wheel
  • 0x1000: UV Light

If you're editing equipment into a character which did not have equipment already (such as a fresh save), make sure to also alter the "selected equipment" field below! It can be difficult to get equipment selected unless the value is set right away.

Selected Equipment

The currently-selected equipment is stored as a u8 at 0x1EA from the start of the save slot. Valid values are:

  • 0x0: None
  • 0x1: Firecracker
  • 0x2: Animal Flute
  • 0x3: Lantern
  • 0x4: Top
  • 0x5: Disc
  • 0x6: B. Wand
  • 0x7: Yoyo
  • 0x8: Slink
  • 0x9: Remote
  • 0xA: Ball
  • 0xB: Wheel
  • 0xC: UV Light

If you unlock any equipment via save editing but leave this field at 0x00 (such as if you're editing a brand-new slot before it's picked up any equipment), equipment-swapping will be in a semi-non-working state. Next/Prev equipment buttons won't work, and if you only have a single equipment item, you can't enable it via the inventory screen, either. If you have more than one equipment item in your inventory, you can select one of them from the inventory screen, at which point all the equipment keys should work as intended. Bottom line, if you're enabling equipment with save editing, just be sure to make sure this field is set to one of the items you've added to the save.

Other Inventory Unlock Bitfields

Not sure if it makes sense to group this separately from the “equippable” items, but these are items which show up in your inventory but which you don't directly use (except in specific locations, like keys).

0x1DE

  • 0x02: S Medal
  • 0x08: House Key (I think, could have that switched with Office)
  • 0x10: Office Key (I think, could have that switched with House)
  • 0x20: Unused Key (literally not used in the game at all)
  • 0x40: E Medal
  • 0x80: Fanny Pack

Map Unlock Bitfield

This bitfield controls what aspects of the map you've got unlocked.

0x1ED

  • 0x02 - The map itself
  • 0x04 - Stamp
  • 0x08 - Pencil

Egg Bitfield

The eggs you acquire are stored in a 64-bit field starting at 0x188 from the start of the slot data, and all 64 bits are used. The bitfield is set up like so:

  • 0x0000000000000001: Reference Egg
  • 0x0000000000000002: Brown Egg
  • 0x0000000000000004: Raw Egg
  • 0x0000000000000008: Pickled Egg
  • 0x0000000000000010: Big Egg
  • 0x0000000000000020: Swan Egg
  • 0x0000000000000040: Forbidden Egg
  • 0x0000000000000080: Shadow Egg
  • 0x0000000000000100: Vanity Egg
  • 0x0000000000000200: Egg as a Service
  • 0x0000000000000400: Depraved Egg
  • 0x0000000000000800: Chaos Egg
  • 0x0000000000001000: Upside Down Egg
  • 0x0000000000002000: Evil Egg
  • 0x0000000000004000: Sweet Egg
  • 0x0000000000008000: Chocolate Egg
  • 0x0000000000010000: Value Egg
  • 0x0000000000020000: Plant Egg
  • 0x0000000000040000: Red Egg
  • 0x0000000000080000: Orange Egg
  • 0x0000000000100000: Sour Egg
  • 0x0000000000200000: Post Modern Egg
  • 0x0000000000400000: Universal Basic Egg
  • 0x0000000000800000: Laissez-Faire Egg
  • 0x0000000001000000: Zen Egg
  • 0x0000000002000000: Future Egg
  • 0x0000000004000000: Friendship Egg
  • 0x0000000008000000: Truth Egg
  • 0x0000000010000000: Transcendental Egg
  • 0x0000000020000000: Ancient Egg
  • 0x0000000040000000: Magic Egg
  • 0x0000000080000000: Mystic Egg
  • 0x0000000100000000: Holiday Egg
  • 0x0000000200000000: Rain Egg
  • 0x0000000400000000: Razzle Egg
  • 0x0000000800000000: Dazzle Egg
  • 0x0000001000000000: Virtual Egg
  • 0x0000002000000000: Normal Egg
  • 0x0000004000000000: Great Egg
  • 0x0000008000000000: Gorgeous Egg
  • 0x0000010000000000: Planet Egg
  • 0x0000020000000000: Moon Egg
  • 0x0000040000000000: Galaxy Egg
  • 0x0000080000000000: Sunset Egg
  • 0x0000100000000000: Goodnight Egg
  • 0x0000200000000000: Dream Egg
  • 0x0000400000000000: Travel Egg
  • 0x0000800000000000: Promise Egg
  • 0x0001000000000000: Ice Egg
  • 0x0002000000000000: Fire Egg
  • 0x0004000000000000: Bubble Egg
  • 0x0008000000000000: Desert Egg
  • 0x0010000000000000: Clover Egg
  • 0x0020000000000000: Brick Egg
  • 0x0040000000000000: Neon Egg
  • 0x0080000000000000: Iridescent Egg
  • 0x0100000000000000: Rust Egg
  • 0x0200000000000000: Scarlet Egg
  • 0x0400000000000000: Sapphire Egg
  • 0x0800000000000000: Ruby Egg
  • 0x1000000000000000: Jade Egg
  • 0x2000000000000000: Obsidian Egg
  • 0x4000000000000000: Crystal Egg
  • 0x8000000000000000: Golden Egg

Bunny Bitfield

The bunnies that you've collected are stored in a 32-bit field starting at 0x198 from the start of the slot. Technically all 32 bits are used, but unlocking any of the "illegal" bunnies will make BDTP impossible to solve.

The valid bunny bitmasks are:

  • 0x00000001: Tutorial Bunny (#4)
  • 0x00000004: Origami Bunny (#17)
  • 0x00000008: Crow Bunny (#10)
  • 0x00000010: Ghost Bunny (#9)
  • 0x00000040: Fish Mural Bunny (#8)
  • 0x00000080: Map Numbers Bunny (#5)
  • 0x00000100: TV Bunny (#16)
  • 0x00000200: UV Bunny (#7)
  • 0x00000400: Bulb Bunny (#13)
  • 0x00000800: Chinchilla Bunny (#2)
  • 0x00008000: Bunny Mural Bunny (#1)
  • 0x00400000: Duck Bunny (#11)
  • 0x02000000: Ghost Dog Bunny (#18)
  • 0x10000000: Dream Bunny (#12)
  • 0x40000000: Floor Is Lava Bunny (#14)
  • 0x80000000: Spike Room Bunny (#20)

The "illegal" bunny bitmasks are:

  • 0x00000002: Illegal 1
  • 0x00000020: Illegal 2
  • 0x00001000: Illegal 3
  • 0x00002000: Illegal 4
  • 0x00004000: Illegal 5
  • 0x00010000: Illegal 6
  • 0x00020000: Illegal 7
  • 0x00040000: Illegal 8
  • 0x00080000: Illegal 9
  • 0x00100000: Illegal 10
  • 0x00200000: Illegal 11
  • 0x00800000: Illegal 12
  • 0x01000000: Illegal 13
  • 0x04000000: Illegal 14
  • 0x08000000: Illegal 15
  • 0x20000000: Illegal 16

Minimap

“Basic” minimap data is stored as a single bit for each “pixel” of the minimap. The game engine fills in the colors as-appropriate, and will update the map depending on the actual game state (if walls have been demolished, etc).

Each minimap room is 40x22 pixels, so that's five bytes for a single row across a room, and 110 bytes total for the room. Even though the playable game area is 16x16 rooms, the minimap (and the actual map, technically), is 20x24, with the 16x16 playable area centered in there. There are four empty rows of rooms on the top+bottom, and two columns of empty rooms on the sides. So, that yields 52,800 bytes of info for the minimap as a whole.

Structurally, it's stored sort of like an image; one big row at a time. So the entire first row comes first (for all rooms at the “top”), then the next row down, etc. The minimap starts at 0x3EC and runs up until 0xD22C (non-inclusive).

Immediately after the “main” minimap data area is a single (presumably unused) byte, and then another chunk of 52,800 bytes which describe the “pencil” data which can be drawn by the user. It's in the same format as the main minimap data. That starts at 0xD22D and runs up until 0x1A06D (non-inclusive).

Stamps are stored earlier in the game data, starting at 0x225. The first bit of data is a u8 describing how many stamps have been placed. Next is a u16 which stores the stamp icon that's currently selected by the user. The values are:

  • 0: Chest
  • 1: Heart
  • 2: Skull
  • 3: Diamond-or-whatever
  • 4: Spiral
  • 5: Flame
  • 6: Diamond “grid”
  • 7: Question Mark

(a u16 is a bit overkill for that, but it's what the game seems to use).

Then after that are 64 slots for stamp descriptions. The game will compact them into a consecutive list as stamps are deleted, so you don't need to check for “null” stamps or anything; just read in however many the save says are there. The format of each stamp is:

  1. u16 - x coordinate (in minimap pixels)
  2. u16 - y coordinate (in minimap pixels)
  3. u16 - icon, using the same values as above

The stamp data should end at byte 0x3A7 (so 0x3A8 would be the next-free byte for other data).

Game Options

ANIMAL SICK has pretty thoroughly figured that section out – we'll paste that in here once we get permission for that. The options start just after the last save slot, at 0x75048.

Clone this wiki locally