diff options
-rwxr-xr-x | .arc-linters/check-cpp.py | 37 | ||||
-rw-r--r-- | .arclint | 5 |
2 files changed, 42 insertions, 0 deletions
diff --git a/.arc-linters/check-cpp.py b/.arc-linters/check-cpp.py new file mode 100755 index 0000000000..3794ca2cee --- /dev/null +++ b/.arc-linters/check-cpp.py @@ -0,0 +1,37 @@ +#!/usr/bin/env python + +# A linter to warn for ASSERT macros which are separated from their argument +# list by a space, which Clang's CPP barfs on + +import sys +import logging +import os +import json +import re + + +def setup_logging(): + logger = logging.getLogger() + hdlr = logging.FileHandler('linter.log', 'w') + logger.addHandler(hdlr) + logger.setLevel(logging.DEBUG) + return logger + +logger = setup_logging() +#logger.debug(sys.argv) + +path = sys.argv[1] +warnings = [] +if os.path.isfile(path): + with open(path) as f: + for lineno, line in enumerate(f): + if re.search('ASSERT \(', line) is not None: + warning = { + 'severity': 'warning', + 'message': 'CPP macros should not have a space between the macro name and their argument list', + 'line': lineno+1, + } + warnings.append(warning) + +logger.debug(warnings) +print json.dumps(warnings) @@ -56,6 +56,11 @@ "check-binaries": { "type": "external-json", "external-json.script": "python .arc-linters/check-binaries.py" + }, + "bad-assert-clang-cpp": { + "type": "external-json", + "include": ["(\\.(l?hs|x|y\\.pp)(\\.in)?$)"], + "external-json.script": "python .arc-linters/check-cpp.py" } }, |