2017-08-18 05:18:15 +00:00
|
|
|
A game folder
|
|
|
|
is higan's way of grouping all
|
|
|
|
the information and resources required
|
|
|
|
to properly emulate a particular game.
|
|
|
|
Other emulators group resources related to a game
|
|
|
|
by requiring that every file has the base name
|
|
|
|
but different file extensions.
|
|
|
|
|
|
|
|
For example,
|
|
|
|
if another emulator loaded the game `dkc3.sfc`
|
|
|
|
it might store the save data in `dkc3.srm`:
|
|
|
|
|
|
|
|
```text
|
|
|
|
+- Super Famicom
|
|
|
|
|
|
|
|
|
+- dkc3.sfc
|
|
|
|
|
|
|
|
|
+- dkc3.srm
|
|
|
|
```
|
|
|
|
|
|
|
|
higan would create a game folder named `dkc3.sfc`,
|
|
|
|
and inside it store the game data as `program.rom`
|
|
|
|
and the save data as `save.ram`:
|
|
|
|
|
|
|
|
```text
|
|
|
|
+- Super Famicom
|
|
|
|
|
|
|
|
|
+- dkc3.sfc
|
|
|
|
|
|
|
|
|
+- program.rom
|
|
|
|
|
|
|
|
|
+- save.ram
|
|
|
|
```
|
2017-07-21 11:40:03 +00:00
|
|
|
|
|
|
|
Why game folders?
|
|
|
|
-----------------
|
|
|
|
|
2017-08-18 05:18:15 +00:00
|
|
|
The traditional files-with-different-extensions system
|
|
|
|
works well enough when a game only requires
|
|
|
|
a small number of files,
|
|
|
|
because a file extension doesn't offer
|
|
|
|
much room for description.
|
|
|
|
Also,
|
|
|
|
since file extensions traditionally describe
|
|
|
|
the format of the file in question,
|
|
|
|
it also means a game can't use
|
|
|
|
two or more files in the same format.
|
|
|
|
|
|
|
|
Compared to other emulators,
|
|
|
|
higan tends to use a larger number of files per game.
|
|
|
|
For example,
|
|
|
|
higan's low-level emulation of Super Famicom co-processors
|
|
|
|
often requires [separate firmware files][firmware].
|
|
|
|
higan's [MSU-1 support][msu1]
|
|
|
|
requires up to 99 audio tracks per game,
|
|
|
|
and higan supports up to 133 save-states per game.
|
|
|
|
Therefore,
|
|
|
|
higan suffers from the limitations of name-based-grouping
|
|
|
|
more than most.
|
2017-07-21 11:40:03 +00:00
|
|
|
|
2017-08-18 05:18:15 +00:00
|
|
|
higan's game folders allow all a game's resources
|
|
|
|
to be given unique, descriptive filenames,
|
|
|
|
and to use the file-extension
|
|
|
|
that's most appropriate for that file.
|
|
|
|
They also allow emulator-specific data
|
|
|
|
like save-states and the cheat database
|
|
|
|
to be kept separate from the game's actual data,
|
|
|
|
by putting it in a sub-folder.
|
2017-07-21 11:40:03 +00:00
|
|
|
|
2017-08-18 05:18:15 +00:00
|
|
|
[msu1]: ../guides/import.md#msu-1-games
|
|
|
|
[firmware]: ../guides/import.md#games-with-co-processor-firmware
|
2017-07-21 11:40:03 +00:00
|
|
|
|
2017-08-18 05:18:15 +00:00
|
|
|
For a more detailed motivation for game folders,
|
|
|
|
see [Game Paks on the higan website][gp].
|
2017-07-21 11:40:03 +00:00
|
|
|
|
2017-08-18 05:18:15 +00:00
|
|
|
[gp]: https://byuu.org/emulation/higan/game-paks
|
2017-07-21 11:40:03 +00:00
|
|
|
|
|
|
|
What's in a game folder?
|
|
|
|
------------------------
|
|
|
|
|
2017-08-22 08:12:17 +00:00
|
|
|
As mentioned above,
|
2017-07-21 11:40:03 +00:00
|
|
|
a game folder collects all the information relevant
|
|
|
|
to emulating a particular game.
|
|
|
|
Not all of the following files
|
|
|
|
are relevant to every emulated console,
|
|
|
|
or to every game on a given console,
|
2017-08-18 05:18:15 +00:00
|
|
|
but they may be present under particular circumstances.
|
2017-07-21 11:40:03 +00:00
|
|
|
|
|
|
|
All the files directly in the game folder
|
|
|
|
are expected to be useful
|
|
|
|
to all emulators that support them:
|
|
|
|
|
|
|
|
- `manifest.bml`:
|
2017-08-22 08:12:17 +00:00
|
|
|
The [manifest](manifests.md) for this game folder.
|
2017-07-21 11:40:03 +00:00
|
|
|
- `program.rom`:
|
|
|
|
For most consoles,
|
|
|
|
this contains
|
|
|
|
the executable instructions and graphics data
|
|
|
|
from the cartridge's ROM chips.
|
|
|
|
For the Famicom,
|
|
|
|
this contains only the executable instructions.
|
|
|
|
- `character.rom`:
|
|
|
|
For the Famicom,
|
|
|
|
this contains only the graphics data
|
|
|
|
from the cartridge's ROM chips.
|
|
|
|
- `ines.rom`:
|
|
|
|
While other consoles typically include enough hints
|
2017-08-18 05:18:15 +00:00
|
|
|
in `program.rom` for icarus to guess a working manifest,
|
2017-07-21 11:40:03 +00:00
|
|
|
the Famicom does not.
|
|
|
|
Famicom games not stored in game folders
|
|
|
|
typically include an "iNES header" to store that information,
|
|
|
|
which icarus preserves after import as `ines.rom`.
|
|
|
|
- `save.ram`:
|
|
|
|
Games that include a save feature
|
|
|
|
will create this file.
|
|
|
|
Note that it is only written to disk
|
|
|
|
when higan exits gracefully,
|
|
|
|
if higan crashes or is forced to quit,
|
|
|
|
in-game saves may be lost.
|
|
|
|
Other emulators sometimes call this an "SRAM file",
|
|
|
|
even though the same filename is used
|
|
|
|
for cartridges that use EEPROM or Flash storage,
|
|
|
|
not just battery-backed Static RAM.
|
|
|
|
- `rtc.ram`:
|
|
|
|
Games that include a calendar or real-time clock
|
|
|
|
will create this file.
|
|
|
|
- `*.data.rom`, `*.program.rom`:
|
2017-08-18 05:18:15 +00:00
|
|
|
Files named like this are usually [co-processor firmware][firmware].
|
2017-07-21 11:40:03 +00:00
|
|
|
- `msu1.rom`:
|
2017-08-18 05:18:15 +00:00
|
|
|
Holds streamable data for [the MSU-1][msu1].
|
2017-07-21 11:40:03 +00:00
|
|
|
- `track-*.pcm`:
|
2017-08-18 05:18:15 +00:00
|
|
|
Holds streamable audio for [the MSU-1][msu1].
|
2017-07-21 11:40:03 +00:00
|
|
|
|
|
|
|
Files that are only useful to higan specifically
|
|
|
|
are placed in a `higan` subdirectory:
|
|
|
|
|
|
|
|
- `cheats.bml`:
|
|
|
|
All information present in
|
2017-08-18 05:18:15 +00:00
|
|
|
[the Cheat Editor](../interface/higan-tools.md#the-cheat-editor)
|
2017-07-21 11:40:03 +00:00
|
|
|
is stored here.
|
|
|
|
- `states/quick/slot-*.bst`:
|
2017-08-18 05:18:15 +00:00
|
|
|
All [Quick States](save-states.md#quick-states) are stored here.
|
2017-07-21 11:40:03 +00:00
|
|
|
- `states/managed/slot-*.bst`:
|
2017-08-18 05:18:15 +00:00
|
|
|
All [Manager States](save-states.md#manager-states) are stored here.
|