iperf3exporter/vendor/github.com/phayes/checkstyle/checkstyle.go
Marvin Preuss 2343c9588a
Some checks failed
continuous-integration/drone/push Build is passing
continuous-integration/drone/tag Build is failing
first commit
2021-10-20 10:08:56 +02:00

113 lines
3.0 KiB
Go

package checkstyle
import "encoding/xml"
import "io/ioutil"
// DefaultCheckStyleVersion defines the default "version" attribute on "<checkstyle>" lememnt
var DefaultCheckStyleVersion = "1.0.0"
// Severity defines a checkstyle severity code
type Severity string
var (
SeverityError Severity = "error"
SeverityInfo Severity = "info"
SeverityWarning Severity = "warning"
SeverityIgnore Severity = "ignore"
SeverityNone Severity
)
// CheckStyle represents a <checkstyle> xml element found in a checkstyle_report.xml file.
type CheckStyle struct {
XMLName xml.Name `xml:"checkstyle"`
Version string `xml:"version,attr"`
File []*File `xml:"file"`
}
// AddFile adds a checkstyle.File with the given filename.
func (cs *CheckStyle) AddFile(csf *File) {
cs.File = append(cs.File, csf)
}
// GetFile gets a CheckStyleFile with the given filename.
func (cs *CheckStyle) GetFile(filename string) (csf *File, ok bool) {
for _, file := range cs.File {
if file.Name == filename {
csf = file
ok = true
return
}
}
return
}
// EnsureFile ensures that a CheckStyleFile with the given name exists
// Returns either an exiting CheckStyleFile (if a file with that name exists)
// or a new CheckStyleFile (if a file with that name does not exists)
func (cs *CheckStyle) EnsureFile(filename string) (csf *File) {
csf, ok := cs.GetFile(filename)
if !ok {
csf = NewFile(filename)
cs.AddFile(csf)
}
return csf
}
// String implements Stringer. Returns as xml.
func (cs *CheckStyle) String() string {
checkStyleXML, err := xml.Marshal(cs)
if err != nil {
panic(err)
}
return string(checkStyleXML)
}
// New returns a new CheckStyle
func New() *CheckStyle {
return &CheckStyle{Version: DefaultCheckStyleVersion, File: []*File{}}
}
// File represents a <file> xml element.
type File struct {
XMLName xml.Name `xml:"file"`
Name string `xml:"name,attr"`
Error []*Error `xml:"error"`
}
// AddError adds a checkstyle.Error to the file.
func (csf *File) AddError(cse *Error) {
csf.Error = append(csf.Error, cse)
}
// NewFile creates a new checkstyle.File
func NewFile(filename string) *File {
return &File{Name: filename, Error: []*Error{}}
}
// Error represents a <error> xml element
type Error struct {
XMLName xml.Name `xml:"error"`
Line int `xml:"line,attr"`
Column int `xml:"column,attr,omitempty"`
Severity Severity `xml:"severity,attr,omitempty"`
Message string `xml:"message,attr"`
Source string `xml:"source,attr"`
}
// NewError creates a new checkstyle.Error
// Note that line starts at 0, and column starts at 1
func NewError(line int, column int, severity Severity, message string, source string) *Error {
return &Error{Line: line, Column: column, Severity: severity, Message: message, Source: source}
}
// ReadFile reads a checkfile.xml file and returns a CheckStyle object.
func ReadFile(filename string) (*CheckStyle, error) {
checkStyleXML, err := ioutil.ReadFile(filename)
if err != nil {
return nil, err
}
checkStyle := New()
err = xml.Unmarshal(checkStyleXML, checkStyle)
return checkStyle, err
}