Rewrite cpplint script in python.
This commit is contained in:
		
					parent
					
						
							
								5c48f03dfe
							
						
					
				
			
			
				commit
				
					
						cce712549b
					
				
			
		
					 2 changed files with 45 additions and 26 deletions
				
			
		|  | @ -1,26 +0,0 @@ | |||
| #!/bin/bash | ||||
| 
 | ||||
| cd "`dirname $0`/.." | ||||
| 
 | ||||
| # List all Objective-C headers here, should not cpplint them. | ||||
| OBJC_HEADERS=' | ||||
| browser/atom_event_processing_window.h | ||||
| browser/atom_application_mac.h | ||||
| browser/atom_application_delegate_mac.h | ||||
| browser/native_window_mac.h | ||||
| browser/nsalert_synchronous_sheet.h | ||||
| common/api/api_messages.cc | ||||
| common/api/api_messages.h' | ||||
| 
 | ||||
| FILES=`find app browser common renderer -type f -name '*.h' -or -name '*.cc'` | ||||
| FILTERED_FILES= | ||||
| 
 | ||||
| while read file; do | ||||
|   if ! echo "$OBJC_HEADERS" | grep "$file" > /dev/null ; then | ||||
|     FILTERED_FILES="$FILTERED_FILES $file" | ||||
|   fi | ||||
| done <<< "$FILES" | ||||
| 
 | ||||
| python ./vendor/cpplint.py \ | ||||
|   --filter=-build/header_guard,-build/include_what_you_use \ | ||||
|   $FILTERED_FILES | ||||
							
								
								
									
										45
									
								
								script/cpplint.py
									
										
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										45
									
								
								script/cpplint.py
									
										
									
									
										vendored
									
									
										Executable file
									
								
							|  | @ -0,0 +1,45 @@ | |||
| #!/usr/bin/env python | ||||
| 
 | ||||
| import fnmatch | ||||
| import os | ||||
| import subprocess | ||||
| import sys | ||||
| 
 | ||||
| OBJC_HEADERS = [ | ||||
|   'browser/atom_event_processing_window.h', | ||||
|   'browser/atom_application_mac.h', | ||||
|   'browser/atom_application_delegate_mac.h', | ||||
|   'browser/native_window_mac.h', | ||||
|   'browser/nsalert_synchronous_sheet.h', | ||||
|   'common/api/api_messages.cc', | ||||
|   'common/api/api_messages.h', | ||||
| ] | ||||
| 
 | ||||
| SOURCE_ROOT = os.path.dirname(os.path.dirname(__file__)) | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|   os.chdir(SOURCE_ROOT) | ||||
|   files = list_files(['app', 'browser', 'common', 'renderer'], | ||||
|                      ['*.cc', '*.h']) | ||||
|   call_cpplint(list(set(files) - set(OBJC_HEADERS))) | ||||
| 
 | ||||
| 
 | ||||
| def list_files(directories, filters): | ||||
|   matches = [] | ||||
|   for directory in directories: | ||||
|     for root, dirs, filenames, in os.walk(directory): | ||||
|       for f in filters: | ||||
|         for filename in fnmatch.filter(filenames, f): | ||||
|           matches.append(os.path.join(root, filename)) | ||||
|   return matches | ||||
| 
 | ||||
| 
 | ||||
| def call_cpplint(files): | ||||
|   cpplint = os.path.join(SOURCE_ROOT, 'vendor', 'cpplint.py') | ||||
|   rules = '--filter=-build/header_guard,-build/include_what_you_use' | ||||
|   subprocess.call([sys.executable, cpplint, rules] + files) | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|   sys.exit(main()) | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Cheng Zhao
				Cheng Zhao