Ran autopep8.

This commit is contained in:
XhmikosR 2016-07-23 14:44:05 +03:00
parent 7ef02a7469
commit 07b43c6929
6 changed files with 233 additions and 233 deletions

View File

@ -578,6 +578,7 @@ class CppCheckFormatter(argparse.HelpFormatter):
''' '''
Properly formats multiline argument helps Properly formats multiline argument helps
''' '''
def _split_lines(self, text, width): def _split_lines(self, text, width):
# this is the RawTextHelpFormatter._split_lines # this is the RawTextHelpFormatter._split_lines
if text.startswith('R|'): if text.startswith('R|'):
@ -591,12 +592,12 @@ def ArgumentParser():
''' '''
parser = argparse.ArgumentParser(formatter_class=CppCheckFormatter) parser = argparse.ArgumentParser(formatter_class=CppCheckFormatter)
parser.add_argument('-t', '--template', metavar='<text>', parser.add_argument('-t', '--template', metavar='<text>',
default='{callstack}: ({severity}) {message}', default='{callstack}: ({severity}) {message}',
help="R|Format the error messages. E.g.\n" \ help="R|Format the error messages. E.g.\n"
"'{file}:{line},{severity},{id},{message}' or\n" \ "'{file}:{line},{severity},{id},{message}' or\n"
"'{file}({line}):({severity}) {message}' or\n" \ "'{file}({line}):({severity}) {message}' or\n"
"'{callstack} {message}'\n" \ "'{callstack} {message}'\n"
"Pre-defined templates: gcc, vs, edit") "Pre-defined templates: gcc, vs, edit")
return parser return parser
# Format an error message. # Format an error message.
@ -619,9 +620,9 @@ def reportError(template, callstack=[], severity='', message='', id=''):
elif template == 'edit': elif template == 'edit':
template = '{file} +{line}: {severity}: {message}' template = '{file} +{line}: {severity}: {message}'
# compute 'callstack}, {file} and {line} replacements # compute 'callstack}, {file} and {line} replacements
stack = ' -> '.join(['['+f+':'+str(l)+']' for (f,l) in callstack]) stack = ' -> '.join(['[' + f + ':' + str(l) + ']' for (f, l) in callstack])
file = callstack[-1][0] file = callstack[-1][0]
line = str(callstack[-1][1]) line = str(callstack[-1][1])
# format message # format message
return template.format(callstack=stack, file=file, line=line, return template.format(callstack=stack, file=file, line=line,
severity=severity, message=message, id=id) severity=severity, message=message, id=id)

View File

@ -198,7 +198,7 @@ def find_dump_files(paths):
for (top, subdirs, files) in os.walk(path): for (top, subdirs, files) in os.walk(path):
for file in files: for file in files:
if file.endswith('.dump'): if file.endswith('.dump'):
f = top+'/'+file f = top + '/' + file
if not f in dumpfiles: if not f in dumpfiles:
dumpfiles.append(f) dumpfiles.append(f)
dumpfiles.sort() dumpfiles.sort()
@ -212,9 +212,9 @@ def find_dump_files(paths):
parser = cppcheckdata.ArgumentParser() parser = cppcheckdata.ArgumentParser()
parser.add_argument('-q', '--quiet', action='store_true', parser.add_argument('-q', '--quiet', action='store_true',
help='do not print "Checking ..." lines') help='do not print "Checking ..." lines')
parser.add_argument('paths', nargs='+', metavar='path', parser.add_argument('paths', nargs='+', metavar='path',
help='path to dump file or directory') help='path to dump file or directory')
# parse command line # parse command line

View File

@ -150,7 +150,7 @@ def scanarchive(filepath, jobs):
removeLargeFiles('') removeLargeFiles('')
print(strfCurrTime('[%H:%M] cppcheck ' ) + filename) print(strfCurrTime('[%H:%M] cppcheck ') + filename)
p = subprocess.Popen( p = subprocess.Popen(
['nice', ['nice',

View File

@ -9,224 +9,224 @@ SEGFAULT = False
FILE = None FILE = None
BACKUPFILE = None BACKUPFILE = None
for arg in sys.argv[1:]: for arg in sys.argv[1:]:
if arg.startswith('--cmd='): if arg.startswith('--cmd='):
CMD = arg[arg.find('=')+1:] CMD = arg[arg.find('=') + 1:]
elif arg.startswith('--expected='): elif arg.startswith('--expected='):
EXPECTED = arg[arg.find('=')+1:] EXPECTED = arg[arg.find('=') + 1:]
elif arg.startswith('--file='): elif arg.startswith('--file='):
FILE = arg[arg.find('=')+1:] FILE = arg[arg.find('=') + 1:]
BACKUPFILE = FILE + '.bak' BACKUPFILE = FILE + '.bak'
elif arg == '--segfault': elif arg == '--segfault':
SEGFAULT = True SEGFAULT = True
if CMD is None: if CMD is None:
print('Abort: No --cmd') print('Abort: No --cmd')
sys.exit(1) sys.exit(1)
if SEGFAULT == False and EXPECTED is None: if SEGFAULT == False and EXPECTED is None:
print('Abort: No --expected') print('Abort: No --expected')
sys.exit(1) sys.exit(1)
if FILE is None: if FILE is None:
print('Abort: No --file') print('Abort: No --file')
sys.exit(1) sys.exit(1)
print('CMD='+CMD) print('CMD=' + CMD)
if SEGFAULT: if SEGFAULT:
print('EXPECTED=SEGFAULT') print('EXPECTED=SEGFAULT')
else: else:
print('EXPECTED='+EXPECTED) print('EXPECTED=' + EXPECTED)
print('FILE='+FILE) print('FILE=' + FILE)
def runtool(): def runtool():
p = subprocess.Popen(CMD.split(), stdout=subprocess.PIPE, stderr=subprocess.PIPE) p = subprocess.Popen(CMD.split(), stdout=subprocess.PIPE, stderr=subprocess.PIPE)
comm = p.communicate() comm = p.communicate()
if SEGFAULT: if SEGFAULT:
if p.returncode != 0: if p.returncode != 0:
return True return True
elif p.returncode == 0: elif p.returncode == 0:
out = comm[0] + '\n' + comm[1] out = comm[0] + '\n' + comm[1]
if (out.find('error:') < 0) and (out.find(EXPECTED) > 0): if (out.find('error:') < 0) and (out.find(EXPECTED) > 0):
return True return True
return False return False
def writefile(filename, filedata): def writefile(filename, filedata):
f = open(filename, 'wt') f = open(filename, 'wt')
for line in filedata: for line in filedata:
f.write(line) f.write(line)
f.close() f.close()
def replaceandrun(what, filedata, i, line): def replaceandrun(what, filedata, i, line):
print(what + ' ' + str(i+1) + '/' + str(len(filedata)) + '..') print(what + ' ' + str(i + 1) + '/' + str(len(filedata)) + '..')
bak = filedata[i] bak = filedata[i]
filedata[i] = line filedata[i] = line
writefile(FILE, filedata) writefile(FILE, filedata)
if runtool() == True: if runtool() == True:
print('pass') print('pass')
writefile(BACKUPFILE, filedata) writefile(BACKUPFILE, filedata)
return True return True
print('fail') print('fail')
filedata[i] = bak filedata[i] = bak
return False return False
def replaceandrun2(what, filedata, i, line1, line2): def replaceandrun2(what, filedata, i, line1, line2):
print(what + ' ' + str(i+1) + '/' + str(len(filedata)) + '..') print(what + ' ' + str(i + 1) + '/' + str(len(filedata)) + '..')
bak1 = filedata[i] bak1 = filedata[i]
bak2 = filedata[i+1] bak2 = filedata[i + 1]
filedata[i] = line1 filedata[i] = line1
filedata[i+1] = line2 filedata[i + 1] = line2
writefile(FILE, filedata) writefile(FILE, filedata)
if runtool() == True: if runtool() == True:
print('pass') print('pass')
writefile(BACKUPFILE, filedata) writefile(BACKUPFILE, filedata)
else: else:
print('fail') print('fail')
filedata[i] = bak1 filedata[i] = bak1
filedata[i+1] = bak2 filedata[i + 1] = bak2
def clearandrun(what, filedata, i1, i2): def clearandrun(what, filedata, i1, i2):
print(what + ' ' + str(i1+1) + '/' + str(len(filedata)) + '..') print(what + ' ' + str(i1 + 1) + '/' + str(len(filedata)) + '..')
filedata2 = list(filedata) filedata2 = list(filedata)
i = i1 i = i1
while i <= i2 and i < len(filedata2): while i <= i2 and i < len(filedata2):
filedata2[i] = '' filedata2[i] = ''
i = i + 1 i = i + 1
writefile(FILE, filedata2) writefile(FILE, filedata2)
if runtool() == True: if runtool() == True:
print('pass') print('pass')
writefile(BACKUPFILE, filedata2) writefile(BACKUPFILE, filedata2)
return filedata2 return filedata2
print('fail') print('fail')
return filedata
def removecomments(filedata):
for i in range(len(filedata)):
line = filedata[i]
if line.find('//') >= 0:
replaceandrun('remove comment', filedata, i, line[:line.find('//')].rstrip())
def checkpar(line):
par = 0
for c in line:
if c=='(' or c=='[':
par = par + 1
elif c==')' or c==']':
par = par - 1
if par<0:
return False
return par == 0
def combinelines(filedata):
if len(filedata) < 3:
return
lines = []
for i in range(len(filedata)-1):
fd1 = filedata[i].rstrip()
if fd1.endswith(','):
fd2 = filedata[i+1].lstrip()
if fd2 != '':
lines.append(i)
chunksize = len(lines)
while chunksize > 10:
i = 0
while i < len(lines):
i1 = i
i2 = i + chunksize
i = i2
if i2 > len(lines):
i2 = len(lines)
filedata2 = list(filedata)
for line in lines[i1:i2]:
filedata2[line] = filedata2[line].rstrip() + filedata2[line+1].lstrip()
filedata2[line+1] = ''
if replaceandrun('combine lines', filedata2, lines[i1]+1, ''):
filedata = filedata2
lines[i1:i2] = []
i = i1
chunksize = chunksize / 2
for line in lines:
fd1 = filedata[line].rstrip()
fd2 = filedata[line+1].lstrip()
replaceandrun2('combine lines', filedata, line, fd1+fd2, '')
def removedirectives(filedata):
for i in range(len(filedata)):
if filedata[i].lstrip().startswith('#'):
replaceandrun('remove preprocessor directive', filedata, i, '')
def removeblocks(filedata):
if len(filedata) < 3:
return filedata return filedata
for i in range(len(filedata)): def removecomments(filedata):
strippedline = filedata[i].strip() for i in range(len(filedata)):
if len(strippedline)==0: line = filedata[i]
continue if line.find('//') >= 0:
if ';{}'.find(strippedline[-1]) < 0: replaceandrun('remove comment', filedata, i, line[:line.find('//')].rstrip())
continue
i1 = i + 1 def checkpar(line):
while i1 < len(filedata) and filedata[i1].startswith('#'): par = 0
i1 = i1 + 1 for c in line:
if c == '(' or c == '[':
par = par + 1
elif c == ')' or c == ']':
par = par - 1
if par < 0:
return False
return par == 0
i2 = i1 def combinelines(filedata):
indent = 0 if len(filedata) < 3:
while i2 < len(filedata): return
for c in filedata[i2]:
if c == '}':
indent = indent - 1
if indent == 0:
indent = -100
elif c == '{':
indent = indent + 1
if indent < 0:
break
i2 = i2 + 1
if indent == -100:
indent = 0
if i2 == i1 or i2 >= len(filedata):
continue
if filedata[i2].strip() != '}' and filedata[i2].strip() != '};':
continue
if indent < 0:
i2 = i2 - 1
filedata = clearandrun('remove codeblock', filedata, i1, i2)
return filedata lines = []
for i in range(len(filedata) - 1):
fd1 = filedata[i].rstrip()
if fd1.endswith(','):
fd2 = filedata[i + 1].lstrip()
if fd2 != '':
lines.append(i)
chunksize = len(lines)
while chunksize > 10:
i = 0
while i < len(lines):
i1 = i
i2 = i + chunksize
i = i2
if i2 > len(lines):
i2 = len(lines)
filedata2 = list(filedata)
for line in lines[i1:i2]:
filedata2[line] = filedata2[line].rstrip() + filedata2[line + 1].lstrip()
filedata2[line + 1] = ''
if replaceandrun('combine lines', filedata2, lines[i1] + 1, ''):
filedata = filedata2
lines[i1:i2] = []
i = i1
chunksize = chunksize / 2
for line in lines:
fd1 = filedata[line].rstrip()
fd2 = filedata[line + 1].lstrip()
replaceandrun2('combine lines', filedata, line, fd1 + fd2, '')
def removedirectives(filedata):
for i in range(len(filedata)):
if filedata[i].lstrip().startswith('#'):
replaceandrun('remove preprocessor directive', filedata, i, '')
def removeblocks(filedata):
if len(filedata) < 3:
return filedata
for i in range(len(filedata)):
strippedline = filedata[i].strip()
if len(strippedline) == 0:
continue
if ';{}'.find(strippedline[-1]) < 0:
continue
i1 = i + 1
while i1 < len(filedata) and filedata[i1].startswith('#'):
i1 = i1 + 1
i2 = i1
indent = 0
while i2 < len(filedata):
for c in filedata[i2]:
if c == '}':
indent = indent - 1
if indent == 0:
indent = -100
elif c == '{':
indent = indent + 1
if indent < 0:
break
i2 = i2 + 1
if indent == -100:
indent = 0
if i2 == i1 or i2 >= len(filedata):
continue
if filedata[i2].strip() != '}' and filedata[i2].strip() != '};':
continue
if indent < 0:
i2 = i2 - 1
filedata = clearandrun('remove codeblock', filedata, i1, i2)
return filedata
def removeline(filedata): def removeline(filedata):
stmt = True stmt = True
for i in range(len(filedata)): for i in range(len(filedata)):
line = filedata[i] line = filedata[i]
strippedline = line.strip() strippedline = line.strip()
if len(strippedline) == 0: if len(strippedline) == 0:
continue continue
if stmt and strippedline[-1]==';' and checkpar(line) and line.find('{')<0 and line.find('}')<0: if stmt and strippedline[-1] == ';' and checkpar(line) and line.find('{') < 0 and line.find('}') < 0:
replaceandrun('remove line', filedata, i, '') replaceandrun('remove line', filedata, i, '')
elif stmt and strippedline.find('{') > 0 and strippedline.find('}') == len(strippedline) - 1: elif stmt and strippedline.find('{') > 0 and strippedline.find('}') == len(strippedline) - 1:
replaceandrun('remove line', filedata, i, '') replaceandrun('remove line', filedata, i, '')
if ';{}'.find(strippedline[-1]) >= 0: if ';{}'.find(strippedline[-1]) >= 0:
stmt = True stmt = True
else: else:
stmt = False stmt = False
# reduce.. # reduce..
print('Make sure error can be reproduced...') print('Make sure error can be reproduced...')
if runtool() == False: if runtool() == False:
print("Cannot reproduce") print("Cannot reproduce")
sys.exit(1) sys.exit(1)
f = open(FILE, 'rt') f = open(FILE, 'rt')
filedata = f.readlines() filedata = f.readlines()
@ -235,31 +235,31 @@ f.close()
writefile(BACKUPFILE, filedata) writefile(BACKUPFILE, filedata)
while True: while True:
filedata1 = list(filedata) filedata1 = list(filedata)
print('remove comments...') print('remove comments...')
removecomments(filedata) removecomments(filedata)
print('remove preprocessor directives...') print('remove preprocessor directives...')
removedirectives(filedata) removedirectives(filedata)
print('remove blocks...') print('remove blocks...')
filedata = removeblocks(filedata) filedata = removeblocks(filedata)
print('combine lines..') print('combine lines..')
combinelines(filedata) combinelines(filedata)
print('remove line...') print('remove line...')
removeline(filedata) removeline(filedata)
# if filedata and filedata2 are identical then stop # if filedata and filedata2 are identical then stop
if len(filedata1) == len(filedata): if len(filedata1) == len(filedata):
i = 0 i = 0
while i < len(filedata1): while i < len(filedata1):
if filedata[i] != filedata1[i]: if filedata[i] != filedata1[i]:
break break
i = i + 1 i = i + 1
if i == len(filedata1): if i == len(filedata1):
break break
writefile(FILE, filedata) writefile(FILE, filedata)

View File

@ -10,12 +10,12 @@ import sys
START = 0 START = 0
PASSWORD = '' PASSWORD = ''
for arg in sys.argv[1:]: for arg in sys.argv[1:]:
if len(arg)==1: if len(arg) == 1:
START = '0123456789abcdefghijklmnopqrstuvwxyz'.find(arg) START = '0123456789abcdefghijklmnopqrstuvwxyz'.find(arg)
if START < 0: if START < 0:
START = 0 START = 0
else: else:
PASSWORD = arg PASSWORD = arg
# Upload file to sourceforge web server using scp # Upload file to sourceforge web server using scp
def upload(file_to_upload, destination): def upload(file_to_upload, destination):

View File

@ -21,20 +21,20 @@ import re
import sys import sys
if len(sys.argv) != 2: if len(sys.argv) != 2:
print('revisions not specified') print('revisions not specified')
sys.exit(1) sys.exit(1)
res = re.match(r'([0-9]+):([0-9]+)', sys.argv[1]) res = re.match(r'([0-9]+):([0-9]+)', sys.argv[1])
if res is None: if res is None:
print('invalid format, 11111:22222') print('invalid format, 11111:22222')
sys.exit(1) sys.exit(1)
rev1 = int(res.group(1)) rev1 = int(res.group(1))
rev2 = int(res.group(2)) rev2 = int(res.group(2))
if rev1>rev2 or rev1<10000 or rev2>20000 or rev2-rev1>500: if rev1 > rev2 or rev1 < 10000 or rev2 > 20000 or rev2 - rev1 > 500:
print('range, aborting') print('range, aborting')
sys.exit(1) sys.exit(1)
print('Revisions: ' + str(rev1) + ':' + str(rev2)) print('Revisions: ' + str(rev1) + ':' + str(rev2))
@ -42,17 +42,16 @@ f = open('results.txt', 'wt')
f.write('\n') f.write('\n')
f.close() f.close()
for rev in range(rev1,rev2): for rev in range(rev1, rev2):
subprocess.call(['svn', 'revert', '-R', '.']) subprocess.call(['svn', 'revert', '-R', '.'])
subprocess.call(['svn', 'up', '-r' + str(rev)]) subprocess.call(['svn', 'up', '-r' + str(rev)])
for vcxproj in glob.glob('*/*.vcxproj'): for vcxproj in glob.glob('*/*.vcxproj'):
subprocess.call([r'c:\cygwin64\bin\sed.exe', '-i', 's/140/120/', vcxproj]) subprocess.call([r'c:\cygwin64\bin\sed.exe', '-i', 's/140/120/', vcxproj])
subprocess.call('msbuild cppcheck.sln /t:build /p:configuration=Release,platform=x64'.split()) subprocess.call('msbuild cppcheck.sln /t:build /p:configuration=Release,platform=x64'.split())
print('Revision:' + str(rev)) print('Revision:' + str(rev))
p = subprocess.Popen(r'bin\cppcheck.exe src -q --showtime=summary'.split(), stdout=subprocess.PIPE, stderr=subprocess.PIPE) p = subprocess.Popen(r'bin\cppcheck.exe src -q --showtime=summary'.split(), stdout=subprocess.PIPE, stderr=subprocess.PIPE)
comm = p.communicate() comm = p.communicate()
f = open('results.txt', 'at') f = open('results.txt', 'at')
f.write('\nREV ' + str(rev) + '\n') f.write('\nREV ' + str(rev) + '\n')
f.write(comm[0].decode('utf-8')) f.write(comm[0].decode('utf-8'))
f.close() f.close()