2019-03-20 20:12:47 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
2019-06-15 17:26:09 +00:00
|
|
|
from __future__ import print_function
|
2019-03-21 19:15:55 +00:00
|
|
|
import argparse
|
2019-03-20 20:12:47 +00:00
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
|
|
|
|
SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
|
|
|
|
DOCS_DIR = os.path.join(SOURCE_ROOT, 'docs')
|
|
|
|
|
|
|
|
def main():
|
|
|
|
os.chdir(SOURCE_ROOT)
|
|
|
|
|
2019-03-21 19:15:55 +00:00
|
|
|
args = parse_args()
|
|
|
|
|
2019-03-20 20:12:47 +00:00
|
|
|
filepaths = []
|
|
|
|
totalDirs = 0
|
|
|
|
try:
|
|
|
|
for root, dirs, files in os.walk(DOCS_DIR):
|
|
|
|
totalDirs += len(dirs)
|
|
|
|
for f in files:
|
|
|
|
if f.endswith('.md'):
|
|
|
|
filepaths.append(os.path.join(root, f))
|
|
|
|
except KeyboardInterrupt:
|
|
|
|
print('Keyboard interruption. Please try again.')
|
|
|
|
return
|
|
|
|
|
|
|
|
trailingWhiteSpaceFiles = 0
|
|
|
|
for path in filepaths:
|
2019-03-21 19:15:55 +00:00
|
|
|
trailingWhiteSpaceFiles += hasTrailingWhiteSpace(path, args.fix)
|
2019-03-20 20:12:47 +00:00
|
|
|
|
|
|
|
print('Parsed through ' + str(len(filepaths)) +
|
|
|
|
' files within docs directory and its ' +
|
|
|
|
str(totalDirs) + ' subdirectories.')
|
|
|
|
print('Found ' + str(trailingWhiteSpaceFiles) +
|
|
|
|
' files with trailing whitespace.')
|
|
|
|
return trailingWhiteSpaceFiles
|
|
|
|
|
2019-03-21 19:15:55 +00:00
|
|
|
def hasTrailingWhiteSpace(filepath, fix):
|
2019-03-20 20:12:47 +00:00
|
|
|
try:
|
|
|
|
f = open(filepath, 'r')
|
|
|
|
lines = f.read().splitlines()
|
|
|
|
except KeyboardInterrupt:
|
2020-10-05 14:38:50 +00:00
|
|
|
print('Keyboard interruption while parsing. Please try again.')
|
2019-03-20 20:12:47 +00:00
|
|
|
finally:
|
|
|
|
f.close()
|
|
|
|
|
2019-03-21 19:15:55 +00:00
|
|
|
fixed_lines = []
|
2019-09-09 13:15:24 +00:00
|
|
|
for num, line in enumerate(lines):
|
2019-03-21 19:15:55 +00:00
|
|
|
fixed_lines.append(line.rstrip() + '\n')
|
|
|
|
if not fix and line != line.rstrip():
|
2019-10-28 14:02:16 +00:00
|
|
|
print("Trailing whitespace on line {} in file: {}".format(
|
|
|
|
num + 1, filepath))
|
2019-03-20 20:12:47 +00:00
|
|
|
return True
|
2019-03-21 19:15:55 +00:00
|
|
|
if fix:
|
|
|
|
with open(filepath, 'w') as f:
|
|
|
|
print(fixed_lines)
|
|
|
|
f.writelines(fixed_lines)
|
2019-03-20 20:12:47 +00:00
|
|
|
|
|
|
|
return False
|
|
|
|
|
2019-03-21 19:15:55 +00:00
|
|
|
def parse_args():
|
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
description='Check for trailing whitespace in md files')
|
|
|
|
parser.add_argument('-f', '--fix',
|
|
|
|
help='Automatically fix trailing whitespace issues',
|
|
|
|
action='store_true')
|
|
|
|
return parser.parse_known_args()[0]
|
|
|
|
|
2019-03-20 20:12:47 +00:00
|
|
|
if __name__ == '__main__':
|
|
|
|
sys.exit(main())
|