Cubyz/format_check.py
Mikael Klages 2950c152bb
Fix issues with check_format.py (#667)
* Made format_check use os.sep when checking if it should ignore a folder

* Made format_check specify utf-8 encoding when loading files.

* Fixed documentation using wrong filename for format_check.py
2024-09-04 20:53:02 +02:00

45 lines
1.4 KiB
Python

import os
import sys
directory = os.fsencode(".")
fails = 0
for subdir, dirs, files in os.walk("."):
for file in files:
#print os.path.join(subdir, file)
filepath = subdir + os.sep + file
if filepath.startswith(f".{os.sep}compiler"): continue
if filepath.startswith(f".{os.sep}saves"): continue
if filepath.startswith(f".{os.sep}serverAssets"): continue
if filepath.startswith(f".{os.sep}zig-cache"): continue
if filepath.startswith(f".{os.sep}.zig-cache"): continue
if filepath.endswith(".json") or filepath.endswith(".zig") or filepath.endswith(".py") or filepath.endswith(".zon") or filepath.endswith(".vs") or filepath.endswith(".fs") or filepath.endswith(".glsl"):
with open(filepath, "r", newline = '', encoding="utf-8") as f:
string = f.read()
line = 1
lineStart = True
for i, c in enumerate(string):
if(c == '\r'):
print("Incorrect line ending \\r in file ", filepath, " in line ", line, ". Please configure your editor to use LF instead of CRLF.")
fails += 1
elif(c == '\n'):
line += 1
lineStart = True
elif(c == ' '):
if(lineStart):
print("Incorrect indentation in file ", filepath, " in line ", line, ". Please use tabs instead of spaces.")
fails += 1
lineStart = False # avoid repeating this error multiple times
elif(c == '\t'):
continue
elif(lineStart):
lineStart = False
else:
continue
if(fails != 0):
sys.exit(1)
sys.exit(0)