cppcheck/tools/daca2.py

247 lines
7.0 KiB
Python
Raw Normal View History

2013-10-12 16:55:21 +02:00
#!/usr/bin/python
#
# 1. Create a folder daca2 in your HOME folder
# 2. Put cppcheck-O2 in daca2. It should be built with all optimisations.
2013-10-19 13:46:15 +02:00
# 3. Optional: Put a file called "suppressions.txt" in the daca2 folder.
# 4. Optional: tweak FTPSERVER and FTPPATH in this script below.
# 5. Run the daca2 script: python daca2.py FOLDER
import subprocess
import sys
import shutil
import glob
import os
2013-10-13 11:47:51 +02:00
import datetime
import time
2015-09-28 09:08:37 +02:00
DEBIAN = ['ftp://ftp.se.debian.org/debian/',
'ftp://ftp.debian.org/debian/']
def wget(filepath):
filename = filepath
if filepath.find('/') >= 0:
filename = filename[filename.rfind('/') + 1:]
for d in DEBIAN:
subprocess.call(
2014-02-23 10:21:00 +01:00
['nice', 'wget', '--tries=10', '--timeout=300', '-O', filename, d + filepath])
if os.path.isfile(filename):
return True
2013-10-27 07:53:23 +01:00
print('Sleep for 10 seconds..')
time.sleep(10)
return False
2013-10-19 13:46:15 +02:00
2013-10-20 12:45:05 +02:00
2013-10-19 13:46:15 +02:00
def getpackages(folder):
if not wget('ls-lR.gz'):
return []
2013-10-24 18:22:15 +02:00
subprocess.call(['nice', 'gunzip', 'ls-lR.gz'])
f = open('ls-lR', 'rt')
lines = f.readlines()
f.close()
subprocess.call(['rm', 'ls-lR'])
path = None
2013-10-19 13:46:15 +02:00
archives = []
2013-10-24 18:22:15 +02:00
filename = None
for line in lines:
2013-10-24 18:36:08 +02:00
line = line.strip()
2013-10-24 18:22:15 +02:00
if len(line) < 4:
if filename:
archives.append(path + '/' + filename)
path = None
filename = None
elif line[:13 + len(folder)] == './pool/main/' + folder + '/':
2013-10-24 18:36:08 +02:00
path = line[2:-1]
2013-10-24 18:22:15 +02:00
elif path and line.find('.orig.tar.') > 0:
filename = line[1 + line.rfind(' '):]
2013-10-19 13:46:15 +02:00
2013-10-24 18:36:08 +02:00
for a in archives:
print(a)
2013-10-19 13:46:15 +02:00
return archives
2013-10-12 16:55:21 +02:00
2013-10-18 17:35:59 +02:00
2013-10-14 15:49:11 +02:00
def handleRemoveReadonly(func, path, exc):
import stat
if not os.access(path, os.W_OK):
# Is the error an access error ?
os.chmod(path, stat.S_IWUSR)
func(path)
else:
raise
2013-10-18 17:35:59 +02:00
def removeAllExceptResults():
filenames = []
for g in glob.glob('[A-Za-z0-9]*'):
filenames.append(g)
for g in glob.glob('.[a-z]*'):
filenames.append(g)
for filename in filenames:
count = 5
while count > 0:
count = count - 1
try:
2013-10-16 17:22:00 +02:00
if os.path.isdir(filename):
shutil.rmtree(filename, onerror=handleRemoveReadonly)
elif filename != 'results.txt':
os.remove(filename)
break
except WindowsError as err:
time.sleep(30)
if count == 0:
f = open('results.txt','at')
f.write('Failed to cleanup ' + filename + ': ' + str(err))
f.close()
except OSError as err:
time.sleep(30)
if count == 0:
f = open('results.txt','at')
f.write('Failed to cleanup ' + filename + ': ' + str(err))
f.close()
2013-10-18 17:35:59 +02:00
2013-10-18 04:53:14 +02:00
def removeLargeFiles(path):
for g in glob.glob(path + '*'):
2013-10-18 17:35:59 +02:00
if g == '.' or g == '..':
2013-10-18 04:53:14 +02:00
continue
2013-11-18 17:59:47 +01:00
if os.path.islink(g):
continue
2013-10-18 04:53:14 +02:00
if os.path.isdir(g):
# Remove test code
if g.endswith('/testsuite') or g.endswith('/clang/INPUTS'):
shutil.rmtree(g, onerror=handleRemoveReadonly)
else:
removeLargeFiles(g + '/')
elif os.path.isfile(g) and g[-4:] != '.txt':
2013-10-18 04:53:14 +02:00
statinfo = os.stat(g)
if statinfo.st_size > 1000000:
try:
os.remove(g)
except OSError as err:
f = open('results.txt','at')
f.write('Failed to remove ' + g + ': ' + str(err))
f.close()
2013-10-13 08:07:39 +02:00
2016-07-22 08:31:00 +02:00
def strfCurrTime(fmt):
return datetime.time.strftime(datetime.datetime.now().time(), fmt)
2013-10-18 17:35:59 +02:00
2016-09-20 12:46:15 +02:00
def scanarchive(filepath, jobs, cpulimit):
2013-10-27 07:53:23 +01:00
# remove all files/folders except results.txt
removeAllExceptResults()
results = open('results.txt', 'at')
results.write(DEBIAN[0] + filepath + '\n')
results.close()
2013-10-13 11:10:22 +02:00
if not wget(filepath):
if not wget(filepath):
results = open('results.txt', 'at')
results.write('wget failed\n')
results.close()
return
2013-10-24 17:39:37 +02:00
filename = filepath[filepath.rfind('/') + 1:]
if filename[-3:] == '.gz':
subprocess.call(['tar', 'xzvf', filename])
2013-10-20 12:45:05 +02:00
elif filename[-3:] == '.xz':
subprocess.call(['tar', 'xJvf', filename])
elif filename[-4:] == '.bz2':
subprocess.call(['tar', 'xjvf', filename])
2013-10-13 11:10:22 +02:00
removeLargeFiles('')
2016-07-23 13:44:05 +02:00
print(strfCurrTime('[%H:%M] cppcheck ') + filename)
2016-09-20 12:46:15 +02:00
if cpulimit:
cmd = 'cpulimit --limit=' + cpulimit
2016-09-20 12:46:15 +02:00
else:
cmd = 'nice --adjustment=1000'
2016-12-06 11:19:33 +01:00
cmd = cmd + ' ../cppcheck-O2 -D__GCC__ --enable=style --inconclusive --error-exitcode=0 --exception-handling=stderr ' + jobs + ' .'
cmds = cmd.split()
cmds.append('--template={callstack}: ({severity}) {message} [{id}]')
2016-09-20 12:46:15 +02:00
p = subprocess.Popen(cmds, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
2013-10-13 11:10:22 +02:00
comm = p.communicate()
results = open('results.txt', 'at')
2013-12-31 20:56:16 +01:00
if p.returncode == 0:
2016-07-22 08:31:00 +02:00
results.write(comm[1] + strfCurrTime('[%H:%M]') + '\n')
2013-12-31 20:56:16 +01:00
elif comm[0].find('cppcheck: error: could not find or open any of the paths given.') < 0:
2016-07-22 08:31:00 +02:00
results.write(comm[1] + strfCurrTime('[%H:%M]') + '\n')
results.write('Exit code is not zero! Crash?\n')
results.write('\n')
2013-10-13 11:10:22 +02:00
results.close()
2013-10-20 10:49:54 +02:00
FOLDER = None
2014-10-11 18:04:53 +02:00
JOBS = '-j1'
2013-10-20 10:49:54 +02:00
REV = None
SKIP = []
2016-09-20 12:46:15 +02:00
WORKDIR = os.path.expanduser('~/daca2')
CPULIMIT = None
2013-10-20 10:49:54 +02:00
for arg in sys.argv[1:]:
if arg[:6] == '--rev=':
REV = arg[6:]
2014-10-11 18:04:53 +02:00
elif arg[:2] == '-j':
JOBS = arg
2016-09-20 12:46:15 +02:00
elif arg.startswith('--skip='):
SKIP.append(arg[7:])
2016-09-20 12:46:15 +02:00
elif arg.startswith('--workdir='):
WORKDIR = arg[10:]
2016-09-20 12:46:15 +02:00
elif arg.startswith('--cpulimit='):
CPULIMIT = arg[11:]
2013-10-20 10:49:54 +02:00
else:
FOLDER = arg
2013-10-20 11:28:16 +02:00
if not FOLDER:
print('no folder given')
sys.exit(1)
if not os.path.isdir(WORKDIR):
print('workdir \'' + WORKDIR + '\' is not a folder')
sys.exit(1)
2013-10-19 13:46:15 +02:00
archives = getpackages(FOLDER)
2013-10-24 17:39:37 +02:00
if len(archives) == 0:
print('failed to load packages')
sys.exit(1)
if not WORKDIR.endswith('/'):
WORKDIR = WORKDIR + '/'
print('~/daca2/' + FOLDER)
if not os.path.isdir(WORKDIR + FOLDER):
os.makedirs(WORKDIR + FOLDER)
os.chdir(WORKDIR + FOLDER)
2013-10-13 11:10:22 +02:00
try:
2013-10-13 11:43:05 +02:00
results = open('results.txt', 'wt')
results.write('STARTDATE ' + str(datetime.date.today()) + '\n')
2016-07-22 08:31:00 +02:00
results.write('STARTTIME ' + strfCurrTime('%H:%M:%S') + '\n')
2013-10-20 10:49:54 +02:00
if REV:
results.write('GIT-REVISION ' + REV + '\n')
results.write('\n')
2013-10-13 11:43:05 +02:00
results.close()
for archive in archives:
if len(SKIP) > 0:
a = archive[:archive.rfind('/')]
a = a[a.rfind('/')+1:]
if a in SKIP:
continue
2016-09-20 12:46:15 +02:00
scanarchive(archive, JOBS, CPULIMIT)
2013-10-13 08:07:39 +02:00
results = open('results.txt', 'at')
results.write('DATE ' + str(datetime.date.today()) + '\n')
2016-07-22 08:31:00 +02:00
results.write('TIME ' + strfCurrTime('%H:%M:%S') + '\n')
results.close()
2013-10-13 13:10:25 +02:00
except EOFError:
pass
# remove all files/folders except results.txt
removeAllExceptResults()