refactor: use switch-case not try-err (#1112)

This commit is contained in:
6543 2022-08-15 14:39:08 +02:00 committed by GitHub
parent 5a945c10e9
commit a46723334b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -97,34 +97,26 @@ func (when *When) IsLocal() bool {
}
func (when *When) UnmarshalYAML(value *yaml.Node) error {
unmarshelAsList := func() error {
lst := []Constraint{}
err := value.Decode(&lst)
if err != nil {
switch value.Kind {
case yaml.SequenceNode:
if err := value.Decode(&when.Constraints); err != nil {
return err
}
when.Constraints = lst
return nil
}
unmarshelAsDict := func() error {
case yaml.MappingNode:
c := Constraint{}
err := value.Decode(&c)
if err != nil {
if err := value.Decode(&c); err != nil {
return err
}
when.Constraints = append(when.Constraints, c)
default:
return fmt.Errorf("not supported yaml kind: %v", value.Kind)
}
return nil
}
err := unmarshelAsList()
if err != nil {
err = unmarshelAsDict()
}
return err
}
// Match returns true if all constraints match the given input. If a single
// constraint fails a false value is returned.
func (c *Constraint) Match(metadata frontend.Metadata) bool {