| 
									
										
										
										
											2019-03-20 21:12:47 +01:00
										 |  |  | #!/usr/bin/env python | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-05 17:40:04 -07:00
										 |  |  | from __future__ import print_function, unicode_literals | 
					
						
							| 
									
										
										
										
											2019-03-21 12:15:55 -07:00
										 |  |  | import argparse | 
					
						
							| 
									
										
										
										
											2020-10-05 17:40:04 -07:00
										 |  |  | import io | 
					
						
							| 
									
										
										
										
											2019-03-20 21:12:47 +01: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 12:15:55 -07:00
										 |  |  |   args = parse_args() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 21:12:47 +01: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 12:15:55 -07:00
										 |  |  |     trailingWhiteSpaceFiles += hasTrailingWhiteSpace(path, args.fix) | 
					
						
							| 
									
										
										
										
											2019-03-20 21:12:47 +01: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 12:15:55 -07:00
										 |  |  | def hasTrailingWhiteSpace(filepath, fix): | 
					
						
							| 
									
										
										
										
											2019-03-20 21:12:47 +01:00
										 |  |  |   try: | 
					
						
							| 
									
										
										
										
											2020-10-05 17:40:04 -07:00
										 |  |  |     with io.open(filepath, 'r', encoding='utf-8') as f: | 
					
						
							|  |  |  |       lines = f.read().splitlines() | 
					
						
							| 
									
										
										
										
											2019-03-20 21:12:47 +01:00
										 |  |  |   except KeyboardInterrupt: | 
					
						
							| 
									
										
										
										
											2020-10-05 07:38:50 -07:00
										 |  |  |     print('Keyboard interruption while parsing. Please try again.') | 
					
						
							| 
									
										
										
										
											2020-10-05 17:40:04 -07:00
										 |  |  |     return | 
					
						
							| 
									
										
										
										
											2019-03-20 21:12:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-21 12:15:55 -07:00
										 |  |  |   fixed_lines = [] | 
					
						
							| 
									
										
										
										
											2019-09-09 06:15:24 -07:00
										 |  |  |   for num, line in enumerate(lines): | 
					
						
							| 
									
										
										
										
											2019-03-21 12:15:55 -07:00
										 |  |  |     fixed_lines.append(line.rstrip() + '\n') | 
					
						
							|  |  |  |     if not fix and line != line.rstrip(): | 
					
						
							| 
									
										
										
										
											2019-10-28 17:02:16 +03:00
										 |  |  |       print("Trailing whitespace on line {} in file: {}".format( | 
					
						
							|  |  |  |           num + 1, filepath)) | 
					
						
							| 
									
										
										
										
											2019-03-20 21:12:47 +01:00
										 |  |  |       return True | 
					
						
							| 
									
										
										
										
											2019-03-21 12:15:55 -07:00
										 |  |  |   if fix: | 
					
						
							| 
									
										
										
										
											2020-10-05 17:40:04 -07:00
										 |  |  |     with io.open(filepath, 'w', newline='\n', encoding='utf-8') as f: | 
					
						
							| 
									
										
										
										
											2019-03-21 12:15:55 -07:00
										 |  |  |       print(fixed_lines) | 
					
						
							|  |  |  |       f.writelines(fixed_lines) | 
					
						
							| 
									
										
										
										
											2019-03-20 21:12:47 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return False | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-21 12:15:55 -07: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 21:12:47 +01:00
										 |  |  | if __name__ == '__main__': | 
					
						
							|  |  |  |   sys.exit(main()) |