-
-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support for loading/writing Hivebrain's MapMacros #3
Comments
Geez, so much for settling on a single universal format. Because of the need to preserve labels, addressing this may have to wait until I make libsonassmd bypass the assembler and parse mappings directly. Those macros of your could help, though I'd like to license them however I want so I may have to write them myself from scratch like I did with MainMemory's. |
It's nice to have a more human-readable format, but alas it makes supporting everything more complicated. xD Parsing the mappings directly is probably the way to go, though the way Hivebrain has implemented them, the DPLC files explicitly depend on the mapping files (the index tables are synchronized via macro), so they would need to be loaded simultaneously. The DPLCs themselves have a interesting caveat: the individual frames are all separate files rather than a single blob, and the DPLCs are generated via macro rather than hard-coded. This may pose an issue while loading the DPLCs, but will simplify generating them (simply writing a macro argument rather than calculating the DPLCs). This feature is only implemented in the HB 2022 disasm for the moment, but I plan to extend it to my Sonic 2 disasm in time, and I suspect it'll be added to Sonic 1 Squared. Anyhow, I've put together a file with all of the macros required to assemble this format, which hopefully should illustrate how it works. https://gist.github.com/OrionNavattan/6e0a6be89096d2b9593557f759b214ef |
Sonic 1-squared actually uses yet another format, inline DPLCs which eliminate the need for a second index. Here's an example: https://github.com/cvghivebrain/Sonic1sq/blob/main/Objects/Giant%20Ring%20%5BMappings%5D.asm Don't worry about adding support for that though. It'll probably only ever be used in my hacks. |
Maybe just allow the user to set their own mapping macro format as need be? |
At this point, these are the only mappings that this program doesn't yet support. Hivebrain's format is similar to the MainMemory's SpritePiece, albeit with an emphasis on human readability:
Looking at the source of libsonassmd, I get the impression that the program converts macro mappings to binary by assembling them if the presence of a copy of MainMemory's macros in assembler.cpp is any indication. I've prepared a file with the macros required to assemble HB's format, and can provide it to help you get started. That said, there is one significant caveat with regards to writing mapping files in this format: the labels used within the mapping files must remain unchanged, as they are referenced in animation scripts. There is also a possible caveat with handling DPLCs, but I'll leave that for later.
The text was updated successfully, but these errors were encountered: