addons: write column in error message(s)

This commit is contained in:
Daniel Marjamäki 2019-04-13 10:22:13 +02:00
parent 1393c1c3a0
commit b1b5b27b4e
5 changed files with 34 additions and 64 deletions

View File

@ -33,11 +33,12 @@ class Directive:
str = None
file = None
linenr = None
col = 0
def __init__(self, element):
self.str = element.get('str')
self.file = element.get('file')
self.linenr = element.get('linenr')
self.linenr = int(element.get('linenr'))
class ValueType:
@ -129,6 +130,7 @@ class Token:
astOperand2 ast operand2
file file name
linenr line number
col column
To iterate through all tokens use such code:
@code
@ -184,6 +186,7 @@ class Token:
file = None
linenr = None
col = None
def __init__(self, element):
self.Id = element.get('id')
@ -222,7 +225,8 @@ class Token:
self.isLogicalOp = True
self.linkId = element.get('link')
self.link = None
self.varId = element.get('varId')
if element.get('varId'):
self.varId = int(element.get('varId'))
self.variableId = element.get('variable')
self.variable = None
self.functionId = element.get('function')
@ -242,7 +246,8 @@ class Token:
self.astOperand2Id = element.get('astOperand2')
self.astOperand2 = None
self.file = element.get('file')
self.linenr = element.get('linenr')
self.linenr = int(element.get('linenr'))
self.col = int(element.get('col'))
def setId(self, IdMap):
self.scope = IdMap[self.scopeId]
@ -792,41 +797,9 @@ def ArgumentParser():
return parser
def reportError(template, callstack=(), severity='', message='', errorId='', suppressions=None, outputFunc=None):
"""
Format an error message according to the template.
:param template: format string, or 'gcc', 'vs' or 'edit'.
:param callstack: e.g. [['file1.cpp',10],['file2.h','20'], ... ]
:param severity: e.g. 'error', 'warning' ...
:param errorId: message ID.
:param message: message text.
"""
# expand predefined templates
if template == 'gcc':
template = '{file}:{line}: {severity}: {message}'
elif template == 'vs':
template = '{file}({line}): {severity}: {message}'
elif template == 'edit':
template = '{file} +{line}: {severity}: {message}'
# compute 'callstack}, {file} and {line} replacements
stack = ' -> '.join('[' + f + ':' + str(l) + ']' for (f, l) in callstack)
file = callstack[-1][0]
line = str(callstack[-1][1])
if suppressions is not None and any(suppression.isMatch(file, line, message, errorId) for suppression in suppressions):
return None
outputLine = template.format(callstack=stack, file=file, line=line,
severity=severity, message=message, id=errorId)
if outputFunc is not None:
outputFunc(outputLine)
# format message
return outputLine
def reportErrorCli(token, severity, message, addon, errorId):
def reportErrorCli(location, severity, message, addon, errorId):
if '--cli' in sys.argv:
errout = sys.stdout
else:
errout = sys.errout
errout.write('[%s:%i]: (%s) %s [%s-%s]\n' % (token.file, int(token.linenr), severity, message, addon, errorId))
errout.write('[%s:%i:%i] (%s) %s [%s-%s]\n' % (location.file, location.linenr, location.col, severity, message, addon, errorId))

View File

@ -2003,30 +2003,20 @@ class MisraChecker:
self.suppressionStats[ruleNum].append(location)
return
else:
id = 'misra-c2012-' + str(num1) + '.' + str(num2)
errorId = 'c2012-' + str(num1) + '.' + str(num2)
severity = 'style'
if ruleNum in self.ruleTexts:
errmsg = self.ruleTexts[ruleNum].text + ' [' + id + ']'
errmsg = self.ruleTexts[ruleNum].text
severity = self.ruleTexts[ruleNum].cppcheck_severity
elif len(self.ruleTexts) == 0:
errmsg = 'misra violation (use --rule-texts=<file> to get proper output) [' + id + ']'
errmsg = 'misra violation (use --rule-texts=<file> to get proper output)'
else:
return
formattedMsg = cppcheckdata.reportError(args.template,
callstack=[(location.file, location.linenr)],
severity=severity,
message = errmsg,
errorId = id,
suppressions = self.dumpfileSuppressions)
if formattedMsg:
if CLI:
print(formattedMsg)
else:
sys.stderr.write(formattedMsg)
sys.stderr.write('\n')
cppcheckdata.reportErrorCli(location, severity, errmsg, 'misra', errorId)
if not severity in self.violations:
self.violations[severity] = []
self.violations[severity].append(id)
self.violations[severity].append(errorId)
def loadRuleTexts(self, filename):
num1 = 0

View File

@ -278,6 +278,7 @@ unsigned int CppCheck::checkFile(const std::string& filename, const std::string
fdump << " <tok "
<< "fileIndex=\"" << tok->location.fileIndex << "\" "
<< "linenr=\"" << tok->location.line << "\" "
<< "col=\"" << tok->location.col << "\" "
<< "str=\"" << ErrorLogger::toxml(tok->str()) << "\""
<< "/>" << std::endl;
}
@ -577,31 +578,36 @@ unsigned int CppCheck::checkFile(const std::string& filename, const std::string
// [test.cpp:123]: (style) some problem [abc-someProblem]
const std::string line = results.substr(pos1, pos2-pos1);
// Line must start with [filename:line]: (
// Line must start with [filename:line:column]: (
const std::string::size_type loc1 = 1;
const std::string::size_type loc2 = line.find(':');
const std::string::size_type loc3 = line.find("]: (");
if (loc2 == std::string::npos || loc3 == std::string::npos)
const std::string::size_type loc4 = line.find("]");
if (loc4 + 5 >= line.size() || line.compare(loc4, 3, "] (", 0, 3) != 0)
continue;
if (!(loc1 < loc2 && loc2 < loc3))
const std::string::size_type loc3 = line.rfind(':', loc4);
if (loc3 == std::string::npos)
continue;
const std::string::size_type loc2 = line.rfind(':', loc3 - 1);
if (loc2 == std::string::npos)
continue;
// Then there must be a (severity)
const std::string::size_type sev1 = loc3 + 4;
const std::string::size_type sev1 = loc4 + 3;
const std::string::size_type sev2 = line.find(")", sev1);
if (sev2 == std::string::npos)
continue;
// line must end with [addon-x]
const std::string::size_type id1 = line.rfind("[" + addonInfo.script + "-");
if (id1 == std::string::npos || id1 < loc3)
if (id1 == std::string::npos || id1 < sev2)
continue;
ErrorLogger::ErrorMessage errmsg;
const std::string filename = line.substr(loc1, loc2-loc1);
const int lineNumber = std::atoi(line.c_str() + loc2 + 1);
const int column = std::atoi(line.c_str() + loc3 + 1);
errmsg._callStack.emplace_back(ErrorLogger::ErrorMessage::FileLocation(filename, lineNumber));
errmsg._callStack.back().col = column;
errmsg._id = line.substr(id1+1, line.size()-id1-2);
std::string text = line.substr(sev2 + 2, id1 - sev2 - 2);

View File

@ -1360,7 +1360,8 @@ void Token::printAst(bool verbose, bool xml, std::ostream &out) const
printed.insert(tok);
if (xml) {
out << "<ast scope=\"" << tok->scope() << "\" fileIndex=\"" << tok->fileIndex() << "\" linenr=\"" << tok->linenr() << "\">" << std::endl;
out << "<ast scope=\"" << tok->scope() << "\" fileIndex=\"" << tok->fileIndex() << "\" linenr=\"" << tok->linenr()
<< "\" col=\"" << tok->col() << "\">" << std::endl;
astStringXml(tok, 2U, out);
out << "</ast>" << std::endl;
} else if (verbose)

View File

@ -4696,7 +4696,7 @@ void Tokenizer::dump(std::ostream &out) const
// tokens..
out << " <tokenlist>" << std::endl;
for (const Token *tok = list.front(); tok; tok = tok->next()) {
out << " <token id=\"" << tok << "\" file=\"" << ErrorLogger::toxml(list.file(tok)) << "\" linenr=\"" << tok->linenr() << '\"';
out << " <token id=\"" << tok << "\" file=\"" << ErrorLogger::toxml(list.file(tok)) << "\" linenr=\"" << tok->linenr() << "\" col=\"" << tok->col() << "\"";
out << " str=\"" << ErrorLogger::toxml(tok->str()) << '\"';
out << " scope=\"" << tok->scope() << '\"';
if (tok->isName()) {