2017-08-29 19:47:29 +02:00
|
|
|
package formatter
|
2017-08-28 01:57:16 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
|
2018-01-25 01:44:03 +02:00
|
|
|
"github.com/mgechev/revive/lint"
|
2017-08-28 01:57:16 +02:00
|
|
|
)
|
|
|
|
|
2018-01-28 03:01:18 +02:00
|
|
|
// JSON is an implementation of the Formatter interface
|
2017-08-28 01:57:16 +02:00
|
|
|
// which formats the errors to JSON.
|
2018-01-28 03:01:18 +02:00
|
|
|
type JSON struct {
|
2018-01-25 01:44:03 +02:00
|
|
|
Metadata lint.FormatterMetadata
|
2017-08-28 01:57:16 +02:00
|
|
|
}
|
|
|
|
|
2018-01-28 02:22:17 +02:00
|
|
|
// Name returns the name of the formatter
|
2018-01-28 03:01:18 +02:00
|
|
|
func (f *JSON) Name() string {
|
2018-01-28 02:22:17 +02:00
|
|
|
return "json"
|
|
|
|
}
|
|
|
|
|
2018-01-25 01:44:03 +02:00
|
|
|
// Format formats the failures gotten from the lint.
|
2018-01-28 03:01:18 +02:00
|
|
|
func (f *JSON) Format(failures <-chan lint.Failure, config lint.RulesConfig) (string, error) {
|
2018-01-25 01:44:03 +02:00
|
|
|
var slice []lint.Failure
|
2018-01-24 04:19:06 +02:00
|
|
|
for failure := range failures {
|
|
|
|
slice = append(slice, failure)
|
2017-08-28 01:57:16 +02:00
|
|
|
}
|
2018-01-24 04:19:06 +02:00
|
|
|
result, err := json.Marshal(slice)
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
return string(result), err
|
2017-08-28 01:57:16 +02:00
|
|
|
}
|