scripts: Strip compiler suffixes in result scripts

This can be explicitly disabled with -x/--no-strip in the relevant
scripts, but stripping by default seems to be more useful for composing
results in higher-level scripts. It's better for the result names to be
consistent, even if they don't match the .o symbols exactly.

Note some scripts are unaffected:

- cov.py - gcov doesn't seem to have an option for getting the
  unstripped symbols, so we only output the stripped names.

- structs.py - structs.py deals with struct names, which are notably not
  symbols.
This commit is contained in:
Christopher Haster
2025-03-06 15:07:12 -06:00
parent 9e22167a31
commit 1cc38acc91
6 changed files with 64 additions and 3 deletions

View File

@@ -323,6 +323,7 @@ def collect_callgraph(ci_path,
def collect_stack(ci_paths, *,
everything=False,
no_strip=False,
depth=1,
**args):
# parse the callgraphs
@@ -351,6 +352,10 @@ def collect_stack(ci_paths, *,
else:
file = os.path.abspath(file)
# strip compiler suffixes
if not no_strip:
name = name.split('.', 1)[0]
nameof.cache[node.name] = name, file
return name, file
@@ -1254,6 +1259,10 @@ if __name__ == "__main__":
'--everything',
action='store_true',
help="Include builtin and libc specific symbols.")
parser.add_argument(
'-x', '--no-strip',
action='store_true',
help="Don't strip compiler optimization suffixes from symbols.")
parser.add_argument(
'-e', '--error-on-recursion',
action='store_true',