Everything here is free to use and modify.
Credit is not mandatory, just don’t take my stuff and claim you’re the one that made it.
Everything here is for FE8.
With the exception of MurderSticks, every hack here was written in C with Stan’s FE-CLIB and converted to EA format with lyn. If you want to modify/recompile a hack here you’ll need both.
Ever wanted to include arenas in your hack, but didn’t want people abusing them to max units out?
Arena Limits + Non Lethal Arena
Download Here - Version 1.1
This hack allows does two things:
- Allows you to set limits on arena usage. You can set a level limit, a turn limit, both or neither.
- Allows you to optionally make arenas nonlethal - lose, and you’ll just lose your gold and be spit out of the arena at 1HP.
Installing it is relatively simple:
- Go into installer.event and change the ArenaLevelLimitTextID define to whichever textID you want to replace. The text itself is built in RAM, so you don’t have to do anything further to have it display.
- Edit the ArenaLimitTable as desired.
- If you want lethal arenas back, change the _NonLethalArena define to 0x0 instead of 0x1.
- If you use a higher maximum level than 20, change the related #define.
It should be compatible with anything that doesn’t alter the arena command usability routine (or the routines I hooked to make arenas nonlethal). Though this hack does store its text in RAM - if you find that this does conflict with another hack, just go and change the FreeSpaceRAM define to a different free RAM location.
Tired of empty level ups/lords getting stat screwed? Want to change maximum levels or maximum luck?
Level Up Rework
Download Here - Version 2
This hack allows you to set a few things:
- Minimum stats gained per level up
- Minimum stats gained per level up for characters with the Lord ability
- The maximum level for all units, and the maximum level for specific classes. So you could have all classes max out at level 15, or some classes max out at level 30, or both.
There’s nothing special to do to install it - just change the settings in Installer.event to suit your needs and then #include it.
It should be compatible with anything that doesn’t modify the same routines. This hack is compatible with the SkillSystem’s Str/Mag split.
Ever wanted to include offensive staves in your hack?
Normally, offensive staves won’t display their statistics in the attack/item windows (since the game expects staves to display an item use description instead). This hack fixes that problem.
Note that unless you modify the default priest/cleric animations (they need to have the right code to wait for the enemy’s HP to deplete), trying to play attack animations for them softlocks the game. So I’ve included fixed versions of those animations in the zip (made with Animation Assembler). Just #include those ontop of the Installer.event and you’re good to go.
Ever wanted to change a chapter’s objective through events?
This hack allows you to change chapter objective text through events. Installation is simple - just #include the Installer.event, then use the provided SetChapterObjectiveText(textid, textid2) macro in your events as necessary. The first text ID is the short objective (the one shown on the map itself), the second one is the longer objective text (shown in the prep screen and status screen).
This stores the new textIDs to be read in trap data. It shouldn’t conflict with any other hacks, unless they also use trap type ID 0xEF. And if that does happen, I can just change the id to something else. If you don’t use SetChapterObjectiveText, it just reads the values from chapter data like in vanilla.
Special thanks to Leonarth for providing multiple suggestions (storing the new textIDs in trap data), and Stan for catching a bug before I posted this.
Ever wanted a little more 776 in your 8? Or just liked the idea of leadership stars?
This hack brings the ‘leadership stars’ mechanic to FE8. Units with leadership stars grant a (configurable) Hit / Avoid bonus to all units of the same allegiance. It requires the Skill System and Modular Stat Screen. Installation is slightly complicated:
- #include the Installer.event - note that it has to be included before Master Skill Installer.event! Edit the LeadershipTable, and other options as desired.
- Go into Skill System\Battle Calculations.event, and add
after one of the POINs. You should end up with a line that looks similar to this:
POIN LeadershipHook ElbowRoom NaturalCover Gamble FieryBlood LifeAndDeath WindDisciple Perfectionist Puissance Hawkeye LightWeight Trample Opportunist
- Take the contents of “put these in your text buildfile.txt” and put it in the top of your text buildfile. If you’ve changed the hit/avoid bonus, you probably want to update the text to match.
- Copy the contents of the ‘mss stuff’ folder into your MSS folder (it should overwrite ModularStatScreen.event, and the mss_page1_skill.dmp/s files)
- (Optional) If you’re using icon 0xCA already (it’s an unused icon in vanilla), it’s possible to change what icon is used for the star. You’ll have to change it in Installer.event, and in mss_page1_skills.s, StatusScreenEnemy.s and StatusScreenPlayer.s (don’t forget to run Assemble ARM on again after changing the icon number)
By default this replaces the affinity/element icon on page 1. If you don’t like that, it’s not too hard to whip up your own MSS settings. It also replaces the textID for one of the debug menu options (the third, which doesn’t even work anyway).
This changes the unit count on the ‘Status’ screen to instead display the total amount of leadership stars for ally and enemy units, so players can have a quick way to view total leadership.
As usual, this hack (well, LeadershipFunctions.c at least) was written in Stan’s FE-CLIB and converted to EA format by lyn.
Wouldn’t it be nice if you could just type like normal and the game would insert newlines for you? What if it could calculate how long sentences are, and intelligently place newlines and A presses to keep them together on the same text box?
This hack intelligently inserts [A] and [NL] codes in text, as well as handling multiple other text codes automatically (for example, turning … into [Beat]). Installation is fairly simple:
- #include the Installer.event. It has to be included after Anti-Huffman (usually included in the essential fixes). This hack hooks into Anti-Huffman.
- Read the README.txt to get an idea of how to use the hack. It even comes with some example text entries you can insert to get a feel for how the hack works.
- Adjust the options in Installer.event… or leave them at defaults, either works.
- Have fun writing text without the hassle of manual newlines.
While all code in this hack is original, credit for the concept/idea goes to laqieer ( https://github.com/laqieer/FE7CNLOL/blob/master/src/FE7CNText.c ). I certainly would not have thought to do this on my own.
Note that this hack assumes your Anti-Huffman is installed in the standard location (specifically the " ORG 0x464470; AntiHuffmanFreeSpace:" bit.) If your Anti-Huffman is elsewhere for some reason, just drop me a line and I can make you another hook.
As usual, this hack was written in C with Stan’s FE-CLIB and converted to EA format by lyn.
Ever wish you could make enemy autolevels less random? Ever wondered why promoted enemies have way higher stats in hard mode?
This hack gives you multiple options to tweak how autoleveling works.
- Normally, the game adds an extra random bonus to autoleveled growths, which makes enemy stats more variable. You can reduce, eliminate, or even increase this bonus.
- You can specify the amount of ‘bonus’ levels a promoted unit gains. In vanilla, on normal mode this is +9 levels (as if the unit had promoted at level 10)… but on Hard, it’s +19 (as if every enemy unit promoted at level 20)
- There’s an option to further reduce variance by calculating all growths at once using the promoted class’ growths (instead of autoleveling twice, once for ‘before promotion’, once for ‘after promotion’). See the readme for more details.
- Finally, it turns out that the difficulty level bonus/penalty is applied separately from autoleveling. There’s an option that does them both at once, to further reduce randomness.
- Oh, and I threw in the ability to disable level bonus/penalty being applied to bosses. Might be useful.
Installation is simple: #include the Installer.event, change options as desired.
Credits to decomp ( https://github.com/FireEmblemUniverse/fireemblem8u/blob/master/src/bmunit.c ) for making it far easier for me to understand how autoleveling works.