2017-05-23 18:06:26 +02:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
2017-12-20 16:37:20 +01:00
|
|
|
import os
|
|
|
|
import sys
|
2017-05-23 18:06:26 +02:00
|
|
|
import difflib
|
|
|
|
from io import BytesIO, TextIOWrapper
|
|
|
|
|
|
|
|
_in = "/-."
|
|
|
|
_out = "___"
|
|
|
|
|
|
|
|
transtab = str.maketrans(_in, _out)
|
|
|
|
|
2017-12-20 16:37:20 +01:00
|
|
|
|
2017-05-23 18:06:26 +02:00
|
|
|
def path_to_guardname(filepath):
|
|
|
|
res = filepath.upper().translate(transtab)
|
|
|
|
if res.startswith("_"):
|
|
|
|
res = "PRIV" + res
|
|
|
|
return res
|
|
|
|
|
2017-12-20 16:37:20 +01:00
|
|
|
|
2017-05-23 18:06:26 +02:00
|
|
|
def get_guard_name(filepath):
|
|
|
|
parts = filepath.split(os.sep)
|
|
|
|
start = 0
|
|
|
|
found = False
|
|
|
|
for i, part in enumerate(parts):
|
|
|
|
if part == "include":
|
|
|
|
found = True
|
2017-12-20 16:37:20 +01:00
|
|
|
start = i + 1
|
2017-05-23 18:06:26 +02:00
|
|
|
break
|
|
|
|
|
|
|
|
if not found:
|
2017-12-20 16:37:20 +01:00
|
|
|
start = len(parts) - 1
|
2017-05-23 18:06:26 +02:00
|
|
|
|
|
|
|
return path_to_guardname(os.path.join(*parts[start:]))
|
|
|
|
|
2017-12-20 16:37:20 +01:00
|
|
|
|
2017-05-23 18:06:26 +02:00
|
|
|
def fix_headerguard(filename):
|
|
|
|
supposed = get_guard_name(filename)
|
2017-12-20 16:37:20 +01:00
|
|
|
with open(filename, "r", encoding='utf-8', errors='ignore') as f:
|
2017-05-23 18:06:26 +02:00
|
|
|
inlines = f.readlines()
|
|
|
|
|
|
|
|
tmp = TextIOWrapper(BytesIO(), encoding="utf-8", errors="ignore")
|
|
|
|
tmp.seek(0)
|
|
|
|
|
|
|
|
guard_found = 0
|
|
|
|
guard_name = ""
|
|
|
|
ifstack = 0
|
2017-12-20 16:37:20 +01:00
|
|
|
for line in inlines:
|
2017-05-23 18:06:26 +02:00
|
|
|
if guard_found == 0:
|
|
|
|
if line.startswith("#ifndef"):
|
|
|
|
guard_found += 1
|
|
|
|
guard_name = line[8:].rstrip()
|
|
|
|
line = "#ifndef %s\n" % (supposed)
|
|
|
|
elif guard_found == 1:
|
|
|
|
if line.startswith("#define") and line[8:].rstrip() == guard_name:
|
|
|
|
line = "#define %s\n" % (supposed)
|
|
|
|
guard_found += 1
|
|
|
|
else:
|
|
|
|
break
|
|
|
|
elif guard_found == 2:
|
|
|
|
if line.startswith("#if"):
|
|
|
|
ifstack += 1
|
|
|
|
elif line.startswith("#endif"):
|
|
|
|
if ifstack > 0:
|
|
|
|
ifstack -= 1
|
|
|
|
else:
|
|
|
|
guard_found += 1
|
|
|
|
line = "#endif /* %s */\n" % supposed
|
|
|
|
|
|
|
|
tmp.write(line)
|
|
|
|
|
|
|
|
tmp.seek(0)
|
|
|
|
if guard_found == 3:
|
2017-12-20 16:37:20 +01:00
|
|
|
for line in difflib.unified_diff(inlines, tmp.readlines(),
|
|
|
|
"%s" % filename, "%s" % filename):
|
2017-05-23 18:06:26 +02:00
|
|
|
sys.stdout.write(line)
|
|
|
|
else:
|
|
|
|
print("%s: no / broken header guard" % filename, file=sys.stderr)
|
|
|
|
return False
|
|
|
|
|
2017-12-20 16:37:20 +01:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2017-05-23 18:06:26 +02:00
|
|
|
error = False
|
|
|
|
for filename in sys.argv[1:]:
|
2017-12-20 16:37:20 +01:00
|
|
|
if fix_headerguard(filename) is False:
|
2017-05-23 18:06:26 +02:00
|
|
|
error = True
|
|
|
|
|
|
|
|
if error:
|
|
|
|
sys.exit(1)
|