mirror of
https://github.com/isledecomp/isle.git
synced 2025-10-24 17:04:17 +00:00
(Proposal) Adjustments to "decomp" language (#308)
* Adjustments to "decomp" language * Fix a comment * Fix accidental clang-formatting * Fix order * Fix order * Remove junk * Fix OFFSET * Adjustments based on new suggestions * Annotate globals * Globals in ISLE * More globals * Merge from parser2 branch * Allow prepending space for exact marker match * To eliminate noise, require the 0x prefix on offset for marker match * fix test from previous * Count tab stops for indented functions to reduce MISSED_END_OF_FUNCTION noise * FUNCTION to SYNTHETIC where needed * Missed marker conversion on SetAtomId * pylint cleanup, remove unused code * Fix unexpected function end, add more unit tests * Be more strict about synthetic name syntax * Revert "Missed marker conversion on SetAtomId" This reverts commitd87d665127. * Revert "FUNCTION to SYNTHETIC where needed" This reverts commit8c815418d2. * Implicit lookup by name for functions * Fix VTABLE SYNTHETIC and other decomp markers * Get vtable class name * Vtable marker should identify struct * No colon for SIZE comment * Update README.md * Update README.md * Update CONTRIBUTING.md * Update README.md * Update README.md * Update CONTRIBUTING.md * Update README.md * Update CONTRIBUTING.md * Fix destructor/annotation * Update README.md * Update README.md * Update README.md * Update README.md * Update README.md --------- Co-authored-by: disinvite <disinvite@users.noreply.github.com>
This commit is contained in:
committed by
GitHub
parent
4f5b70013f
commit
494a556f8e
@@ -2,8 +2,7 @@ import os
|
||||
import sys
|
||||
import argparse
|
||||
from isledecomp.dir import walk_source_dir, is_file_cpp
|
||||
from isledecomp.parser import find_code_blocks
|
||||
from isledecomp.parser.util import is_exact_offset_comment
|
||||
from isledecomp.parser import DecompParser
|
||||
|
||||
|
||||
def sig_truncate(sig: str) -> str:
|
||||
@@ -16,23 +15,21 @@ def check_file(filename: str, verbose: bool = False) -> bool:
|
||||
"""Open and read the given file, then check whether the code blocks
|
||||
are in order. If verbose, print each block."""
|
||||
|
||||
parser = DecompParser()
|
||||
with open(filename, "r", encoding="utf-8") as f:
|
||||
code_blocks = find_code_blocks(f)
|
||||
parser.read_lines(f)
|
||||
|
||||
bad_comments = [
|
||||
(block.start_line, block.offset_comment)
|
||||
for block in code_blocks
|
||||
if not is_exact_offset_comment(block.offset_comment)
|
||||
]
|
||||
|
||||
just_offsets = [block.offset for block in code_blocks]
|
||||
just_offsets = [block.offset for block in parser.functions]
|
||||
sorted_offsets = sorted(just_offsets)
|
||||
file_out_of_order = just_offsets != sorted_offsets
|
||||
|
||||
# TODO: When we add parser error severity, actual errors that obstruct
|
||||
# parsing should probably be shown here regardless of verbose mode
|
||||
|
||||
# If we detect inexact comments, don't print anything unless we are
|
||||
# in verbose mode. If the file is out of order, we always print the
|
||||
# file name.
|
||||
should_report = (len(bad_comments) > 0 and verbose) or file_out_of_order
|
||||
should_report = (len(parser.alerts) > 0 and verbose) or file_out_of_order
|
||||
|
||||
if not should_report and not file_out_of_order:
|
||||
return False
|
||||
@@ -44,22 +41,22 @@ def check_file(filename: str, verbose: bool = False) -> bool:
|
||||
order_lookup = {k: i for i, k in enumerate(sorted_offsets)}
|
||||
prev_offset = 0
|
||||
|
||||
for block in code_blocks:
|
||||
for fun in parser.functions:
|
||||
msg = " ".join(
|
||||
[
|
||||
" " if block.offset > prev_offset else "!",
|
||||
f"{block.offset:08x}",
|
||||
f"{block.end_line - block.start_line:4} lines",
|
||||
f"{order_lookup[block.offset]:3}",
|
||||
" " if fun.offset > prev_offset else "!",
|
||||
f"{fun.offset:08x}",
|
||||
f"{fun.end_line - fun.line_number:4} lines",
|
||||
f"{order_lookup[fun.offset]:3}",
|
||||
" ",
|
||||
sig_truncate(block.signature),
|
||||
sig_truncate(fun.signature),
|
||||
]
|
||||
)
|
||||
print(msg)
|
||||
prev_offset = block.offset
|
||||
prev_offset = fun.offset
|
||||
|
||||
for line_no, line in bad_comments:
|
||||
print(f"* line {line_no:3} bad offset comment ({line})")
|
||||
for alert in parser.alerts:
|
||||
print(f"* line {alert.line_number:4} {alert.code} ({alert.line})")
|
||||
|
||||
print()
|
||||
|
||||
|
||||
Reference in New Issue
Block a user