You've already forked Diddy-Kong-Racing
mirror of
https://github.com/izzy2lost/Diddy-Kong-Racing.git
synced 2026-03-10 11:36:09 -07:00
* Fix some AVOID_UB stuff, and some small documenting. * Fix m2ctx.py and add NON_EQUIV func_80045C48 * Minor issue cleanups * Clean up audioline_ambient_create match * Match func_80008040 as audioline_init, fix the generate ctx script, and some small warning stuff. * Minor work on func_80008174 so it can be NON_EQUIVALENT again * redefine asm abs * Hackishly fix the ctx file when generated. * Use some more constants and got rid of some start: auto stuff which is not recommended in splat anymore for BSS * Do some documenting, and slightly better matches using JFG source. * Formatting * Clean up some more audio stuff * Further cleanup and naming of things
104 lines
2.6 KiB
Python
104 lines
2.6 KiB
Python
#!/usr/bin/env python3
|
|
|
|
import argparse
|
|
import os
|
|
import sys
|
|
import subprocess
|
|
import tempfile
|
|
|
|
script_dir = os.path.dirname(os.path.realpath(__file__))
|
|
root_dir = os.path.abspath(os.path.join(script_dir, ".."))
|
|
src_dir = root_dir + "src/"
|
|
|
|
# Project-specific
|
|
CPP_FLAGS = [
|
|
"-Iinclude",
|
|
"-Iinclude/libc",
|
|
"-Iinclude/PR",
|
|
"-Iinclude/sys",
|
|
"-Iassets",
|
|
"-Isrc",
|
|
"-Ilibultra",
|
|
"-Ilibultra/src/gu",
|
|
"-Ilibultra/src/libc",
|
|
"-Ilibultra/src/io",
|
|
"-Ilibultra/src/sc",
|
|
"-Ilibultra/src/audio",
|
|
"-Ilibultra/src/os",
|
|
"-D_LANGUAGE_C",
|
|
"-DF3DDKR_GBI",
|
|
"-D_MIPS_SZLONG=32",
|
|
"-DBUILD_VERSION=4",
|
|
"-DTARGET_N64",
|
|
"-D_FINALROM",
|
|
"-DNDEBUG",
|
|
"-DVERSION_us_v77",
|
|
"-DANTI_TAMPER",
|
|
"-D BUILD_VERSION_STRING=\"2.0G\"",
|
|
"-DM2CTX",
|
|
"-D__sgi",
|
|
"-DCIC_ID=6103",
|
|
"-U__GNUC__",
|
|
]
|
|
|
|
def import_c_file(in_file) -> str:
|
|
in_file = os.path.relpath(in_file, root_dir)
|
|
|
|
cpp_command = ["gcc", "-E", "-P", "-dD", *CPP_FLAGS, in_file]
|
|
|
|
with tempfile.NamedTemporaryFile(suffix=".c") as tmp:
|
|
stock_macros = subprocess.check_output(["gcc", "-E", "-P", "-dM", tmp.name], cwd=root_dir, encoding="utf-8")
|
|
|
|
try:
|
|
out_text = subprocess.check_output(cpp_command, cwd=root_dir, encoding="utf-8")
|
|
except subprocess.CalledProcessError:
|
|
print(
|
|
"Failed to preprocess input file, when running command:\n"
|
|
+ " ".join(cpp_command),
|
|
file=sys.stderr,
|
|
)
|
|
sys.exit(1)
|
|
|
|
if not out_text:
|
|
print("Output is empty - aborting")
|
|
sys.exit(1)
|
|
|
|
defines = {}
|
|
source_lines = []
|
|
for line in out_text.splitlines(keepends=True):
|
|
if line.startswith("#define"):
|
|
sym = line.split()[1].split("(")[0]
|
|
defines[sym] = line
|
|
elif line.startswith("#undef"):
|
|
sym = line.split()[1]
|
|
if sym in defines:
|
|
del defines[sym]
|
|
else:
|
|
source_lines.append(line)
|
|
|
|
for line in stock_macros.strip().splitlines():
|
|
sym = line.split()[1].split("(")[0]
|
|
if sym in defines:
|
|
del defines[sym]
|
|
|
|
return "".join(defines.values()) + "".join(source_lines)
|
|
|
|
def main():
|
|
parser = argparse.ArgumentParser(
|
|
description="""Create a context file which can be used for m2c / decomp.me"""
|
|
)
|
|
parser.add_argument(
|
|
"c_file",
|
|
help="""File from which to create context""",
|
|
)
|
|
args = parser.parse_args()
|
|
|
|
output = import_c_file(args.c_file)
|
|
|
|
with open(os.path.join(root_dir, "ctx.c"), "w", encoding="UTF-8") as f:
|
|
f.write(output)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|