AM2R-Community-Updates
Please do not request help until you have read this entire document. The vast majority of your questions should be answered within it, and we will be able to easily tell if you have not followed the installation instructions thoroughly.
What is this?
The source code for the AM2R Community Updates 1.5.x branch, free of copyrighted assets and trademarks. If you have not played the AM2R Community Updates before, this will be of no use to you!
This source code is based on AM2Rrc by YellowAfterlife. It could be considered a fork.
If you are looking for a playable build of the game, please download the AM2RLauncher to install the latest update.
Copyright clarifications
This source code does not contain any copyrighted assets or trademarks - in fact, it does not contain any assets at all, just like the AM2Rrc repository.
Assets must be extracted from your copy of the AM2R Community Updates using GMXDataSync in order to compile this project properly.
Furthermore, there are two paid shader assets included in the Community Updates: Pixelated Pope's Retro Palette Swapper (make sure you get the GameMaker: Studio 1.4 version! It should be a .gmz, not a .yyz) and PixHammer's GameBoy Shader. We do not curently have permission to distribute either of these assets, so they are excluded from this repository. You will need to replace them with default shader code in order for the project to compile.
Finally, we have excluded the datafiles and changelog from this repository to further enforce the removal of trademarks.
License
Please read our license before distributing, modifying, contributing to, or otherwise interacting with this project.
Contributing
Please read our Contribution Guidelines before opening any issues or creating pull requests.
Additionally, it would be most helpful if you joined the Official AM2R Discord Server if you plan on contributing to the project.
Known issues
The vast majority of this source code is undocumented, as it is based on a bytecode reconstruction.
The default language files will display three empty fields when loaded due to recent name changes. This will be a non-issue once 1.5.3 releases.
Reordering assets created before the Community Updates began can have consequences throughout the entire project because of magic numbers: references to assets by numeric ID instead of name. Changing asset order will cause magic number references throughout the source code to begin referencing incorrect assets. Because of this, pull requests that attempt to reorganize assets will be denied.
Much of this code is messy, uses unusual solutions, and does not hold to our established formatting style - this is a result of AM2R's reconstruction and nature as a learning project passed down to multiple lead developers.
Requirements
-
GameMaker: Studio 1.4.1763 - the IDE for editing and compiling this project.
-
GMXDataSync - a utility created by YellowAfterlife to populate project files with matching game assets.
-
A copy of the latest release build of the AM2R Community Updates, which can be installed via the AM2RLauncher.
-
Pixelated Pope's Retro Palette Swapper - as said above, make absolutely sure you get the GameMaker: Studio 1.4 version! It's a .gmz file, not a .yyz file!
Installation
This repository, being based on YellowAfterlife's source reconstruction, is installed in a very similar fashion.
- Download everything from the requirements section above.
- Download and extract this repository somewhere.
- Go to where you have your AM2Rlauncher located, then into the
Profiles
folder, and after that theCommunity Updates (Latest)
. Place thedata.win
file from there into the project directory.
- Drag the
data.win
file onto the GmxDataSync executable. If everything is correct, this will populate the project with art/audio assets from the binary.
- Replace the two blank shader assets with default GM:S shader skeletons or your own copy of each shader, as well as the accompanying script files for the Retro Palette Swapper:
pal_swap_init_system
andpal_swap_set
. WARNING: If the two above scripts are not replaced before opening the project file, GM:S 1.4 will replace them with<undefined>
references in the asset tree atScripts/Lojical/Shaders/
. This will produce numerous seemingly unrelated errors until they are deleted and replaced with the appropriately named scripts. - Finally, you will need to install
modifiers.ini
as well as thelang
andmods
folders as datafiles within the GM:S project. The default ones do not contain the actual assets and are merely references. These can be copied from yourCommunity Updates (Latest)
folder. - [optional] Copy music files (.ogg) from game directory into "audio" directory inside the "sound" directory of the project (the game will still work without music, though).