A decompilation of Pikmin 2 (USA) brought to you by fans of the series.
Go to file
HeartPiece e10b48034e mapCode.cpp matched (unlinked) + formatting
need to fix container<mapcode::code> and array container<mapcode::code> vts to link
2022-07-21 20:24:44 +10:00
.github/workflows ci: Generate map & run calcprogress 2022-04-08 19:36:02 -04:00
asm Merge pull request #26 from encounter/challengebase 2022-07-18 12:25:20 -05:00
include mapCode.cpp matched (unlinked) + formatting 2022-07-21 20:24:44 +10:00
sha1 Initial commit 2021-09-27 21:57:49 +01:00
src mapCode.cpp matched (unlinked) + formatting 2022-07-21 20:24:44 +10:00
tools Update calcprogress.py 2022-06-29 17:17:01 -04:00
unsorted_include_todo ogScene WIP 2022-07-16 21:33:00 -04:00
.clang-format adjust formatting for some breathing room 2022-01-11 22:31:11 -05:00
.gitattributes Create .gitattributes 2022-01-27 22:30:48 -05:00
.gitignore stream.cpp (#23) 2022-07-16 13:44:09 -04:00
asmdiff.sh Add makefile for elf2dol, Edit asmdiff.sh, Add patch_linker.sh 2021-10-04 10:10:08 -04:00
e_files.mk link GBAWrite.c 2022-06-28 13:14:36 -04:00
format-files.py Remove unsorted include from format files 2021-12-29 17:42:25 +00:00
genasm.sh Update genasm.sh with --no-strip and some smarts. 2022-07-03 17:28:06 -04:00
genasmNoStrip.sh JPATexture, gameIconTexture, and random progress! 2021-12-05 19:22:31 -05:00
ldscript.lcf Major BSS refactor 2022-06-24 21:08:27 -04:00
LICENSE.MD Rename LICENSE to LICENSE.MD 2022-01-21 21:35:01 -05:00
linker-map.txt recreated source filesystem 2021-09-29 17:30:58 -04:00
Makefile match and link GBA.c 2022-06-29 17:05:43 -04:00
obj_files.mk Merge pull request #26 from encounter/challengebase 2022-07-18 12:25:20 -05:00
README.MD geomClone.cpp linking and geometry.cpp progress (#24) 2022-07-19 01:41:12 +10:00

Pikmin 2

Pikmin 2 decompilation to C++/C

- INFORMATION! -

The ROM this repository builds can be shifted! Meaning you are able to now
add and remove code as you see fit, for modding or research purposes.

It builds the following DOL: pikmin2.usa.dol: sha1: 90d328bf8f190c90472e8c19e7e53c6ad0fe0d1a

Credits

  • intns
  • EpochFlame
  • SodiumChlorideLogic
  • GibHaltmannKill
  • kiwi
  • shibboleet
  • wowjinxy
  • nerduminer
  • JHawk
  • Minty-Meeo
  • Revo
  • ShadowLugia
  • HeartPiece

Building

Required Tools

Instructions

  • WINDOWS ONLY STEP:
    • Launch msys2(Provided by devkitPro) and run the command pacman -S gcc.
  1. Download GC_WII_COMPILERS.zip from (https://cdn.discordapp.com/attachments/727918646525165659/917185027656286218/GC_WII_COMPILERS.zip) and extract the GC folder to tools/mwcc_compiler/.
    • This folder should be made by the user.
  2. Run make -j in a command prompt or terminal.
    • -j Allows make to use multiple threads, speeding up the process.
  • OPTIONAL:
    • Obtain a clean DOL of Pikmin 2 USA 1.0 and place it in the base working directory and rename it to baserom.dol.
    • To generate a linker map (takes a considerable amount of time), run make MAPGENFLAG=1 -j

Generating Context for decomp.me Scratches

(NB: The generator requires Python 3 to run)

  • Stand-alone decompilation packages and tools require information on the functions and structures of the project in order to parse extracted blocks correctly. The easiest way to do this is to pass the tool just the necessary 'context' for the file, i.e. a set of all the headers used by the file that's being worked on.
  • A recursive context processing script is included in the repo (tools/decompctx.py), which generates a ctx.c file in the root directory.
    • The contents of this can then be copied and pasted into the 'Context' section of a decomp.me scratch or similar.
  • To use, call the generator via the terminal/command line from the root directory (replacing DIRECTORY and FILE as required): python3 tools/decompctx.py /src/DIRECTORY/FILE.cpp
  • Credit to encounter and the Metroid Prime decomp project for the script!

Project Organisation

  • For each namespace that types and functions are contained within, create a folder. E.g. the structure Game::GameSystem will go in include/Game/GameSystem.h.
  • The exception is only when adding extra folders becomes useless, for example having to add multiple folders that are empty, you can instead opt for creating a header file with the namespace's definitions inside.
  • The project is actively formatted using .clang-format, for a consistent code style.

Progress

DONE

WIP