mirror of
https://github.com/mgechev/revive.git
synced 2025-01-10 03:17:11 +02:00
55cfae63e9
* adds support for comments when enabling/disabling * adds config flag to require disabling reason * Update lint/file.go adds code fmt suggestion by @mgechev Co-Authored-By: Minko Gechev <mgechev@gmail.com> * moves regexp compilation out of the function fix typo in condition * adds support for comments when enabling/disabling * skips incomplete directives and generate a failure * adds _directive_ concept to cope with specify-disable-reason * adds doc gofmt * fixes severity is ignored
41 lines
883 B
Go
41 lines
883 B
Go
package formatter
|
|
|
|
import (
|
|
"encoding/json"
|
|
|
|
"github.com/mgechev/revive/lint"
|
|
)
|
|
|
|
// JSON is an implementation of the Formatter interface
|
|
// which formats the errors to JSON.
|
|
type JSON struct {
|
|
Metadata lint.FormatterMetadata
|
|
}
|
|
|
|
// Name returns the name of the formatter
|
|
func (f *JSON) Name() string {
|
|
return "json"
|
|
}
|
|
|
|
// jsonObject defines a JSON object of an failure
|
|
type jsonObject struct {
|
|
Severity lint.Severity
|
|
lint.Failure `json:",inline"`
|
|
}
|
|
|
|
// Format formats the failures gotten from the lint.
|
|
func (f *JSON) Format(failures <-chan lint.Failure, config lint.Config) (string, error) {
|
|
var slice []jsonObject
|
|
for failure := range failures {
|
|
obj := jsonObject{}
|
|
obj.Severity = severity(config, failure)
|
|
obj.Failure = failure
|
|
slice = append(slice, obj)
|
|
}
|
|
result, err := json.Marshal(slice)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
return string(result), err
|
|
}
|