-
Notifications
You must be signed in to change notification settings - Fork 6
Getting Started
This page offers step by steps instructions on how to build the MediEvil Decompilation Project using your MediEvil 1 US PSX copy of the game.
The build process has the following package requirements:
- git
- make
- gcc-mipsel-linux-gnu
- binutils-mipsel-linux-gnu
- clang
- clang-format
- clang-tidy-14
- python3
- python3-pip
Under Debian / Ubuntu (which we recommend using), you can install them with the following commands:
sudo apt-get update
sudo apt-get install -y git make gcc-mipsel-linux-gnu binutils-mipsel-linux-gnu clang clang-format clang-tidy-14 python3 python3-pip
Create your own fork of the repository at https://github.com/MediEvilDecompilation/medievil-decomp
. Then clone your fork where you wish to have the project, with the command:
git clone https://github.com/<YOUR_USERNAME>/medievil-decomp.git
This will copy the GitHub repository contents into a new folder in the current directory called medievil-decomp
. Change into this directory before doing anything else:
cd medievil-decomp
The build process has a few python packages required that are located in /tools/requirements-python.txt
.
To install them simply run in a terminal:
python3 -m pip install -r ./tools/requirements-python.txt
git submodule update --init --recursive
Use any software with cue/bin support such as PowerISO to extract the game binaries from your own copy of Medievil US PSX, and put the files inside /disk/
Use this command to clean
, extract
the assembly and build
the project:
make init
Make sure you get an OK
on all the files before proceeding to decompile any function.
Use the following command to clean any untracked files by git:
make clean
Use the following command to disassemble the game binaries:
make extract
Use the following command to build the project:
make build
Use the following command to confirm the built binaries are matching the binaries from the original game:
make check
Use the following command to build and check the project in one go:
make