mirror of https://github.com/PrimeDecomp/prime.git
configure.py: Add --compilers and --build-dir; cleanup
This commit is contained in:
parent
3417e5c576
commit
3ec17fbf33
440
configure.py
440
configure.py
|
@ -2,7 +2,7 @@
|
|||
LIBS = [
|
||||
{
|
||||
"lib": "TRK_MINNOW_DOLPHIN",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -12,7 +12,7 @@ LIBS = [
|
|||
{
|
||||
"lib": "MetroidPrimeCW",
|
||||
"cflags": "$cflags_retro",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"host": True,
|
||||
"objects": [
|
||||
["MetroidPrime/main", False],
|
||||
|
@ -372,7 +372,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "WorldFormatCW",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_retro",
|
||||
"host": True,
|
||||
"objects": [
|
||||
|
@ -392,7 +392,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "WeaponsCW",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_retro",
|
||||
"host": True,
|
||||
"objects": [
|
||||
|
@ -408,14 +408,14 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "MetaRenderCW",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_retro",
|
||||
"host": True,
|
||||
"objects": ["MetaRender/CCubeRenderer"],
|
||||
},
|
||||
{
|
||||
"lib": "GuiSysCW",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_retro",
|
||||
"host": True,
|
||||
"objects": [
|
||||
|
@ -442,7 +442,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "CollisionCW",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_retro",
|
||||
"host": True,
|
||||
"objects": [
|
||||
|
@ -461,7 +461,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "Kyoto_CW1",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_retro",
|
||||
"host": True,
|
||||
"objects": [
|
||||
|
@ -618,7 +618,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "zlib",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_runtime",
|
||||
"host": True,
|
||||
"objects": [
|
||||
|
@ -636,7 +636,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "Kyoto_CW2",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_retro",
|
||||
"host": True,
|
||||
"objects": [
|
||||
|
@ -698,7 +698,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "ai",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -707,7 +707,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "ar",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -717,7 +717,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "base",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -726,7 +726,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "db",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -735,7 +735,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "dsp",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -746,7 +746,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "dvd",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -762,7 +762,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "gx",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base -fp_contract off",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -785,7 +785,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "mtx",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -798,7 +798,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "os",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -829,7 +829,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "pad",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -839,14 +839,14 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "vi",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": ["Dolphin/vi"],
|
||||
},
|
||||
{
|
||||
"lib": "MSL_C.PPCEABI.bare.H",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_runtime",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -918,7 +918,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "musyx",
|
||||
"mwcc_version": "1.3.2",
|
||||
"mw_version": "1.3.2",
|
||||
"cflags": "$cflags_musyx",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -957,7 +957,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "dtk",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -966,7 +966,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "card",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -990,7 +990,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "si",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -1000,7 +1000,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "exi",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -1010,7 +1010,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "thp",
|
||||
"mwcc_version": "1.2.5",
|
||||
"mw_version": "1.2.5",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -1020,7 +1020,7 @@ LIBS = [
|
|||
},
|
||||
{
|
||||
"lib": "gba",
|
||||
"mwcc_version": "1.2.5e",
|
||||
"mw_version": "1.2.5e",
|
||||
"cflags": "$cflags_base",
|
||||
"host": False,
|
||||
"objects": [
|
||||
|
@ -1041,6 +1041,7 @@ if __name__ == "__main__":
|
|||
import sys
|
||||
import argparse
|
||||
|
||||
from pathlib import Path
|
||||
from shutil import which
|
||||
from tools import ninja_syntax
|
||||
|
||||
|
@ -1072,17 +1073,20 @@ if __name__ == "__main__":
|
|||
parser.add_argument(
|
||||
"--devkitppc",
|
||||
dest="devkitppc",
|
||||
type=Path,
|
||||
help="path to devkitPPC",
|
||||
)
|
||||
if os.name != "nt" and not "_NT-" in os.uname().sysname:
|
||||
parser.add_argument(
|
||||
"--wine",
|
||||
dest="wine",
|
||||
type=Path,
|
||||
help="path to wine (or wibo)",
|
||||
)
|
||||
parser.add_argument(
|
||||
"--build-dtk",
|
||||
dest="build_dtk",
|
||||
type=Path,
|
||||
help="path to decomp-toolkit source",
|
||||
)
|
||||
parser.add_argument(
|
||||
|
@ -1091,10 +1095,24 @@ if __name__ == "__main__":
|
|||
action="store_true",
|
||||
help="build with debug info (non-matching)",
|
||||
)
|
||||
parser.add_argument(
|
||||
"--compilers",
|
||||
dest="compilers",
|
||||
type=Path,
|
||||
default=Path("tools/mwcc_compiler"),
|
||||
help="path to compilers",
|
||||
)
|
||||
parser.add_argument(
|
||||
"--build-dir",
|
||||
dest="build_dir",
|
||||
type=Path,
|
||||
default=Path("build"),
|
||||
help="base build directory",
|
||||
)
|
||||
args = parser.parse_args()
|
||||
|
||||
# On Windows, we need this to use && in commands
|
||||
ALLOW_CHAIN = "cmd /c " if os.name == "nt" else ""
|
||||
chain = "cmd /c " if os.name == "nt" else ""
|
||||
|
||||
out = io.StringIO()
|
||||
n = ninja_syntax.Writer(out)
|
||||
|
@ -1108,34 +1126,36 @@ if __name__ == "__main__":
|
|||
if os.name != "nt" and "DEVKITPPC" in os.environ and not args.devkitppc:
|
||||
configure_args.extend(["--devkitppc", os.environ["DEVKITPPC"]])
|
||||
n.variable("configure_args", configure_args)
|
||||
n.variable("python", sys.executable)
|
||||
n.newline()
|
||||
|
||||
###
|
||||
# Variables
|
||||
###
|
||||
n.comment("Variables")
|
||||
n.variable("version", args.version.lower())
|
||||
version = args.version.lower()
|
||||
if args.version.lower() == "kor":
|
||||
n.variable("version_num", "2")
|
||||
version_num = "2"
|
||||
elif args.version.isnumeric() and int(args.version) in [0, 1]:
|
||||
n.variable("version_num", args.version)
|
||||
version_num = args.version
|
||||
else:
|
||||
sys.exit(f'Invalid version "{args.version}"')
|
||||
n.variable("builddir", "build/mp1.$version")
|
||||
n.variable("out", args.build_dir / f"mp1.{version}")
|
||||
build_path = Path("$out")
|
||||
if args.devkitppc:
|
||||
n.variable("devkitppc", args.devkitppc)
|
||||
dkp_path = args.devkitppc
|
||||
elif os.name == "nt":
|
||||
n.variable("devkitppc", "C:\devkitPro\devkitPPC")
|
||||
dkp_path = Path("C:\devkitPro\devkitPPC")
|
||||
elif "DEVKITPPC" in os.environ:
|
||||
n.variable("devkitppc", os.environ["DEVKITPPC"])
|
||||
dkp_path = Path(os.environ["DEVKITPPC"])
|
||||
else:
|
||||
n.variable("devkitppc", "/opt/devkitpro/devkitPPC")
|
||||
cflags_base = "-proc gekko -nodefaults -Cpp_exceptions off -RTTI off -fp hard -fp_contract on -O4,p -maxerrors 1 -enum int -inline auto -str reuse -nosyspath -MMD -DPRIME1 -DVERSION=$version_num -DNONMATCHING=0 -i include/ -i libc/"
|
||||
dkp_path = Path("/opt/devkitpro/devkitPPC")
|
||||
|
||||
cflags_base = f"-proc gekko -nodefaults -Cpp_exceptions off -RTTI off -fp hard -fp_contract on -O4,p -maxerrors 1 -enum int -inline auto -str reuse -nosyspath -MMD -DPRIME1 -DVERSION={version_num} -DNONMATCHING=0 -i include -i libc"
|
||||
if args.debug:
|
||||
cflags_base += " -sym on -D_DEBUG"
|
||||
else:
|
||||
cflags_base += " -DNDEBUG"
|
||||
|
||||
n.variable("cflags_base", cflags_base)
|
||||
n.variable(
|
||||
"cflags_retro",
|
||||
|
@ -1146,82 +1166,120 @@ if __name__ == "__main__":
|
|||
"$cflags_base -use_lmw_stmw on -str reuse,pool,readonly -gccinc -inline deferred,auto",
|
||||
)
|
||||
n.variable("cflags_musyx", "$cflags_base -str reuse,pool,readonly -fp_contract off")
|
||||
asflags = "-mgekko -I include/ --defsym version=$version_num -W --strip-local-absolute -gdwarf-2"
|
||||
asflags = f"-mgekko -I include --defsym version={version_num} -W --strip-local-absolute -gdwarf-2"
|
||||
n.variable("asflags", asflags)
|
||||
ldflags = "-fp fmadd -nodefaults -lcf ldscript.lcf"
|
||||
if args.map:
|
||||
ldflags += " -map $builddir/MetroidPrime.MAP"
|
||||
map_path = build_path / "MetroidPrime.MAP"
|
||||
ldflags += f" -map {map_path}"
|
||||
if args.debug:
|
||||
ldflags += " -g"
|
||||
n.variable("ldflags", ldflags)
|
||||
n.variable("mwcc_version", "1.3.2")
|
||||
n.variable("python", sys.executable)
|
||||
n.variable("mw_version", "1.3.2")
|
||||
if os.name == "nt":
|
||||
n.variable("exe", ".exe")
|
||||
exe = ".exe"
|
||||
wine = ""
|
||||
else:
|
||||
if "_NT-" in os.uname().sysname:
|
||||
# MSYS2
|
||||
n.variable("wine", "")
|
||||
wine = ""
|
||||
elif args.wine:
|
||||
n.variable("wine", args.wine + " ")
|
||||
wine = f"{args.wine} "
|
||||
elif which("wibo") is not None:
|
||||
n.variable("wine", "wibo ")
|
||||
wine = "wibo "
|
||||
else:
|
||||
n.variable("wine", "wine ")
|
||||
n.variable("exe", "")
|
||||
wine = "wine "
|
||||
exe = ""
|
||||
n.newline()
|
||||
|
||||
###
|
||||
# Tooling
|
||||
###
|
||||
n.comment("decomp-toolkit")
|
||||
|
||||
tools_path = Path("tools")
|
||||
build_tools_path = args.build_dir / "tools"
|
||||
|
||||
def path(input: list[Path] | Path | None) -> list[str] | None:
|
||||
if input is None:
|
||||
return None
|
||||
elif isinstance(input, list):
|
||||
return list(map(str, input))
|
||||
else:
|
||||
return [str(input)]
|
||||
|
||||
if args.build_dtk:
|
||||
dtk = build_tools_path / "release" / f"dtk{exe}"
|
||||
n.rule(
|
||||
name="cargo",
|
||||
command="cargo build --release --manifest-path $in --bin $bin --target-dir $target",
|
||||
description="CARGO $bin",
|
||||
depfile=path(Path("$target") / "release" / "$bin.d"),
|
||||
deps="gcc",
|
||||
)
|
||||
n.build(
|
||||
outputs=path(dtk),
|
||||
rule="cargo",
|
||||
inputs=path(args.build_dtk / "Cargo.toml"),
|
||||
variables={
|
||||
"bin": "dtk",
|
||||
"target": build_tools_path,
|
||||
},
|
||||
)
|
||||
else:
|
||||
dtk = build_tools_path / f"dtk{exe}"
|
||||
download_dtk = tools_path / "download_dtk.py"
|
||||
n.rule(
|
||||
name="download_dtk",
|
||||
command=f"$python {download_dtk} $in $out",
|
||||
description="DOWNLOAD $out",
|
||||
)
|
||||
n.build(
|
||||
outputs=path(dtk),
|
||||
rule="download_dtk",
|
||||
inputs="dtk_version",
|
||||
implicit=path([download_dtk]),
|
||||
)
|
||||
n.newline()
|
||||
|
||||
###
|
||||
# Rules
|
||||
###
|
||||
if os.name == "nt":
|
||||
mwcc_command = "tools\\mwcc_compiler\\$mwcc_version\\mwcceppc.exe $cflags -c $in -o $basedir"
|
||||
mwcc_frank_command = (
|
||||
ALLOW_CHAIN
|
||||
+ "tools\\mwcc_compiler\\$mwcc_version\\mwcceppc.exe $cflags -c $in -o $basedir && "
|
||||
+ "$python tools/franklite.py $out $out"
|
||||
)
|
||||
link_elf_command = "tools\\mwcc_compiler\\$mwcc_version\\mwldeppc.exe $ldflags -o $out @$out.rsp"
|
||||
assemble_asm_command = (
|
||||
ALLOW_CHAIN
|
||||
+ "$devkitppc\\bin\\powerpc-eabi-as.exe $asflags -o $out $in -MD $out.d"
|
||||
+ " && $dtk elf fixup $out $out"
|
||||
)
|
||||
compiler_path = args.compilers / "$mw_version"
|
||||
mwcc = compiler_path / "mwcceppc.exe"
|
||||
mwld = compiler_path / "mwldeppc.exe"
|
||||
franklite = tools_path / "franklite.py"
|
||||
gnu_as = dkp_path / "bin" / f"powerpc-eabi-as{exe}"
|
||||
|
||||
n.comment("Link ELF file")
|
||||
n.rule(
|
||||
name="link",
|
||||
command=link_elf_command,
|
||||
description="LINK $out",
|
||||
rspfile="$out.rsp",
|
||||
rspfile_content="$in",
|
||||
)
|
||||
n.newline()
|
||||
else:
|
||||
mwcc_command = "${wine}tools/mwcc_compiler/$mwcc_version/mwcceppc.exe $cflags -c $in -o $basedir && $python tools/transform-dep.py $basefile.d $basefile.d"
|
||||
mwcc_frank_command = (
|
||||
"${wine}tools/mwcc_compiler/$mwcc_version/mwcceppc.exe $cflags -c $in -o $basedir && "
|
||||
+ "$python tools/franklite.py $out $out && "
|
||||
+ "$python tools/transform-dep.py $basefile.d $basefile.d"
|
||||
)
|
||||
link_elf_command = "${wine}tools/mwcc_compiler/$mwcc_version/mwldeppc.exe $ldflags -o $out @$out.rsp"
|
||||
assemble_asm_command = (
|
||||
"$devkitppc/bin/powerpc-eabi-as $asflags -o $out $in -MD $out.d"
|
||||
+ " && $dtk elf fixup $out $out"
|
||||
)
|
||||
mwcc_cmd = f"{chain}{wine}{mwcc} $cflags -c $in -o $basedir"
|
||||
mwcc_frank_cmd = f"{mwcc_cmd} && $python {franklite} $out $out"
|
||||
mwld_cmd = f"{wine}{mwld} $ldflags -o $out @$out.rsp"
|
||||
as_cmd = (
|
||||
f"{chain}{gnu_as} $asflags -o $out $in -MD $out.d"
|
||||
+ f" && {dtk} elf fixup $out $out"
|
||||
)
|
||||
ar_cmd = f"{dtk} ar create $out @$out.rsp"
|
||||
|
||||
if os.name != "nt":
|
||||
transform_dep = tools_path / "transform-dep.py"
|
||||
transform_dep_cmd = f" && $python {transform_dep} $basefile.d $basefile.d"
|
||||
mwcc_cmd += transform_dep_cmd
|
||||
mwcc_frank_cmd += transform_dep_cmd
|
||||
|
||||
n.comment("Link ELF file")
|
||||
n.rule(
|
||||
name="link",
|
||||
command=mwld_cmd,
|
||||
description="LINK $out",
|
||||
rspfile="$out.rsp",
|
||||
rspfile_content="$in_newline",
|
||||
)
|
||||
n.newline()
|
||||
|
||||
n.comment("Link ELF file")
|
||||
n.rule(
|
||||
name="link",
|
||||
command=link_elf_command,
|
||||
description="LINK $out",
|
||||
rspfile="$out.rsp",
|
||||
rspfile_content="$in_newline",
|
||||
)
|
||||
n.newline()
|
||||
|
||||
n.comment("MWCC build")
|
||||
n.rule(
|
||||
name="mwcc",
|
||||
command=mwcc_command,
|
||||
command=mwcc_cmd,
|
||||
description="MWCC $out",
|
||||
depfile="$basefile.d",
|
||||
deps="gcc",
|
||||
|
@ -1231,17 +1289,17 @@ if __name__ == "__main__":
|
|||
n.comment("MWCC build with franklite")
|
||||
n.rule(
|
||||
name="mwcc_frank",
|
||||
command=mwcc_frank_command,
|
||||
command=mwcc_frank_cmd,
|
||||
description="FRANK $out",
|
||||
depfile="$basefile.d",
|
||||
deps="gcc",
|
||||
)
|
||||
n.newline()
|
||||
|
||||
|
||||
n.comment("Assemble asm")
|
||||
n.rule(
|
||||
name="as",
|
||||
command=assemble_asm_command,
|
||||
command=as_cmd,
|
||||
description="AS $out",
|
||||
depfile="$out.d",
|
||||
deps="gcc",
|
||||
|
@ -1251,7 +1309,7 @@ if __name__ == "__main__":
|
|||
n.comment("Create static library")
|
||||
n.rule(
|
||||
name="ar",
|
||||
command="$dtk ar create $out @$out.rsp",
|
||||
command=ar_cmd,
|
||||
description="AR $out",
|
||||
rspfile="$out.rsp",
|
||||
rspfile_content="$in_newline",
|
||||
|
@ -1259,65 +1317,37 @@ if __name__ == "__main__":
|
|||
n.newline()
|
||||
|
||||
n.comment("Host build")
|
||||
n.variable("host_cflags", "-I include/ -Wno-trigraphs")
|
||||
n.variable("host_cflags", "-I include -Wno-trigraphs")
|
||||
n.variable(
|
||||
"host_cppflags",
|
||||
"-std=c++98 -I include/ -fno-exceptions -fno-rtti -D_CRT_SECURE_NO_WARNINGS -Wno-trigraphs -Wno-c++11-extensions",
|
||||
"-std=c++98 -I include -fno-exceptions -fno-rtti -D_CRT_SECURE_NO_WARNINGS -Wno-trigraphs -Wno-c++11-extensions",
|
||||
)
|
||||
n.rule(
|
||||
name="host_cc",
|
||||
command="clang $host_cflags -c -o $out $in",
|
||||
description="host_cc $out",
|
||||
description="CC $out",
|
||||
)
|
||||
n.rule(
|
||||
name="host_cpp",
|
||||
command="clang++ $host_cppflags -c -o $out $in",
|
||||
description="host_c++ $out",
|
||||
description="CXX $out",
|
||||
)
|
||||
n.newline()
|
||||
|
||||
###
|
||||
# Tooling
|
||||
###
|
||||
n.comment("decomp-toolkit")
|
||||
if args.build_dtk:
|
||||
n.variable("dtk", os.path.join("build", "tools", "release", "dtk$exe"))
|
||||
n.rule(
|
||||
name="cargo",
|
||||
command="cargo build --release --manifest-path $in --bin $bin --target-dir $target",
|
||||
description="CARGO $bin",
|
||||
depfile="$target/release/$bin.d",
|
||||
deps="gcc",
|
||||
)
|
||||
n.build(
|
||||
outputs="$dtk",
|
||||
rule="cargo",
|
||||
inputs=os.path.join(args.build_dtk, "Cargo.toml"),
|
||||
variables={
|
||||
"bin": "dtk",
|
||||
"target": os.path.join("build", "tools"),
|
||||
},
|
||||
)
|
||||
else:
|
||||
n.variable("dtk", os.path.join("build", "tools", "dtk$exe"))
|
||||
n.rule(
|
||||
name="download_dtk",
|
||||
command="$python tools/download_dtk.py $in $out",
|
||||
description="DOWNLOAD $out",
|
||||
)
|
||||
n.build(
|
||||
outputs="$dtk",
|
||||
rule="download_dtk",
|
||||
inputs="dtk_version",
|
||||
implicit=["tools/download_dtk.py"],
|
||||
)
|
||||
|
||||
###
|
||||
# Rules for source files
|
||||
###
|
||||
n.comment("Source files")
|
||||
all_source_files = []
|
||||
all_host_source_files = []
|
||||
src_path = Path("src")
|
||||
asm_path = Path("asm")
|
||||
build_src_path = build_path / "src"
|
||||
build_host_path = build_path / "host"
|
||||
build_asm_path = build_path / "asm"
|
||||
build_lib_path = build_path / "lib"
|
||||
|
||||
source_inputs = []
|
||||
host_source_inputs = []
|
||||
link_inputs = []
|
||||
for lib in LIBS:
|
||||
inputs = []
|
||||
if "lib" in lib:
|
||||
|
@ -1325,6 +1355,7 @@ if __name__ == "__main__":
|
|||
n.comment(f"{lib_name}.a")
|
||||
else:
|
||||
n.comment("Loose files")
|
||||
|
||||
for object in lib["objects"]:
|
||||
completed = None
|
||||
add_to_all = True
|
||||
|
@ -1337,104 +1368,85 @@ if __name__ == "__main__":
|
|||
completed = object[1]
|
||||
object = object[0]
|
||||
|
||||
mwcc_version = lib["mwcc_version"]
|
||||
mw_version = lib["mw_version"]
|
||||
c_file = None
|
||||
if os.path.exists(os.path.join("src", f"{object}.cpp")):
|
||||
c_file = os.path.join("src", f"{object}.cpp")
|
||||
elif os.path.exists(os.path.join("src", f"{object}.c")):
|
||||
c_file = os.path.join("src", f"{object}.c")
|
||||
if os.path.exists(src_path / f"{object}.cpp"):
|
||||
c_file = src_path / f"{object}.cpp"
|
||||
elif os.path.exists(src_path / f"{object}.c"):
|
||||
c_file = src_path / f"{object}.c"
|
||||
if c_file is not None:
|
||||
if completed is None:
|
||||
print(f"Mark as incomplete: {c_file}")
|
||||
rule = "mwcc"
|
||||
if mwcc_version == "1.2.5e":
|
||||
mwcc_version = "1.2.5"
|
||||
if mw_version == "1.2.5e":
|
||||
mw_version = "1.2.5"
|
||||
if no_frank is False:
|
||||
rule = "mwcc_frank"
|
||||
n.build(
|
||||
outputs=f"$builddir/src/{object}.o",
|
||||
outputs=path(build_src_path / f"{object}.o"),
|
||||
rule=rule,
|
||||
inputs=c_file,
|
||||
inputs=path(c_file),
|
||||
variables={
|
||||
"mwcc_version": mwcc_version,
|
||||
"mw_version": mw_version,
|
||||
"cflags": lib["cflags"],
|
||||
"basedir": os.path.dirname(f"$builddir/src/{object}"),
|
||||
"basefile": f"$builddir/src/{object}",
|
||||
"basedir": os.path.dirname(build_src_path / f"{object}"),
|
||||
"basefile": path(build_src_path / f"{object}"),
|
||||
},
|
||||
)
|
||||
if lib["host"]:
|
||||
n.build(
|
||||
outputs=f"$builddir/host/{object}.o",
|
||||
rule="host_cc" if c_file.endswith(".c") else "host_cpp",
|
||||
inputs=c_file,
|
||||
outputs=path(build_host_path / f"{object}.o"),
|
||||
rule="host_cc" if c_file.suffix == ".c" else "host_cpp",
|
||||
inputs=path(c_file),
|
||||
variables={
|
||||
"basedir": os.path.dirname(f"$builddir/src/{object}"),
|
||||
"basefile": f"$builddir/src/{object}",
|
||||
"basedir": os.path.dirname(build_host_path / object),
|
||||
"basefile": path(build_host_path / object),
|
||||
},
|
||||
)
|
||||
n.build(
|
||||
outputs=f"host/{c_file}",
|
||||
rule="phony",
|
||||
inputs=f"$builddir/host/{object}.o",
|
||||
)
|
||||
if add_to_all:
|
||||
all_host_source_files.append(f"$builddir/host/{object}.o")
|
||||
host_source_inputs.append(build_host_path / f"{object}.o")
|
||||
if add_to_all:
|
||||
all_source_files.append(f"$builddir/src/{object}.o")
|
||||
if os.path.exists(os.path.join("asm", f"{object}.s")):
|
||||
source_inputs.append(build_src_path / f"{object}.o")
|
||||
if os.path.exists(asm_path / f"{object}.s"):
|
||||
n.build(
|
||||
outputs=f"$builddir/asm/{object}.o",
|
||||
outputs=path(build_asm_path / f"{object}.o"),
|
||||
rule="as",
|
||||
inputs=f"asm/{object}.s",
|
||||
implicit="$dtk",
|
||||
inputs=path(asm_path / f"{object}.s"),
|
||||
implicit=path(dtk),
|
||||
)
|
||||
if completed:
|
||||
inputs.append(f"$builddir/src/{object}.o")
|
||||
inputs.append(build_src_path / f"{object}.o")
|
||||
else:
|
||||
inputs.append(f"$builddir/asm/{object}.o")
|
||||
inputs.append(build_asm_path / f"{object}.o")
|
||||
if args.static_libs and "lib" in lib:
|
||||
lib_name = lib["lib"]
|
||||
n.build(
|
||||
outputs=f"$builddir/lib/{lib_name}.a",
|
||||
outputs=path(build_lib_path / f"{lib_name}.a"),
|
||||
rule="ar",
|
||||
inputs=inputs,
|
||||
implicit="$dtk",
|
||||
inputs=path(inputs),
|
||||
implicit=path(dtk),
|
||||
)
|
||||
link_inputs.append(build_lib_path / f"{lib_name}.a")
|
||||
else:
|
||||
link_inputs.extend(inputs)
|
||||
n.newline()
|
||||
|
||||
###
|
||||
# Link
|
||||
###
|
||||
n.comment("Link")
|
||||
inputs = []
|
||||
for lib in LIBS:
|
||||
if args.static_libs and "lib" in lib:
|
||||
lib_name = lib["lib"]
|
||||
inputs.append(f"$builddir/lib/{lib_name}.a")
|
||||
else:
|
||||
for object in lib["objects"]:
|
||||
completed = False
|
||||
|
||||
if type(object) is list:
|
||||
completed = object[1]
|
||||
object = object[0]
|
||||
|
||||
if completed:
|
||||
inputs.append(f"$builddir/src/{object}.o")
|
||||
else:
|
||||
inputs.append(f"$builddir/asm/{object}.o")
|
||||
if args.map:
|
||||
n.build(
|
||||
outputs="$builddir/main.elf",
|
||||
outputs=path(build_path / "main.elf"),
|
||||
rule="link",
|
||||
inputs=inputs,
|
||||
implicit_outputs="$builddir/MetroidPrime.MAP",
|
||||
inputs=path(link_inputs),
|
||||
implicit_outputs=path(map_path),
|
||||
)
|
||||
else:
|
||||
n.build(
|
||||
outputs="$builddir/main.elf",
|
||||
outputs=path(build_path / "main.elf"),
|
||||
rule="link",
|
||||
inputs=inputs,
|
||||
inputs=path(link_inputs),
|
||||
)
|
||||
n.newline()
|
||||
|
||||
|
@ -1445,7 +1457,7 @@ if __name__ == "__main__":
|
|||
n.build(
|
||||
outputs="all_source",
|
||||
rule="phony",
|
||||
inputs=all_source_files,
|
||||
inputs=path(source_inputs),
|
||||
)
|
||||
n.newline()
|
||||
|
||||
|
@ -1456,7 +1468,7 @@ if __name__ == "__main__":
|
|||
n.build(
|
||||
outputs="all_source_host",
|
||||
rule="phony",
|
||||
inputs=all_host_source_files,
|
||||
inputs=path(host_source_inputs),
|
||||
)
|
||||
n.newline()
|
||||
|
||||
|
@ -1466,16 +1478,16 @@ if __name__ == "__main__":
|
|||
n.comment("Generate DOL")
|
||||
n.rule(
|
||||
name="elf2dol",
|
||||
command=ALLOW_CHAIN
|
||||
+ "$dtk elf2dol $in $out && "
|
||||
+ "$dtk metroidbuildinfo $out buildstrings/mp1.$version.build",
|
||||
command=chain
|
||||
+ f"{dtk} elf2dol $in $out && "
|
||||
+ f"{dtk} metroidbuildinfo $out buildstrings/mp1.{version}.build",
|
||||
description="DOL $out",
|
||||
)
|
||||
n.build(
|
||||
outputs="$builddir/main.dol",
|
||||
outputs=path(build_path / "main.dol"),
|
||||
rule="elf2dol",
|
||||
inputs="$builddir/main.elf",
|
||||
implicit="$dtk",
|
||||
inputs=path(build_path / "main.elf"),
|
||||
implicit=path(dtk),
|
||||
)
|
||||
n.newline()
|
||||
|
||||
|
@ -1486,14 +1498,14 @@ if __name__ == "__main__":
|
|||
n.comment("Check DOL hash")
|
||||
n.rule(
|
||||
name="check",
|
||||
command="$dtk shasum -c $in -o $out",
|
||||
command=f"{dtk} shasum -c $in -o $out",
|
||||
description="CHECK $in",
|
||||
)
|
||||
n.build(
|
||||
outputs="$builddir/main.dol.ok",
|
||||
outputs=path(build_path / "main.dol.ok"),
|
||||
rule="check",
|
||||
inputs="sha1/mp1.$version.sha1",
|
||||
implicit=["$builddir/main.dol", "$dtk"],
|
||||
inputs=f"sha1/mp1.{version}.sha1",
|
||||
implicit=path([build_path / "main.dol", dtk]),
|
||||
)
|
||||
n.newline()
|
||||
|
||||
|
@ -1508,9 +1520,9 @@ if __name__ == "__main__":
|
|||
description="PROGRESS $in",
|
||||
)
|
||||
n.build(
|
||||
outputs="$builddir/main.dol.progress",
|
||||
outputs=path(build_path / "main.dol.progress"),
|
||||
rule="progress",
|
||||
inputs=["$builddir/main.dol", "$builddir/MetroidPrime.MAP"],
|
||||
inputs=path([build_path / "main.dol", map_path]),
|
||||
implicit="progress.py",
|
||||
)
|
||||
n.newline()
|
||||
|
@ -1536,13 +1548,13 @@ if __name__ == "__main__":
|
|||
###
|
||||
n.comment("Default rule")
|
||||
if args.check:
|
||||
dol_out = "$builddir/main.dol.ok"
|
||||
dol_out = build_path / "main.dol.ok"
|
||||
else:
|
||||
dol_out = "$builddir/main.dol"
|
||||
dol_out = build_path / "main.dol"
|
||||
if args.map:
|
||||
n.default([dol_out, "$builddir/main.dol.progress"])
|
||||
n.default(path([dol_out, build_path / "main.dol.progress"]))
|
||||
else:
|
||||
n.default([dol_out])
|
||||
n.default(path([dol_out]))
|
||||
|
||||
with open("build.ninja", "w") as f:
|
||||
f.write(out.getvalue())
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
#!/bin/bash -e
|
||||
VERSION="${VERSION:=0}"
|
||||
OBJDUMP="$DEVKITPPC/bin/powerpc-eabi-objdump -D -bbinary -EB -mpowerpc -M gekko"
|
||||
OBJDUMP="$DEVKITPPC/bin/powerpc-eabi-objdump -Dz -bbinary -EB -mpowerpc -M gekko"
|
||||
if [ ! -z "$1" ]; then
|
||||
OPTIONS="--start-address=$(($1)) --stop-address=$(($2))"
|
||||
fi
|
||||
|
|
Loading…
Reference in New Issue