mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 01:50:30 -04:00 
			
		
		
		
	
		
			
	
	
		
			72 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
		
		
			
		
	
	
			72 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|  | #!/usr/bin/env python | ||
|  | from subprocess import check_output as run | ||
|  | from datetime import datetime | ||
|  | from itertools import groupby | ||
|  | from operator import itemgetter | ||
|  | import re | ||
|  | import magic | ||
|  | 
 | ||
|  | def authors(filename): | ||
|  |     log = run(['git', 'log', '--follow', | ||
|  |               '--date=short','--format=%aN%x09%ad', filename], | ||
|  |               universal_newlines=True) | ||
|  |     for line in log.splitlines(): | ||
|  |         author, date = line.split('\t') | ||
|  |         if author != 'fix-copyright.py': | ||
|  |             yield author, datetime.strptime(date, '%Y-%m-%d') | ||
|  | 
 | ||
|  | def new_copyright(filename, previous): | ||
|  |     def f(): | ||
|  |         au = list(authors(filename)) | ||
|  |         alldates = map(itemgetter(1), au) | ||
|  |         aup = sorted(au + map(lambda a: (a, None), previous), key=itemgetter(0)) | ||
|  |         for author, records in groupby(aup, itemgetter(0)): | ||
|  |             dates = filter(None, map(itemgetter(1), records)) | ||
|  |             if not dates: dates = alldates | ||
|  |             start = min(dates) | ||
|  |             end = max(dates) | ||
|  |             fmt = '{0}' if start.year == end.year else '{0}-{1}' | ||
|  |             line = 'Copyright ' + fmt.format(start.year, end.year) + ' ' + author | ||
|  |             key = (start, author) | ||
|  |             yield key, line | ||
|  |     return map(itemgetter(1), sorted(f())) | ||
|  | 
 | ||
|  | def fix_copyright(filename): | ||
|  |     # Find copyright block in original file | ||
|  |     prefix = set() | ||
|  |     names = [] | ||
|  |     lines = [] | ||
|  |     with open(filename, 'r') as f: | ||
|  |         content = list(f) | ||
|  |     for i, line in enumerate(content[:15]): | ||
|  |         m = re.match(r'^(?P<prefix>\W*)(\(c\))?\s*?copyright\s*(\(c\))?\s+\d{4}(\s*-\s*\d{4})?\s+(?P<name>.+?)\s*$', line, re.IGNORECASE) | ||
|  |         if m: | ||
|  |             d = m.groupdict() | ||
|  |             prefix.add(d['prefix']) | ||
|  |             lines.append(i) | ||
|  |             names.append(d['name'].strip()) | ||
|  |     if len(prefix) != 1: | ||
|  |         print 'Not found:', filename | ||
|  |         return | ||
|  |     prefix = list(prefix)[0] | ||
|  | 
 | ||
|  |     print filename | ||
|  |     new = iter(new_copyright(filename, names)) | ||
|  |     with open(filename, 'w') as f: | ||
|  |         for i, line in enumerate(content): | ||
|  |             if i in lines: | ||
|  |                 for repl in new: | ||
|  |                     print >>f, prefix + repl | ||
|  |             else: | ||
|  |                 print >>f, line, | ||
|  |     pass | ||
|  | 
 | ||
|  | def all_files(): | ||
|  |     ls = run(['git', 'ls-files'], universal_newlines=True) | ||
|  |     for filename in ls.splitlines(): | ||
|  |         if magic.from_file(filename, mime=True).split('/')[0] == 'text': | ||
|  |             yield filename | ||
|  | 
 | ||
|  | for f in all_files(): | ||
|  |     fix_copyright(f) |