mirror of
https://github.com/status-im/status-go.git
synced 2025-01-18 10:42:07 +00:00
Summary: Filter out gas linter error checks for fmt.Fprintf commands. This required defining a custom linter around gas that additionally included the offending code. Notes: Gas format, without piping it through gometalinter, gives output like this: $ gas -fmt=csv geth/jail/console/console.go geth/jail/console/console.go,21,Errors unhandled.,LOW,HIGH,"fmt.Fprintf(w, ""%s: %s"", consoleEventName, formatForConsole(fn.ArgumentList))" Gometalinter, by default, does not grab the line of code when it filters gas errors. To resolve this, I created a wrapper around gas (I wasn't sure what to call this "gas wrapper", I opted for gasv2, open to other names). The first part of the regular expression was taken directly from gometalinter (see https://github.com/alecthomas/gometalinter/blob/master/linters.go#L236), and I then appended ,\".*\" to additionally grab the line of code of the offending line. Lastly, I excluded ".*Errors unhandled.*fmt.Fprintf.*" to filter out only fmt.Fprintf errors around omitted errors. Also as a result of this change, gas lint output will now include the offending code. Closes #590
This commit is contained in:
parent
15c72f3c6b
commit
228bda9fb3
@ -1,15 +1,22 @@
|
|||||||
{
|
{
|
||||||
"Exclude": [
|
"Exclude": [
|
||||||
".*_mock.go",
|
".*_mock.go",
|
||||||
"geth/jail/doc.go"
|
"geth/jail/doc.go",
|
||||||
|
".*Errors unhandled.*fmt.Fprint.*gasv2.*"
|
||||||
],
|
],
|
||||||
"Skip": ["helpers", "static"],
|
"Skip": ["helpers", "static"],
|
||||||
"Vendor": true,
|
"Vendor": true,
|
||||||
"Test": true,
|
"Test": true,
|
||||||
|
"Linters": {
|
||||||
|
"gasv2": {
|
||||||
|
"Command": "gas -fmt=csv",
|
||||||
|
"Pattern": "^(?P<path>.*?\\.go),(?P<line>\\d+),(?P<message>[^,]+,[^,]+,[^,]+,\".*\")"
|
||||||
|
}
|
||||||
|
},
|
||||||
"Enable": [
|
"Enable": [
|
||||||
"deadcode",
|
"deadcode",
|
||||||
"errcheck",
|
"errcheck",
|
||||||
"gas",
|
"gasv2",
|
||||||
"goconst",
|
"goconst",
|
||||||
"gocyclo",
|
"gocyclo",
|
||||||
"gofmt",
|
"gofmt",
|
||||||
|
@ -276,7 +276,7 @@ Examples:
|
|||||||
|
|
||||||
Options:
|
Options:
|
||||||
`
|
`
|
||||||
fmt.Fprint(os.Stderr, usage) // nolint: gas
|
fmt.Fprintf(os.Stderr, usage)
|
||||||
flag.PrintDefaults()
|
flag.PrintDefaults()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -131,9 +131,9 @@ func Fatalf(reason interface{}, args ...interface{}) {
|
|||||||
// find out whether error or string has been passed as a reason
|
// find out whether error or string has been passed as a reason
|
||||||
r := reflect.ValueOf(reason)
|
r := reflect.ValueOf(reason)
|
||||||
if r.Kind() == reflect.String {
|
if r.Kind() == reflect.String {
|
||||||
fmt.Fprintf(w, "Fatal Failure: %v\n%v\n", reason.(string), args) //nolint: gas
|
fmt.Fprintf(w, "Fatal Failure: %v\n%v\n", reason.(string), args)
|
||||||
} else {
|
} else {
|
||||||
fmt.Fprintf(w, "Fatal Failure: %v\n", reason.(error)) //nolint: gas
|
fmt.Fprintf(w, "Fatal Failure: %v\n", reason.(error))
|
||||||
}
|
}
|
||||||
|
|
||||||
debug.PrintStack()
|
debug.PrintStack()
|
||||||
|
@ -18,7 +18,7 @@ func Write(fn otto.FunctionCall, w io.Writer, consoleEventName string) otto.Valu
|
|||||||
})
|
})
|
||||||
|
|
||||||
// Next print out the giving values.
|
// Next print out the giving values.
|
||||||
fmt.Fprintf(w, "%s: %s", consoleEventName, formatForConsole(fn.ArgumentList)) // nolint: gas
|
fmt.Fprintf(w, "%s: %s", consoleEventName, formatForConsole(fn.ArgumentList))
|
||||||
|
|
||||||
return otto.UndefinedValue()
|
return otto.UndefinedValue()
|
||||||
}
|
}
|
||||||
|
@ -91,7 +91,7 @@ func SetLogFile(filename string) error {
|
|||||||
func levelFromString(level string) log.Lvl {
|
func levelFromString(level string) log.Lvl {
|
||||||
lvl, err := log.LvlFromString(strings.ToLower(level))
|
lvl, err := log.LvlFromString(strings.ToLower(level))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Fprintf(os.Stderr, "Incorrect log level: %s, using defaults\n", level) // nolint: gas
|
fmt.Fprintf(os.Stderr, "Incorrect log level: %s, using defaults\n", level)
|
||||||
lvl = log.LvlInfo
|
lvl = log.LvlInfo
|
||||||
}
|
}
|
||||||
return lvl
|
return lvl
|
||||||
|
Loading…
x
Reference in New Issue
Block a user