2018-07-14 00:01:27 +02:00
|
|
|
package formatter
|
|
|
|
|
|
|
|
import (
|
2023-10-29 02:05:08 -05:00
|
|
|
"bytes"
|
2018-07-14 00:01:27 +02:00
|
|
|
"encoding/json"
|
|
|
|
|
|
|
|
"github.com/mgechev/revive/lint"
|
|
|
|
)
|
|
|
|
|
|
|
|
// NDJSON is an implementation of the Formatter interface
|
|
|
|
// which formats the errors to NDJSON stream.
|
|
|
|
type NDJSON struct {
|
|
|
|
Metadata lint.FormatterMetadata
|
|
|
|
}
|
|
|
|
|
|
|
|
// Name returns the name of the formatter
|
2022-04-10 11:55:13 +02:00
|
|
|
func (*NDJSON) Name() string {
|
2018-07-14 00:01:27 +02:00
|
|
|
return "ndjson"
|
|
|
|
}
|
|
|
|
|
|
|
|
// Format formats the failures gotten from the lint.
|
2022-04-10 11:55:13 +02:00
|
|
|
func (*NDJSON) Format(failures <-chan lint.Failure, config lint.Config) (string, error) {
|
2023-10-29 02:05:08 -05:00
|
|
|
var buf bytes.Buffer
|
|
|
|
enc := json.NewEncoder(&buf)
|
2018-07-14 00:01:27 +02:00
|
|
|
for failure := range failures {
|
|
|
|
obj := jsonObject{}
|
|
|
|
obj.Severity = severity(config, failure)
|
|
|
|
obj.Failure = failure
|
|
|
|
err := enc.Encode(obj)
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
}
|
2023-10-29 02:05:08 -05:00
|
|
|
return buf.String(), nil
|
2018-07-14 00:01:27 +02:00
|
|
|
}
|