MAME Path Handling¶
MAME has a specific order it uses when checking for user files such as ROM sets and cheat files.
Order of Path Loading¶
Let’s use an example of the cheat file for AfterBurner 2 for Sega Genesis/MegaDrive (aburner2 in the megadrive softlist), and your cheatpath is set to “cheat” (as per the default) – this is how MAME will search for that cheat file:
- cheat/megadriv/aburner2.xml
- cheat/megadriv.zip -> aburner2.xml Notice that it checks for a .ZIP file first before a .7Z file.
- cheat/megadriv.zip -> <arbitrary path>/aburner2.xml It will look for the first (if any) aburner2.xml file it can find inside that zip, no matter what the path is.
- cheat.zip -> megadriv/aburner2.xml Now it is specifically looking for the file and folder combination, but inside the cheat.zip file.
- cheat.zip -> <arbitrary path>/megadriv/aburner2.xml Like before, except looking for the first (if any) aburner2.xml inside a megadriv folder inside the zip.
- cheat/megadriv.7z -> aburner2.xml Now we start checking 7ZIP files.
- cheat/megadriv.7z -> <arbitrary path>/aburner2.xml
- cheat.7z -> megadriv/aburner2.xml
- cheat.7z -> <arbitrary path>/megadriv/aburner2.xml Similar to zip, except now 7ZIP files.
[todo: ROM set loading is slightly more complicated, adding CRC. Get that documented in the next day or two.]