Go to file
coco875 02ad54ca72
Refactor yaml and remove segment (#531)
* move yaml (still need to fix header path)

* fix header

* change kart to karts and add migration

* fix include

* Update migration.py

* fix common_texture_debug_font extraction

* Update torch

* update torch and header

* unduplicate texture for tumble

* Update torch

* Update migration.py

* put the sort by default

* fix replace_segmented_textures_with_o2r_textures

* Update torch

* fix yamls

* add manual_segments in data of course

* comment out replace_segmented_textures_with_o2r_textures and segment 3

* remove segment 5

* (wip) remove segment 6

still plenty of thing to do

* more vtx

* more change

* Update torch

* small fix

* Update BansheeBoardwalk.cpp

* fix blockFort

* Delete test.yaml

* fix bowser castle and simplify track sections

* fix choco mountain

* clean banshee

* fix dk jungle

* fix double deck

* fix macos

* fix error

* fix macos ci

* Update torch

* Update torch

* fix frappe snowland

* fix kalimari desert

* fix koopa troopa beach

* fix luigi raceway

* fix mario raceway and simplify thing

* fix moo moo farm

* fix rainbow road

* Update torch

* Update torch

* hopefully fix windows error

* fix a small error

* fix royal raceway (and podium in theory)

* fix sherbet_land

* fix skyscraper

* fix toads turnpike

* fix wario stadium

* fix yoshi valley

* update torch

* more clang tidy rules

* REMOVE totally SEGMENT (sorry for the PR)

* remove unused field in course and props and unused packed asset

* fix kart texture

* fix particle

* fix track section and transparency

* try fix mode extra

* fix macos build and render

* fix collision in extra

* small change and try fix windows error

* a little of clean

* more cleanup

* forget header and more clean up

* Update Makefile

* fix credits

* fix kart texture offset

* remove LoadTextures and add Unload

* fix definitevely mirror mode

* add unload but it's not perfect

* revert a bad fix

* clean no longer used python script

* fix crash with player

* being able to load the same course twice

* add a comment on DrawWater

* fix render of transparent object

* better hack

* add a proper migration instruction

* fix number

* add basic modsmanager

* add meta/mods.toml

* Update EditorMath.h

* Update ModsManager.cpp

* basic modManager (maybe I should rename it ModLoader)

* use range on dependencies

* add information about mods.toml

* fix coment

* some rename around

* Delete beta-to-v1.md

* Update migrations.md

* Update textures-pack.md

* Update modding.md

* Update modding.md

* clean yamls_old

* move to mods in engine

* rename ModsManger to  ModManager

* move init and unload at the top

* rename ModsMetadata to ModMetadata

* fix header

* Update ModManager.cpp

* put core mods at top
2025-12-07 07:34:53 -07:00
.github/workflows Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
assets Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
cmake Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
courses Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
docs Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
doxygen-awesome-css@9760c30014 enable and update doxygen (#364) 2025-06-25 08:37:40 -06:00
include Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
libultraship@d1bbd53e8a Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
meta Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
models Impl new intro (#193) 2025-05-14 18:30:32 -06:00
mods [modding] Implement jumbtron fb effect (#125) 2024-11-15 03:02:20 -07:00
port/assets/fonts Fix Compile (#188) 2025-02-07 23:48:36 -07:00
src Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
tools Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
torch@c3fdb5d5e3 Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
yamls/us Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
.clang-format Update decomp clang (#67) 2024-08-27 17:47:39 -06:00
.clang-tidy Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
.editorconfig Memory and Actor decomp (#201) 2022-05-14 15:12:32 -07:00
.gitattributes Add building on macOS (#224) 2022-06-15 17:26:03 -07:00
.gitignore Add basic documentation (#416) 2025-07-04 19:30:04 -06:00
.gitmodules Remove unused submodules (#226) 2025-06-16 16:33:31 -06:00
CMakeLists.txt Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
Dockerfile Docker: Use latest cmake release 2025-07-04 11:17:06 +02:00
Doxyfile re add the doxyfile who get remove (#365) 2025-06-25 09:03:35 -06:00
ExecutableResource.h Pr before release (#239) 2025-06-20 16:54:31 -06:00
Info.plist Fixed MacOS Build 2025-03-07 18:32:15 -06:00
README.md Update README.md (#576) 2025-11-28 11:16:40 -07:00
Resource.rc Pr before release (#239) 2025-06-20 16:54:31 -06:00
SpaghettiKart.desktop Impl new intro (#193) 2025-05-14 18:30:32 -06:00
addr_to_sym.py Delete courses/cup folders and rename course related files (#432) 2023-09-20 17:17:24 -06:00
check_type_yamls.py Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
config.yml Refactor yaml and remove segment (#531) 2025-12-07 07:34:53 -07:00
extract_assets.py add compatibilty for Windows build (#564) 2024-02-22 08:33:46 -07:00
icon.png Fixed MacOS Build 2025-03-07 18:32:15 -06:00
lus-cvars.cmake Define default keyboard layout 2024-11-21 17:29:14 -07:00
progress.py Action Renames (#606) 2024-04-12 19:16:13 -06:00
properties.h Pr before release (#239) 2025-06-20 16:54:31 -06:00
properties.h.in Pr before release (#239) 2025-06-20 16:54:31 -06:00
python_convert.py place surface type const and unassemble flag in vtx and document effects (#553) 2024-01-20 21:22:35 -07:00
rename_sym.sh Linkage for the ceremony_data file (#478) 2023-10-27 22:18:20 -06:00
spaghettikart.ico Pr before release (#239) 2025-06-20 16:54:31 -06:00
spaghettikart.manifest Pr before release (#239) 2025-06-20 16:54:31 -06:00
test_blend.bat update with the decomp (#97) 2024-09-17 09:32:50 -06:00
valgrind_callgrind.sh make some texture more flexible and editable + port documentation from the decomp + fix some bug (#309) 2025-07-01 17:42:14 -06:00
vcpkg.json Update vcpkg.json (#561) 2025-11-14 11:44:33 -07:00

README.md

Spaghetti Kart Spaghetti Kart

Discord

Official Discord: https://discord.com/invite/shipofharkinian

If you're having any trouble after reading through this README, feel free ask for help in the SpaghettiKart Support text channels. Please keep in mind that we do not condone piracy.

Quick Start

SpaghettiKart does not include any copyrighted assets. You are required to provide a supported copy of the game.

1. Verify your ROM dump

The US ROM is the only supported version. You can verify you have dumped a supported copy of the game by using the SHA-1 File Checksum Online at https://www.romhacking.net/hash/. The hash for a US ROM is SHA-1: 579C48E211AE952530FFC8738709F078D5DD215E.

2. Verify your ROM is in .z64 format

Your ROM needs to be in .z64 format. If it's in .n64 format, use the following to convert it to a .z64: https://hack64.net/tools/swapper.php

2. Download SpaghettiKart from Releases

3. Generating the O2R from the ROM

Windows

  • Extract every file from the zip into a folder of your choosing.
  • Run "Spaghettify.exe" and select your US ROM.

Linux

  • Extract every file from the zip into a folder of your choosing.
  • Ensure zenity or kdialog package is installed.
  • Run "spaghetti.appimage" and select your US ROM. You may have to chmod +x the appimage via terminal.

Nintendo Switch

  • Run one of the PC releases to generate an mk64.o2r file. After launching the game on PC, you will be able to find these files in the same directory as Spaghettify.exe or spaghetti.appimage.
  • Copy the files to your sd card

4. Play!

  • Launch Spaghettify.exe Congratulations, you are now sailing with SpaghettiKart! Have fun!

Configuration

Default controls configuration

N64 A B L R Z Start Analogue stick C buttons D-Pad
Keyboard Shift Ctrl Q Space Z Enter Arrow keys TGFH (↑ ↓ ← →) Num 8 2 4 6
SDL Gamepad A X LB RB LT Start L-Stick R-Stick Up, B, Y, R-Stick Right (↑ ↓ ← →) D-Pad

Other shortcuts

Keys Action
F11 Fullscreen
Tab Toggle Alternate assets
Ctrl+R Reset
Esc Settings

Graphics Backends

Currently, there are three rendering APIs supported: DirectX11 (Windows), OpenGL (all platforms), and Metal (macOS). You can change which API to use in the Settings menu of the menubar, which requires a restart. If you're having an issue with crashing, you can change the API in the spaghettify.cfg.json file by finding the line "Backend":{... and changing the id value to 3 and set the Name to OpenGL. DirectX 11 with id 2 is the default on Windows. Metal with id 4 is the default on macOS.

Custom Assets

Custom assets are packed in .o2r or stored .zip files. To use custom assets, place them in the mods folder.

If you're interested in creating and/or packing your own custom asset .o2r files, check out the following tools:

Note that .otr archives are not supported in SpaghettiKart!

Development

Building

If you want to manually compile SpaghettiKart, please consult the building instructions.

Playtesting

If you want to playtest a continuous integration build, you can find them at the links below. Keep in mind that these are for playtesting only, and you will likely encounter bugs and possibly crashes.

Maintainers: MegaMech, Coco, Kirito

Powered by libultraship