pulumi/pkg/ast/versions.go

56 lines
1.7 KiB
Go

// Copyright 2016 Marapongo, Inc. All rights reserved.
package ast
import (
"errors"
"regexp"
"github.com/blang/semver"
// TODO[marapongo/mu#18]: consider supporting the sugared NPM-style semvers, like tilde and caret ranges.
)
var sha1HashRegexps = "[0-9a-fA-F]"
var shortSHA1HashRegexp = regexp.MustCompile(sha1HashRegexps + "{7}")
var longSHA1HashRegexp = regexp.MustCompile(sha1HashRegexps + "{40}")
// Check ensures the given Version is valid; if it is, Check returns nil; if not, an error describing why is returned.
func (v Version) Check() error {
// The only three legal values for Version are: a semantic version or a Git SHA hash (short or long).
// Not that ranges are explicitly disallowed with Versions; for those, you'd use a VersionSpec.
vs := string(v)
if vs == "" {
return errors.New("Missing version")
}
if shortSHA1HashRegexp.FindString(vs) == vs {
return nil
}
if longSHA1HashRegexp.FindString(vs) == vs {
return nil
}
_, err := semver.Parse(vs)
return err
}
// LatestVersion indicates that the latest known source version should be used.
const LatestVersion VersionSpec = "latest"
// Check ensures the given Version is valid; if it is, Check returns nil; if not, an error describing why is returned.
func (v VersionSpec) Check() error {
// More legal values are permitted here. Any valid Version is also a valid VersionSpec. However, VersionSpecs
// permit the special LatestVersionSpec string, in addition to semantic version ranges.
if v == LatestVersion {
return nil
}
if err := Version(v).Check(); err == nil {
return nil
}
vs := string(v)
if vs == "" {
return errors.New("Missing version")
}
_, err := semver.ParseRange(vs)
return err
}