58 lines
2.6 KiB
Go
58 lines
2.6 KiB
Go
|
package getmodules
|
||
|
|
||
|
import (
|
||
|
"path"
|
||
|
|
||
|
getter "github.com/hashicorp/go-getter"
|
||
|
)
|
||
|
|
||
|
// SplitPackageSubdir detects whether the given address string has a
|
||
|
// subdirectory portion, and if so returns a non-empty subDir string
|
||
|
// along with the trimmed package address.
|
||
|
//
|
||
|
// If the given string doesn't have a subdirectory portion then it'll
|
||
|
// just be returned verbatim in packageAddr, with an empty subDir value.
|
||
|
//
|
||
|
// Although the rest of this package is focused only on direct remote
|
||
|
// module packages, this particular function and its companion
|
||
|
// ExpandSubdirGlobs are both also relevant for registry-based module
|
||
|
// addresses, because a registry translates such an address into a
|
||
|
// remote module package address and thus can contribute its own
|
||
|
// additions to the final subdirectory selection.
|
||
|
func SplitPackageSubdir(given string) (packageAddr, subDir string) {
|
||
|
// We delegate this mostly to go-getter, because older Terraform
|
||
|
// versions just used go-getter directly and so we need to preserve
|
||
|
// its various quirks for compatibility reasons.
|
||
|
//
|
||
|
// However, note that in Terraform we _always_ split off the subdirectory
|
||
|
// portion and handle it within Terraform-level code, _never_ passing
|
||
|
// a subdirectory portion down into go-getter's own Get function, because
|
||
|
// Terraform's ability to refer between local paths inside the same
|
||
|
// package depends on Terraform itself always being aware of where the
|
||
|
// package's root directory ended up on disk, and always needs the
|
||
|
// package installed wholesale.
|
||
|
packageAddr, subDir = getter.SourceDirSubdir(given)
|
||
|
if subDir != "" {
|
||
|
subDir = path.Clean(subDir)
|
||
|
}
|
||
|
return packageAddr, subDir
|
||
|
}
|
||
|
|
||
|
// ExpandSubdirGlobs handles a subdir string that might contain glob syntax,
|
||
|
// turning it into a concrete subdirectory path by referring to the actual
|
||
|
// files on disk in the given directory which we assume contains the content
|
||
|
// of whichever package this is a subdirectory glob for.
|
||
|
//
|
||
|
// Subdir globs are used, for example, when a module registry wants to specify
|
||
|
// to select the contents of the single directory at the root of a conventional
|
||
|
// tar archive but it doesn't actually know the exact name of that directory.
|
||
|
// In that case it might specify a subdir of just "*", which this function
|
||
|
// will then expand into the single subdirectory found inside instDir, or
|
||
|
// return an error if the result would be ambiguous.
|
||
|
func ExpandSubdirGlobs(instDir string, subDir string) (string, error) {
|
||
|
// We just delegate this entirely to go-getter, because older Terraform
|
||
|
// versions just used go-getter directly and so we need to preserve
|
||
|
// its various quirks for compatibility reasons.
|
||
|
return getter.SubdirGlob(instDir, subDir)
|
||
|
}
|