summaryrefslogtreecommitdiffstats
path: root/misc
diff options
context:
space:
mode:
authorRémi Verschelde <remi@verschelde.fr>2024-07-23 16:19:15 +0200
committerGitHub <noreply@github.com>2024-07-23 16:19:15 +0200
commit18c1c25ca0468ece9cb9935b5607b74834910ad4 (patch)
tree28407838257e7e9a89c9ccd647114e07d4cef28e /misc
parente4f7b6947061a9dbbf1f1e39979232c5d6f18a75 (diff)
parent09f2b9513c39f05adea23a091aa0149088247684 (diff)
downloadredot-engine-18c1c25ca0468ece9cb9935b5607b74834910ad4.tar.gz
Merge pull request #94652 from shana/fix-header-guards
Fix `header_guards.py` so it detects the copyright header properly.
Diffstat (limited to 'misc')
-rwxr-xr-xmisc/scripts/header_guards.py37
1 files changed, 28 insertions, 9 deletions
diff --git a/misc/scripts/header_guards.py b/misc/scripts/header_guards.py
index b554be5159..fed418db1e 100755
--- a/misc/scripts/header_guards.py
+++ b/misc/scripts/header_guards.py
@@ -8,22 +8,38 @@ if len(sys.argv) < 2:
print("Invalid usage of header_guards.py, it should be called with a path to one or multiple files.")
sys.exit(1)
-HEADER_CHECK_OFFSET = 30
-HEADER_BEGIN_OFFSET = 31
-HEADER_END_OFFSET = -1
-
changed = []
invalid = []
for file in sys.argv[1:]:
- with open(file, "rt", encoding="utf-8", newline="\n") as f:
+ header_start = -1
+ HEADER_CHECK_OFFSET = -1
+
+ with open(file.strip(), "rt", encoding="utf-8", newline="\n") as f:
lines = f.readlines()
- if len(lines) <= HEADER_BEGIN_OFFSET:
- continue # Most likely a dummy file.
+ for idx, line in enumerate(lines):
+ sline = line.strip()
+
+ if header_start < 0:
+ if sline == "": # Skip empty lines at the top.
+ continue
+
+ if sline.startswith("/**********"): # Godot header starts this way.
+ header_start = idx
+ else:
+ HEADER_CHECK_OFFSET = 0 # There is no Godot header.
+ break
+ else:
+ if not sline.startswith("*") and not sline.startswith("/*"): # Not in the Godot header anymore.
+ HEADER_CHECK_OFFSET = idx + 1 # The include should be two lines below the Godot header.
+ break
+
+ if HEADER_CHECK_OFFSET < 0:
+ continue
- if lines[HEADER_CHECK_OFFSET].startswith("#import"):
- continue # Early catch obj-c file.
+ HEADER_BEGIN_OFFSET = HEADER_CHECK_OFFSET + 1
+ HEADER_END_OFFSET = len(lines) - 1
split = file.split("/") # Already in posix-format.
@@ -82,6 +98,9 @@ for file in sys.argv[1:]:
objc = False
for idx, line in enumerate(lines):
+ if line.startswith("// #import"): # Some dummy obj-c files only have commented out import lines.
+ objc = True
+ break
if not line.startswith("#"):
continue
elif line.startswith("#ifndef") and header_check == -1: