ModSDK - a modding toolkit to create mods for Crash Team Racing in C. This repository also houses an effort to fully decompile and reverse-engineer CTR in C.
Go to file
2023-04-09 13:33:24 -04:00
psx-modding-toolchain 230 progress 2023-04-09 13:33:24 -04:00
.gitignore some stuff 2022-08-29 15:10:03 -04:00
lectures.txt lectures 2022-11-12 15:18:21 -05:00
README.md Update README.md 2023-03-26 16:48:51 -04:00

CTR-ModSDK

ModSDK. (noun) A toolkit that allows you to create mods for Crash Team Racing (1999) in C.

Contributors Discord Server

This repository also houses an effort to fully decompile and reverse-engineer CTR in C.

This SDK uses:

📃 Features

  • Extract and build ISO in few steps
  • Supports all retail versions and two prototypes
  • Compile C code into any address and overlay
  • Integrated Xdelta patch generation
  • Hot Swap: Load code replacements while the game is running

🏁 How to Start Modding

Requirements

  • python 3+
  • Open command prompt (CMD/Terminal) and install the dependencies:
pip install requests
pip install opencv-python

Downloading the SDK

Clone this repository:

$ git clone https://github.com/CTR-Tools/CTR-ModSDK.git
  • You can find example mods in our repo.
  • Each mod folder includes a readme.txt file on what the mod does and how to use it.
  • To build a mod, simply run build.bat in the mod folder.

CTR-in-C

Work-in-progress project to decompile Crash Team Racing into human-readable C code.

Decompile Overview

📊 Progress

Decompilation, Research and Documentation

Decompiling the binaries assisted by Ghidra, researching how it works and documentating them with comments.

Code Rewrite

Rewriting Ghidra output to human-readable C Code and testing if it's functional. Most of the source code are shared between versions.

* These are not accurate numbers and subject to change.

🤝 Contributing

Are you interested in contributing? Have any experience in C programming language? You're welcome to join!

How to rewrite functions:

  • Make sure you have cloned this repo and installed the requirements.
  • Choose a .c file from ghidra folder. Each file represents a code section or category. All non-numbered .c files are parts of the main EXE while the numbered files are overlays.
  • Choose a function in that section to rewrite. Read the documentation comments on what the function does and what's the address.
  • Add a new line for your new function to buildList.txt with this format:
common*, exe**, <name of original function to replace>, 0x0,  <rewritten function .c file>

* Build codenames:
common: All versions;
926: USA Retail;
1006: Japan Trial;
1020: Europe Retail;
1111: Japan Retail.

** Code region:
exe: main EXE;
221-233: Overlays (use the original .c filename number)

  • Run build.bat and choose "Compile", "build ISO", then test the game.
  • After you've confirmed that it's functional, add your new function c file to the decompile directory.
  • Now you can make a pull request

If you have any questions, reach us out in our Discord server.