Compare commits
2 Commits
3be5e73054
...
bc31a5b90d
Author | SHA1 | Date |
---|---|---|
Luke Street | bc31a5b90d | |
Luke Street | 1bcf33638f |
|
@ -9,5 +9,5 @@
|
||||||
*.sh text eol=lf
|
*.sh text eol=lf
|
||||||
*.sha1 text eol=lf
|
*.sha1 text eol=lf
|
||||||
|
|
||||||
# DTK keeps these files with LF
|
# decomp-toolkit writes files with LF
|
||||||
config/**/*.txt text eol=lf
|
config/**/*.txt text eol=lf
|
||||||
|
|
|
@ -9,3 +9,4 @@ objdiff.json
|
||||||
orig/*/*
|
orig/*/*
|
||||||
!orig/*/.gitkeep
|
!orig/*/.gitkeep
|
||||||
/*.txt
|
/*.txt
|
||||||
|
ctx.c
|
||||||
|
|
129
LICENSE
129
LICENSE
|
@ -1,21 +1,116 @@
|
||||||
MIT License
|
CC0 1.0 Universal
|
||||||
|
|
||||||
Copyright (c) 2023 Luke Street
|
Statement of Purpose
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
The laws of most jurisdictions throughout the world automatically confer
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
exclusive Copyright and Related Rights (defined below) upon the creator and
|
||||||
in the Software without restriction, including without limitation the rights
|
subsequent owner(s) (each and all, an "owner") of an original work of
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
authorship and/or a database (each, a "Work").
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
Certain owners wish to permanently relinquish those rights to a Work for the
|
||||||
copies or substantial portions of the Software.
|
purpose of contributing to a commons of creative, cultural and scientific
|
||||||
|
works ("Commons") that the public can reliably and without fear of later
|
||||||
|
claims of infringement build upon, modify, incorporate in other works, reuse
|
||||||
|
and redistribute as freely as possible in any form whatsoever and for any
|
||||||
|
purposes, including without limitation commercial purposes. These owners may
|
||||||
|
contribute to the Commons to promote the ideal of a free culture and the
|
||||||
|
further production of creative, cultural and scientific works, or to gain
|
||||||
|
reputation or greater distribution for their Work in part through the use and
|
||||||
|
efforts of others.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
For these and/or other purposes and motivations, and without any expectation
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
of additional consideration or compensation, the person associating CC0 with a
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
Work (the "Affirmer"), to the extent that he or she is an owner of Copyright
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
and Related Rights in the Work, voluntarily elects to apply CC0 to the Work
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
and publicly distribute the Work under its terms, with knowledge of his or her
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
Copyright and Related Rights in the Work and the meaning and intended legal
|
||||||
SOFTWARE.
|
effect of CC0 on those rights.
|
||||||
|
|
||||||
|
1. Copyright and Related Rights. A Work made available under CC0 may be
|
||||||
|
protected by copyright and related or neighboring rights ("Copyright and
|
||||||
|
Related Rights"). Copyright and Related Rights include, but are not limited
|
||||||
|
to, the following:
|
||||||
|
|
||||||
|
i. the right to reproduce, adapt, distribute, perform, display, communicate,
|
||||||
|
and translate a Work;
|
||||||
|
|
||||||
|
ii. moral rights retained by the original author(s) and/or performer(s);
|
||||||
|
|
||||||
|
iii. publicity and privacy rights pertaining to a person's image or likeness
|
||||||
|
depicted in a Work;
|
||||||
|
|
||||||
|
iv. rights protecting against unfair competition in regards to a Work,
|
||||||
|
subject to the limitations in paragraph 4(a), below;
|
||||||
|
|
||||||
|
v. rights protecting the extraction, dissemination, use and reuse of data in
|
||||||
|
a Work;
|
||||||
|
|
||||||
|
vi. database rights (such as those arising under Directive 96/9/EC of the
|
||||||
|
European Parliament and of the Council of 11 March 1996 on the legal
|
||||||
|
protection of databases, and under any national implementation thereof,
|
||||||
|
including any amended or successor version of such directive); and
|
||||||
|
|
||||||
|
vii. other similar, equivalent or corresponding rights throughout the world
|
||||||
|
based on applicable law or treaty, and any national implementations thereof.
|
||||||
|
|
||||||
|
2. Waiver. To the greatest extent permitted by, but not in contravention of,
|
||||||
|
applicable law, Affirmer hereby overtly, fully, permanently, irrevocably and
|
||||||
|
unconditionally waives, abandons, and surrenders all of Affirmer's Copyright
|
||||||
|
and Related Rights and associated claims and causes of action, whether now
|
||||||
|
known or unknown (including existing as well as future claims and causes of
|
||||||
|
action), in the Work (i) in all territories worldwide, (ii) for the maximum
|
||||||
|
duration provided by applicable law or treaty (including future time
|
||||||
|
extensions), (iii) in any current or future medium and for any number of
|
||||||
|
copies, and (iv) for any purpose whatsoever, including without limitation
|
||||||
|
commercial, advertising or promotional purposes (the "Waiver"). Affirmer makes
|
||||||
|
the Waiver for the benefit of each member of the public at large and to the
|
||||||
|
detriment of Affirmer's heirs and successors, fully intending that such Waiver
|
||||||
|
shall not be subject to revocation, rescission, cancellation, termination, or
|
||||||
|
any other legal or equitable action to disrupt the quiet enjoyment of the Work
|
||||||
|
by the public as contemplated by Affirmer's express Statement of Purpose.
|
||||||
|
|
||||||
|
3. Public License Fallback. Should any part of the Waiver for any reason be
|
||||||
|
judged legally invalid or ineffective under applicable law, then the Waiver
|
||||||
|
shall be preserved to the maximum extent permitted taking into account
|
||||||
|
Affirmer's express Statement of Purpose. In addition, to the extent the Waiver
|
||||||
|
is so judged Affirmer hereby grants to each affected person a royalty-free,
|
||||||
|
non transferable, non sublicensable, non exclusive, irrevocable and
|
||||||
|
unconditional license to exercise Affirmer's Copyright and Related Rights in
|
||||||
|
the Work (i) in all territories worldwide, (ii) for the maximum duration
|
||||||
|
provided by applicable law or treaty (including future time extensions), (iii)
|
||||||
|
in any current or future medium and for any number of copies, and (iv) for any
|
||||||
|
purpose whatsoever, including without limitation commercial, advertising or
|
||||||
|
promotional purposes (the "License"). The License shall be deemed effective as
|
||||||
|
of the date CC0 was applied by Affirmer to the Work. Should any part of the
|
||||||
|
License for any reason be judged legally invalid or ineffective under
|
||||||
|
applicable law, such partial invalidity or ineffectiveness shall not
|
||||||
|
invalidate the remainder of the License, and in such case Affirmer hereby
|
||||||
|
affirms that he or she will not (i) exercise any of his or her remaining
|
||||||
|
Copyright and Related Rights in the Work or (ii) assert any associated claims
|
||||||
|
and causes of action with respect to the Work, in either case contrary to
|
||||||
|
Affirmer's express Statement of Purpose.
|
||||||
|
|
||||||
|
4. Limitations and Disclaimers.
|
||||||
|
|
||||||
|
a. No trademark or patent rights held by Affirmer are waived, abandoned,
|
||||||
|
surrendered, licensed or otherwise affected by this document.
|
||||||
|
|
||||||
|
b. Affirmer offers the Work as-is and makes no representations or warranties
|
||||||
|
of any kind concerning the Work, express, implied, statutory or otherwise,
|
||||||
|
including without limitation warranties of title, merchantability, fitness
|
||||||
|
for a particular purpose, non infringement, or the absence of latent or
|
||||||
|
other defects, accuracy, or the present or absence of errors, whether or not
|
||||||
|
discoverable, all to the greatest extent permissible under applicable law.
|
||||||
|
|
||||||
|
c. Affirmer disclaims responsibility for clearing rights of other persons
|
||||||
|
that may apply to the Work or any use thereof, including without limitation
|
||||||
|
any person's Copyright and Related Rights in the Work. Further, Affirmer
|
||||||
|
disclaims responsibility for obtaining any necessary consents, permissions
|
||||||
|
or other rights required for any use of the Work.
|
||||||
|
|
||||||
|
d. Affirmer understands and acknowledges that Creative Commons is not a
|
||||||
|
party to this document and has no duty or obligation with respect to this
|
||||||
|
CC0 or use of the Work.
|
||||||
|
|
||||||
|
For more information, please see
|
||||||
|
<http://creativecommons.org/publicdomain/zero/1.0/>
|
||||||
|
|
|
@ -29,10 +29,16 @@ References
|
||||||
|
|
||||||
Projects using this structure:
|
Projects using this structure:
|
||||||
- [zeldaret/tww](https://github.com/zeldaret/tww)
|
- [zeldaret/tww](https://github.com/zeldaret/tww)
|
||||||
|
- [PrimeDecomp/prime](https://github.com/PrimeDecomp/prime)
|
||||||
- [PrimeDecomp/echoes](https://github.com/PrimeDecomp/echoes)
|
- [PrimeDecomp/echoes](https://github.com/PrimeDecomp/echoes)
|
||||||
- [DarkRTA/rb3](https://github.com/DarkRTA/rb3)
|
- [DarkRTA/rb3](https://github.com/DarkRTA/rb3)
|
||||||
|
- [InputEvelution/sadx-dtk](https://github.com/InputEvelution/sadx-dtk)
|
||||||
- [InputEvelution/wp](https://github.com/InputEvelution/wp)
|
- [InputEvelution/wp](https://github.com/InputEvelution/wp)
|
||||||
|
- [lepelog/ss-dtk](https://github.com/lepelog/ss-dtk)
|
||||||
|
- [NWPlayer123/AnimalCrossing-dtk](https://github.com/NWPlayer123/AnimalCrossing-dtk)
|
||||||
|
- [Rainchus/mp4-dtk](https://github.com/Rainchus/mp4-dtk)
|
||||||
- [Rainchus/ttyd_dtk](https://github.com/Rainchus/ttyd_dtk)
|
- [Rainchus/ttyd_dtk](https://github.com/Rainchus/ttyd_dtk)
|
||||||
|
- [Sage-of-Mirrors/zmansion](https://github.com/Sage-of-Mirrors/zmansion)
|
||||||
|
|
||||||
Features
|
Features
|
||||||
--------
|
--------
|
||||||
|
@ -63,3 +69,4 @@ Temporary, delete when done:
|
||||||
- `config/GAMEID/config.example.yml` - Example configuration file and documentation.
|
- `config/GAMEID/config.example.yml` - Example configuration file and documentation.
|
||||||
- `docs/` - Documentation for decomp-toolkit configuration.
|
- `docs/` - Documentation for decomp-toolkit configuration.
|
||||||
- `README.md` - This file, replace with your own. For a template, see [`README.example.md`](README.example.md).
|
- `README.md` - This file, replace with your own. For a template, see [`README.example.md`](README.example.md).
|
||||||
|
- `LICENSE` - This repository is licensed under the CC0 license. Replace with your own if desired.
|
||||||
|
|
17
configure.py
17
configure.py
|
@ -117,10 +117,10 @@ if not is_windows():
|
||||||
config.wrapper = args.wrapper
|
config.wrapper = args.wrapper
|
||||||
|
|
||||||
# Tool versions
|
# Tool versions
|
||||||
config.compilers_tag = "20230715"
|
config.compilers_tag = "20231018"
|
||||||
config.dtk_tag = "v0.5.7"
|
config.dtk_tag = "v0.6.0"
|
||||||
config.sjiswrap_tag = "v1.1.1"
|
config.sjiswrap_tag = "v1.1.1"
|
||||||
config.wibo_tag = "0.6.3"
|
config.wibo_tag = "0.6.9"
|
||||||
|
|
||||||
# Project
|
# Project
|
||||||
config.config_path = Path("config") / config.version / "config.yml"
|
config.config_path = Path("config") / config.version / "config.yml"
|
||||||
|
@ -128,7 +128,7 @@ config.check_sha_path = Path("config") / config.version / "build.sha1"
|
||||||
config.ldflags = [
|
config.ldflags = [
|
||||||
"-fp hardware",
|
"-fp hardware",
|
||||||
"-nodefaults",
|
"-nodefaults",
|
||||||
"-listclosure",
|
# "-listclosure", # Uncomment for Wii linkers
|
||||||
]
|
]
|
||||||
|
|
||||||
# Base flags, common to most GC/Wii games.
|
# Base flags, common to most GC/Wii games.
|
||||||
|
@ -151,8 +151,7 @@ cflags_base = [
|
||||||
"-fp_contract on",
|
"-fp_contract on",
|
||||||
"-str reuse",
|
"-str reuse",
|
||||||
"-i include",
|
"-i include",
|
||||||
"-i libc",
|
"-multibyte", # For Wii compilers, replace with `-enc SJIS`
|
||||||
"-enc SJIS",
|
|
||||||
f"-DVERSION={version_num}",
|
f"-DVERSION={version_num}",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -179,14 +178,14 @@ cflags_rel = [
|
||||||
"-sdata2 0",
|
"-sdata2 0",
|
||||||
]
|
]
|
||||||
|
|
||||||
config.linker_version = "Wii/1.3"
|
config.linker_version = "GC/1.3.2"
|
||||||
|
|
||||||
|
|
||||||
# Helper function for Dolphin libraries
|
# Helper function for Dolphin libraries
|
||||||
def DolphinLib(lib_name, objects):
|
def DolphinLib(lib_name, objects):
|
||||||
return {
|
return {
|
||||||
"lib": lib_name,
|
"lib": lib_name,
|
||||||
"mw_version": "Wii/1.1",
|
"mw_version": "GC/1.2.5n",
|
||||||
"cflags": cflags_base,
|
"cflags": cflags_base,
|
||||||
"host": False,
|
"host": False,
|
||||||
"objects": objects,
|
"objects": objects,
|
||||||
|
@ -197,7 +196,7 @@ def DolphinLib(lib_name, objects):
|
||||||
def Rel(lib_name, objects):
|
def Rel(lib_name, objects):
|
||||||
return {
|
return {
|
||||||
"lib": lib_name,
|
"lib": lib_name,
|
||||||
"mw_version": "Wii/1.3",
|
"mw_version": "GC/1.3.2",
|
||||||
"cflags": cflags_rel,
|
"cflags": cflags_rel,
|
||||||
"host": True,
|
"host": True,
|
||||||
"objects": objects,
|
"objects": objects,
|
||||||
|
|
|
@ -16,7 +16,6 @@ import os
|
||||||
import platform
|
import platform
|
||||||
import shutil
|
import shutil
|
||||||
import stat
|
import stat
|
||||||
import sys
|
|
||||||
import urllib.request
|
import urllib.request
|
||||||
import zipfile
|
import zipfile
|
||||||
|
|
||||||
|
@ -52,6 +51,7 @@ def wibo_url(tag):
|
||||||
def compilers_url(tag):
|
def compilers_url(tag):
|
||||||
return f"https://files.decomp.dev/compilers_{tag}.zip"
|
return f"https://files.decomp.dev/compilers_{tag}.zip"
|
||||||
|
|
||||||
|
|
||||||
TOOLS = {
|
TOOLS = {
|
||||||
"dtk": dtk_url,
|
"dtk": dtk_url,
|
||||||
"sjiswrap": sjiswrap_url,
|
"sjiswrap": sjiswrap_url,
|
||||||
|
|
|
@ -56,13 +56,13 @@ class ProjectConfig:
|
||||||
self.version = None # Version name
|
self.version = None # Version name
|
||||||
self.warn_missing_config = False # Warn on missing unit configuration
|
self.warn_missing_config = False # Warn on missing unit configuration
|
||||||
self.warn_missing_source = False # Warn on missing source file
|
self.warn_missing_source = False # Warn on missing source file
|
||||||
|
self.rel_strip_partial = True # Generate PLFs with -strip_partial
|
||||||
|
self.rel_empty_file = None # Path to empty.c for generating empty RELs
|
||||||
|
|
||||||
# Progress output and progress.json config
|
# Progress output and progress.json config
|
||||||
self.progress_all = True # Include combined "all" category
|
self.progress_all = True # Include combined "all" category
|
||||||
self.progress_modules = True # Include combined "modules" category
|
self.progress_modules = True # Include combined "modules" category
|
||||||
self.progress_each_module = (
|
self.progress_each_module = True # Include individual modules, disable for large numbers of modules
|
||||||
True # Include individual modules, disable for large numbers of modules
|
|
||||||
)
|
|
||||||
|
|
||||||
def validate(self):
|
def validate(self):
|
||||||
required_attrs = [
|
required_attrs = [
|
||||||
|
@ -98,6 +98,7 @@ class Object:
|
||||||
self.options = {
|
self.options = {
|
||||||
"add_to_all": True,
|
"add_to_all": True,
|
||||||
"cflags": None,
|
"cflags": None,
|
||||||
|
"extra_cflags": None,
|
||||||
"mw_version": None,
|
"mw_version": None,
|
||||||
"shiftjis": True,
|
"shiftjis": True,
|
||||||
"source": name,
|
"source": name,
|
||||||
|
@ -461,7 +462,12 @@ def generate_build_ninja(config, build_config):
|
||||||
preplf_path = build_path / self.name / f"{self.name}.preplf"
|
preplf_path = build_path / self.name / f"{self.name}.preplf"
|
||||||
plf_path = build_path / self.name / f"{self.name}.plf"
|
plf_path = build_path / self.name / f"{self.name}.plf"
|
||||||
preplf_ldflags = f"$ldflags -sdata 0 -sdata2 0 -r"
|
preplf_ldflags = f"$ldflags -sdata 0 -sdata2 0 -r"
|
||||||
plf_ldflags = f"$ldflags -sdata 0 -sdata2 0 -m {self.entry} -r1 -strip_partial -lcf {self.ldscript}"
|
plf_ldflags = f"$ldflags -sdata 0 -sdata2 0 -r1 -lcf {self.ldscript}"
|
||||||
|
if self.entry:
|
||||||
|
plf_ldflags += f" -m {self.entry}"
|
||||||
|
# -strip_partial is only valid with -m
|
||||||
|
if config.rel_strip_partial:
|
||||||
|
plf_ldflags += " -strip_partial"
|
||||||
if config.generate_map:
|
if config.generate_map:
|
||||||
preplf_map = map_path(preplf_path)
|
preplf_map = map_path(preplf_path)
|
||||||
preplf_ldflags += f" -map {preplf_map}"
|
preplf_ldflags += f" -map {preplf_map}"
|
||||||
|
@ -495,6 +501,12 @@ def generate_build_ninja(config, build_config):
|
||||||
host_source_inputs = []
|
host_source_inputs = []
|
||||||
source_added = set()
|
source_added = set()
|
||||||
|
|
||||||
|
def make_cflags_str(cflags):
|
||||||
|
if isinstance(cflags, list):
|
||||||
|
return " ".join(cflags)
|
||||||
|
else:
|
||||||
|
return cflags
|
||||||
|
|
||||||
def add_unit(build_obj, link_step):
|
def add_unit(build_obj, link_step):
|
||||||
obj_path, obj_name = build_obj["object"], build_obj["name"]
|
obj_path, obj_name = build_obj["object"], build_obj["name"]
|
||||||
result = config.find_object(obj_name)
|
result = config.find_object(obj_name)
|
||||||
|
@ -512,17 +524,16 @@ def generate_build_ninja(config, build_config):
|
||||||
|
|
||||||
unit_src_path = config.src_dir / options["source"]
|
unit_src_path = config.src_dir / options["source"]
|
||||||
if not unit_src_path.exists():
|
if not unit_src_path.exists():
|
||||||
if config.warn_missing_source:
|
if config.warn_missing_source or completed:
|
||||||
print(f"Missing source file {unit_src_path}")
|
print(f"Missing source file {unit_src_path}")
|
||||||
link_step.add(obj_path)
|
link_step.add(obj_path)
|
||||||
return
|
return
|
||||||
|
|
||||||
mw_version = options["mw_version"] or lib["mw_version"]
|
mw_version = options["mw_version"] or lib["mw_version"]
|
||||||
cflags = options["cflags"] or lib["cflags"]
|
cflags_str = make_cflags_str(options["cflags"] or lib["cflags"])
|
||||||
if type(cflags) is list:
|
if options["extra_cflags"] is not None:
|
||||||
cflags_str = " ".join(cflags)
|
extra_cflags_str = make_cflags_str(options["extra_cflags"])
|
||||||
else:
|
cflags_str += " " + extra_cflags_str
|
||||||
cflags_str = str(cflags)
|
|
||||||
used_compiler_versions.add(mw_version)
|
used_compiler_versions.add(mw_version)
|
||||||
|
|
||||||
base_object = Path(obj.name).with_suffix("")
|
base_object = Path(obj.name).with_suffix("")
|
||||||
|
@ -583,6 +594,18 @@ def generate_build_ninja(config, build_config):
|
||||||
module_link_step = LinkStep(module)
|
module_link_step = LinkStep(module)
|
||||||
for unit in module["units"]:
|
for unit in module["units"]:
|
||||||
add_unit(unit, module_link_step)
|
add_unit(unit, module_link_step)
|
||||||
|
# Add empty object to empty RELs
|
||||||
|
if len(module_link_step.inputs) == 0:
|
||||||
|
if not config.rel_empty_file:
|
||||||
|
sys.exit("ProjectConfig.rel_empty_file missing")
|
||||||
|
add_unit(
|
||||||
|
{
|
||||||
|
"object": None,
|
||||||
|
"name": config.rel_empty_file,
|
||||||
|
"autogenerated": True,
|
||||||
|
},
|
||||||
|
module_link_step,
|
||||||
|
)
|
||||||
link_steps.append(module_link_step)
|
link_steps.append(module_link_step)
|
||||||
n.newline()
|
n.newline()
|
||||||
|
|
||||||
|
@ -607,18 +630,41 @@ def generate_build_ninja(config, build_config):
|
||||||
###
|
###
|
||||||
# Generate RELs
|
# Generate RELs
|
||||||
###
|
###
|
||||||
rel_outputs = list(
|
generated_rels = []
|
||||||
map(
|
for link in build_config["links"]:
|
||||||
lambda step: step.output(),
|
# Map module names to link steps
|
||||||
filter(lambda step: step.module_id != 0, link_steps),
|
link_steps_local = list(
|
||||||
|
filter(
|
||||||
|
lambda step: step.name in link["modules"],
|
||||||
|
link_steps,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
link_steps_local.sort(key=lambda step: step.module_id)
|
||||||
|
# RELs can be the output of multiple link steps,
|
||||||
|
# so we need to filter out duplicates
|
||||||
|
rels_to_generate = list(
|
||||||
|
filter(
|
||||||
|
lambda step: step.module_id != 0
|
||||||
|
and not step.name in generated_rels,
|
||||||
|
link_steps_local,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
if len(rels_to_generate) == 0:
|
||||||
|
continue
|
||||||
|
generated_rels.extend(map(lambda step: step.name, rels_to_generate))
|
||||||
|
rel_outputs = list(
|
||||||
|
map(
|
||||||
|
lambda step: step.output(),
|
||||||
|
rels_to_generate,
|
||||||
|
)
|
||||||
)
|
)
|
||||||
)
|
|
||||||
if len(rel_outputs) > 0:
|
|
||||||
n.comment("Generate RELs")
|
n.comment("Generate RELs")
|
||||||
n.build(
|
n.build(
|
||||||
outputs=path(rel_outputs),
|
outputs=path(rel_outputs),
|
||||||
rule="makerel",
|
rule="makerel",
|
||||||
inputs=path(list(map(lambda step: step.partial_output(), link_steps))),
|
inputs=path(
|
||||||
|
list(map(lambda step: step.partial_output(), link_steps_local))
|
||||||
|
),
|
||||||
implicit=path([dtk, config.config_path]),
|
implicit=path([dtk, config.config_path]),
|
||||||
variables={"config": path(config.config_path)},
|
variables={"config": path(config.config_path)},
|
||||||
)
|
)
|
||||||
|
@ -798,6 +844,7 @@ def generate_objdiff_config(config, build_config):
|
||||||
"*.cpp",
|
"*.cpp",
|
||||||
"*.h",
|
"*.h",
|
||||||
"*.hpp",
|
"*.hpp",
|
||||||
|
"*.inc",
|
||||||
"*.py",
|
"*.py",
|
||||||
"*.yml",
|
"*.yml",
|
||||||
"*.txt",
|
"*.txt",
|
||||||
|
@ -940,6 +987,9 @@ def calculate_progress(config):
|
||||||
print("Progress:")
|
print("Progress:")
|
||||||
|
|
||||||
def print_category(unit):
|
def print_category(unit):
|
||||||
|
if unit is None:
|
||||||
|
return
|
||||||
|
|
||||||
code_frac = unit.code_frac()
|
code_frac = unit.code_frac()
|
||||||
data_frac = unit.data_frac()
|
data_frac = unit.data_frac()
|
||||||
print(
|
print(
|
||||||
|
|
Loading…
Reference in New Issue