add built-in report formats incl. GitHub Actions
use on ourself and enable unused variables test to do first test in CI
This commit is contained in:
parent
5c2035ff76
commit
83eb9c5c2e
|
@ -23,7 +23,7 @@ if_else_same_check="enabled"
|
||||||
; Checks for some problems with constructors
|
; Checks for some problems with constructors
|
||||||
constructor_check="enabled"
|
constructor_check="enabled"
|
||||||
; Checks for unused variables and function parameters
|
; Checks for unused variables and function parameters
|
||||||
unused_variable_check="disabled"
|
unused_variable_check="enabled"
|
||||||
; Checks for unused labels
|
; Checks for unused labels
|
||||||
unused_label_check="enabled"
|
unused_label_check="enabled"
|
||||||
; Checks for duplicate attributes
|
; Checks for duplicate attributes
|
||||||
|
|
|
@ -135,7 +135,7 @@ jobs:
|
||||||
else
|
else
|
||||||
EXE=""
|
EXE=""
|
||||||
fi
|
fi
|
||||||
"./bin/dscanner$EXE" --config .dscanner.ini --styleCheck src
|
"./bin/dscanner$EXE" --config .dscanner.ini --styleCheck -f github src
|
||||||
|
|
||||||
# Parse phobos to check for failures / crashes / ...
|
# Parse phobos to check for failures / crashes / ...
|
||||||
- name: Checkout Phobos
|
- name: Checkout Phobos
|
||||||
|
|
|
@ -101,6 +101,16 @@ private alias ASTAllocator = CAllocatorImpl!(
|
||||||
|
|
||||||
immutable string defaultErrorFormat = "{filepath}({line}:{column})[{type}]: {message}";
|
immutable string defaultErrorFormat = "{filepath}({line}:{column})[{type}]: {message}";
|
||||||
|
|
||||||
|
string[string] errorFormatMap()
|
||||||
|
{
|
||||||
|
static string[string] ret;
|
||||||
|
if (ret is null)
|
||||||
|
ret = [
|
||||||
|
"github": "::{type2} file={filepath},line={line},endLine={endLine},col={column},endColumn={endColumn},title={Type2} ({name})::{message}"
|
||||||
|
];
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
void messageFunctionFormat(string format, Message message, bool isError)
|
void messageFunctionFormat(string format, Message message, bool isError)
|
||||||
{
|
{
|
||||||
auto s = format;
|
auto s = format;
|
||||||
|
@ -111,6 +121,11 @@ void messageFunctionFormat(string format, Message message, bool isError)
|
||||||
s = s.replace("{endLine}", to!string(message.endLine));
|
s = s.replace("{endLine}", to!string(message.endLine));
|
||||||
s = s.replace("{endColumn}", to!string(message.endColumn));
|
s = s.replace("{endColumn}", to!string(message.endColumn));
|
||||||
s = s.replace("{type}", isError ? "error" : "warn");
|
s = s.replace("{type}", isError ? "error" : "warn");
|
||||||
|
s = s.replace("{Type}", isError ? "Error" : "Warn");
|
||||||
|
s = s.replace("{TYPE}", isError ? "ERROR" : "WARN");
|
||||||
|
s = s.replace("{type2}", isError ? "error" : "warning");
|
||||||
|
s = s.replace("{Type2}", isError ? "Error" : "Warning");
|
||||||
|
s = s.replace("{TYPE2}", isError ? "ERROR" : "WARNING");
|
||||||
s = s.replace("{message}", message.message);
|
s = s.replace("{message}", message.message);
|
||||||
s = s.replace("{name}", message.checkName);
|
s = s.replace("{name}", message.checkName);
|
||||||
|
|
||||||
|
|
|
@ -167,6 +167,8 @@ else
|
||||||
|
|
||||||
if (!errorFormat.length)
|
if (!errorFormat.length)
|
||||||
errorFormat = defaultErrorFormat;
|
errorFormat = defaultErrorFormat;
|
||||||
|
else if (auto errorFormatSuppl = errorFormat in errorFormatMap)
|
||||||
|
errorFormat = *errorFormatSuppl;
|
||||||
|
|
||||||
const(string[]) absImportPaths = importPaths.map!(a => a.absolutePath()
|
const(string[]) absImportPaths = importPaths.map!(a => a.absolutePath()
|
||||||
.buildNormalizedPath()).array();
|
.buildNormalizedPath()).array();
|
||||||
|
@ -405,8 +407,22 @@ Options:
|
||||||
--errorFormat|f <pattern>
|
--errorFormat|f <pattern>
|
||||||
Format errors produced by the style/syntax checkers. The default
|
Format errors produced by the style/syntax checkers. The default
|
||||||
value for the pattern is: "%2$s".
|
value for the pattern is: "%2$s".
|
||||||
Supported placeholders are: {filepath}, {line}, {column}, {type},
|
|
||||||
{endLine}, {endColumn}, {message}, and {name}.
|
Supported placeholders are:
|
||||||
|
- {filepath}: file path, usually relative to CWD
|
||||||
|
- {line}: start line number, 1-based
|
||||||
|
- {endLine}: end line number, 1-based, inclusive
|
||||||
|
- {column}: start column on start line, 1-based, in bytes
|
||||||
|
- {endColumn}: end column on end line, 1-based, in bytes, exclusive
|
||||||
|
- {type}: "error" or "warn", uppercase variants: {Type}, {TYPE},
|
||||||
|
- {type2}: "error" or "warning", uppercase variants: {Type2}, {TYPE2}
|
||||||
|
- {message}: human readable message such as "Variable c is never used."
|
||||||
|
- {name}: D-Scanner check name such as "unused_variable_check"
|
||||||
|
|
||||||
|
For compatibility with other tools, the following strings may be
|
||||||
|
specified as shorthand aliases:
|
||||||
|
|
||||||
|
%3$(-f %1$s -> %2$s\n %)
|
||||||
|
|
||||||
--ctags <file | directory>..., -c <file | directory>...
|
--ctags <file | directory>..., -c <file | directory>...
|
||||||
Generates ctags information from the given source code file. Note that
|
Generates ctags information from the given source code file. Note that
|
||||||
|
@ -453,7 +469,7 @@ Options:
|
||||||
Does not analyze code in unittests. Only works if --styleCheck
|
Does not analyze code in unittests. Only works if --styleCheck
|
||||||
is specified.`,
|
is specified.`,
|
||||||
|
|
||||||
programName, defaultErrorFormat);
|
programName, defaultErrorFormat, errorFormatMap);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void doNothing(string, size_t, size_t, string, bool)
|
private void doNothing(string, size_t, size_t, string, bool)
|
||||||
|
|
Loading…
Reference in New Issue