2023-01-07 02:38:35 +02:00
|
|
|
package taskfile
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"gopkg.in/yaml.v3"
|
2023-01-07 02:39:57 +02:00
|
|
|
|
|
|
|
"github.com/go-task/task/v3/internal/goext"
|
2023-01-07 02:38:35 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// Platform represents GOOS and GOARCH values
|
|
|
|
type Platform struct {
|
|
|
|
OS string
|
|
|
|
Arch string
|
|
|
|
}
|
|
|
|
|
2023-03-25 21:13:06 +02:00
|
|
|
func (p *Platform) DeepCopy() *Platform {
|
|
|
|
if p == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return &Platform{
|
|
|
|
OS: p.OS,
|
|
|
|
Arch: p.Arch,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-07 02:39:57 +02:00
|
|
|
type ErrInvalidPlatform struct {
|
|
|
|
Platform string
|
2023-01-07 02:38:35 +02:00
|
|
|
}
|
|
|
|
|
2023-01-07 02:39:57 +02:00
|
|
|
func (err *ErrInvalidPlatform) Error() string {
|
|
|
|
return fmt.Sprintf(`task: Invalid platform "%s"`, err.Platform)
|
2023-01-07 02:38:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// UnmarshalYAML implements yaml.Unmarshaler interface.
|
|
|
|
func (p *Platform) UnmarshalYAML(node *yaml.Node) error {
|
|
|
|
switch node.Kind {
|
|
|
|
case yaml.ScalarNode:
|
|
|
|
var platform string
|
|
|
|
if err := node.Decode(&platform); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-01-07 02:39:57 +02:00
|
|
|
if err := p.parsePlatform(platform); err != nil {
|
2023-01-07 02:38:35 +02:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return fmt.Errorf("yaml: line %d: cannot unmarshal %s into platform", node.Line, node.ShortTag())
|
|
|
|
}
|
|
|
|
|
2023-01-07 02:39:57 +02:00
|
|
|
// parsePlatform takes a string representing an OS/Arch combination (or either on their own)
|
|
|
|
// and parses it into the Platform struct. It returns an error if the input string is invalid.
|
|
|
|
// Valid combinations for input: OS, Arch, OS/Arch
|
|
|
|
func (p *Platform) parsePlatform(input string) error {
|
|
|
|
splitValues := strings.Split(input, "/")
|
|
|
|
if len(splitValues) > 2 {
|
|
|
|
return &ErrInvalidPlatform{Platform: input}
|
|
|
|
}
|
|
|
|
if err := p.parseOsOrArch(splitValues[0]); err != nil {
|
|
|
|
return &ErrInvalidPlatform{Platform: input}
|
|
|
|
}
|
|
|
|
if len(splitValues) == 2 {
|
|
|
|
if err := p.parseArch(splitValues[1]); err != nil {
|
|
|
|
return &ErrInvalidPlatform{Platform: input}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2023-01-07 02:38:35 +02:00
|
|
|
// parseOsOrArch will check if the given input is a valid OS or Arch value.
|
|
|
|
// If so, it will store it. If not, an error is returned
|
|
|
|
func (p *Platform) parseOsOrArch(osOrArch string) error {
|
|
|
|
if osOrArch == "" {
|
|
|
|
return fmt.Errorf("task: Blank OS/Arch value provided")
|
|
|
|
}
|
2023-01-07 02:39:57 +02:00
|
|
|
if goext.IsKnownOS(osOrArch) {
|
2023-01-07 02:38:35 +02:00
|
|
|
p.OS = osOrArch
|
|
|
|
return nil
|
|
|
|
}
|
2023-01-07 02:39:57 +02:00
|
|
|
if goext.IsKnownArch(osOrArch) {
|
2023-01-07 02:38:35 +02:00
|
|
|
p.Arch = osOrArch
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return fmt.Errorf("task: Invalid OS/Arch value provided (%s)", osOrArch)
|
|
|
|
}
|
2023-01-07 02:39:57 +02:00
|
|
|
|
2023-01-07 02:38:35 +02:00
|
|
|
func (p *Platform) parseArch(arch string) error {
|
|
|
|
if arch == "" {
|
|
|
|
return fmt.Errorf("task: Blank Arch value provided")
|
|
|
|
}
|
|
|
|
if p.Arch != "" {
|
|
|
|
return fmt.Errorf("task: Multiple Arch values provided")
|
|
|
|
}
|
2023-01-07 02:39:57 +02:00
|
|
|
if goext.IsKnownArch(arch) {
|
2023-01-07 02:38:35 +02:00
|
|
|
p.Arch = arch
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return fmt.Errorf("task: Invalid Arch value provided (%s)", arch)
|
|
|
|
}
|