1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
#!/usr/bin/env python
# Convert output from Google's cpplint.py to the cppcheck XML format for
# consumption by the Jenkins cppcheck plugin.
# Reads from stdin and writes to stderr (to mimic cppcheck)
import sys
import re
import xml.sax.saxutils
def cpplint_score_to_cppcheck_severity(score):
# I'm making this up
if score == 1:
return 'style'
elif score == 2:
return 'style'
elif score == 3:
return 'warning'
elif score == 4:
return 'warning'
elif score == 5:
return 'error'
def parse():
# TODO: do this properly, using the xml module.
# Write header
sys.stderr.write('''<?xml version="1.0" encoding="UTF-8"?>\n''')
sys.stderr.write('''<results>\n''')
# Do line-by-line conversion
r = re.compile('([^:]*):([0-9]*): ([^\[]*)\[([^\]]*)\] \[([0-9]*)\].*')
for l in sys.stdin.readlines():
m = r.match(l.strip())
if not m:
continue
g = m.groups()
if len(g) != 5:
continue
fname, lineno, rawmsg, label, score = g
# Protect Jenkins from bad XML, which makes it barf
msg = xml.sax.saxutils.escape(rawmsg)
severity = cpplint_score_to_cppcheck_severity(int(score))
sys.stderr.write('''<error file="%s" line="%s" id="%s" severity="%s" msg="%s"/>\n'''%(fname, lineno, label, severity, msg))
# Write footer
sys.stderr.write('''</results>\n''')
if __name__ == '__main__':
parse()
|