package formatter import ( "bytes" "encoding/xml" "github.com/mgechev/revive/lint" plainTemplate "text/template" ) // Checkstyle is an implementation of the Formatter interface // which formats the errors to Checkstyle-like format. type Checkstyle struct { Metadata lint.FormatterMetadata } // Name returns the name of the formatter func (f *Checkstyle) Name() string { return "checkstyle" } type issue struct { Line int Col int What string Confidence float64 Severity lint.Severity RuleName string } // Format formats the failures gotten from the lint. func (f *Checkstyle) Format(failures <-chan lint.Failure, config lint.RulesConfig) (string, error) { var issues = map[string][]issue{} for failure := range failures { buf := new(bytes.Buffer) xml.Escape(buf, []byte(failure.Failure)) what := buf.String() iss := issue{ Line: failure.Position.Start.Line, Col: failure.Position.Start.Column, What: what, Confidence: failure.Confidence, Severity: severity(config, failure), RuleName: failure.RuleName, } fn := failure.GetFilename() if issues[fn] == nil { issues[fn] = make([]issue, 0) } issues[fn] = append(issues[fn], iss) } t, err := plainTemplate.New("revive").Parse(checkstyleTemplate) if err != nil { return "", err } buf := new(bytes.Buffer) err = t.Execute(buf, issues) if err != nil { return "", err } return buf.String(), nil } const checkstyleTemplate = ` {{- range $k, $v := . }} {{- range $i, $issue := $v }} {{- end }} {{- end }} `