prime/README.md

111 lines
3.5 KiB
Markdown
Raw Normal View History

2024-06-24 05:06:28 +00:00
Metroid Prime
2024-09-19 06:20:50 +00:00
[![Build Status]][actions] [![Code Progress]][progress] [![Data Progress]][progress] [![Discord Badge]][discord]
=============
[Build Status]: https://github.com/PrimeDecomp/prime/actions/workflows/build.yml/badge.svg
[actions]: https://github.com/PrimeDecomp/prime/actions/workflows/build.yml
2024-09-19 06:20:50 +00:00
[Code Progress]: https://decomp.dev/PrimeDecomp/prime.svg?mode=shield&measure=code&label=Code
[Data Progress]: https://decomp.dev/PrimeDecomp/prime.svg?mode=shield&measure=data&label=Data
[progress]: https://decomp.dev/PrimeDecomp/prime
2024-06-24 05:06:28 +00:00
[Discord Badge]: https://img.shields.io/discord/727908905392275526?color=%237289DA&logo=discord&logoColor=%23FFFFFF
[discord]: https://discord.gg/hKx3FJJgrV
A work-in-progress decompilation of Metroid Prime.
This repository does **not** contain any game assets or assembly whatsoever. An existing copy of the game is required.
The following game versions are supported:
- `GM8E01_00` (USA v1.088)
<!--
- `GM8E01_01` (USA v1.093)
- `GM8E01_48` (KOR v1.097)
-->
If you'd like to contribute, see [CONTRIBUTING.md](CONTRIBUTING.md).
Dependencies
============
2024-09-05 04:03:20 +00:00
Windows
--------
On Windows, it's **highly recommended** to use native tooling. WSL or msys2 are **not** required.
When running under WSL, [objdiff](#diffing) is unable to get filesystem notifications for automatic rebuilds.
- Install [Python](https://www.python.org/downloads/) and add it to `%PATH%`.
- Also available from the [Windows Store](https://apps.microsoft.com/store/detail/python-311/9NRWMJP3717K).
- Download [ninja](https://github.com/ninja-build/ninja/releases) and add it to `%PATH%`.
- Quick install via pip: `pip install ninja`
2024-09-05 04:03:20 +00:00
macOS
------
2024-09-05 04:03:20 +00:00
- Install [ninja](https://github.com/ninja-build/ninja/wiki/Pre-built-Ninja-packages):
2024-09-05 04:03:20 +00:00
```sh
brew install ninja
```
2024-09-05 04:03:20 +00:00
- Install [wine-crossover](https://github.com/Gcenx/homebrew-wine):
2024-09-05 04:03:20 +00:00
```sh
brew install --cask --no-quarantine gcenx/wine/wine-crossover
```
After OS upgrades, if macOS complains about `Wine Crossover.app` being unverified, you can unquarantine it using:
2024-09-05 04:03:20 +00:00
```sh
sudo xattr -rd com.apple.quarantine '/Applications/Wine Crossover.app'
```
2024-09-05 04:03:20 +00:00
Linux
------
2024-09-05 04:03:20 +00:00
- Install [ninja](https://github.com/ninja-build/ninja/wiki/Pre-built-Ninja-packages).
- For non-x86(_64) platforms: Install wine from your package manager.
2024-09-05 04:03:20 +00:00
- For x86(_64), [wibo](https://github.com/decompals/wibo), a minimal 32-bit Windows binary wrapper, will be automatically downloaded and used.
Building
========
- Clone the repository:
2024-09-05 04:03:20 +00:00
```sh
git clone https://github.com/PrimeDecomp/prime.git
```
2024-09-05 04:03:20 +00:00
- Update and Initialize submodules:
2024-09-05 04:03:20 +00:00
```sh
git submodule update --init --recursive
```
2024-09-05 04:03:20 +00:00
- Copy your game's disc image to `orig/GM8E01_00` (or the appropriate version).
- Supported formats: ISO (GCM), RVZ, WIA, WBFS, CISO, NFS, GCZ, TGC
- After the initial build, the disc image can be deleted to save space.
- Configure:
2024-09-05 04:03:20 +00:00
```sh
python configure.py
```
2024-09-05 04:03:20 +00:00
To use a version other than `GM8E01_00` (USA), specify `--version GM8E01_01` or similar.
- Build:
2024-09-05 04:03:20 +00:00
```sh
ninja
```
Diffing
=======
2024-09-05 04:03:20 +00:00
Once the initial build succeeds, an `objdiff.json` should exist in the project root.
2024-09-05 04:03:20 +00:00
Download the latest release from [encounter/objdiff](https://github.com/encounter/objdiff). Under project settings, set `Project directory`. The configuration should be loaded automatically.
Select an object from the left sidebar to begin diffing. Changes to the project will rebuild automatically: changes to source files, headers, `configure.py`, `splits.txt` or `symbols.txt`.
![](assets/objdiff.png)