Mini Shell
import os
import re
from prospector.formatters.base import Formatter
class PylintFormatter(Formatter):
"""
This formatter outputs messages in the same way as pylint -f parseable , which is used by several
tools to parse pylint output. This formatter is therefore a compatibility shim between tools built
on top of pylint and prospector itself.
"""
def render(self, summary=True, messages=True, profile=False):
# this formatter will always ignore the summary and profile
cur_loc = None
output = []
for message in sorted(self.messages):
if cur_loc != message.location.path:
cur_loc = message.location.path
module_name = self._make_path(message.location.path).replace(os.path.sep, ".")
module_name = re.sub(r"(\.__init__)?\.py$", "", module_name)
header = "************* Module %s" % module_name
output.append(header)
# ={path}:{line}: [{msg_id}({symbol}), {obj}] {msg}
# prospector/configuration.py:65: [missing-docstring(missing-docstring), build_default_sources] \
# Missing function docstring
template = "%(path)s:%(line)s: [%(code)s(%(source)s), %(function)s] %(message)s"
output.append(
template
% {
"path": self._make_path(message.location.path),
"line": message.location.line,
"source": message.source,
"code": message.code,
"function": message.location.function,
"message": message.message.strip(),
}
)
return "\n".join(output)
Zerion Mini Shell 1.0