Update build.go

This commit is contained in:
Alexander Neumann 2017-07-21 21:51:01 +02:00
parent 91edebf1fe
commit 9cd422791a

View file

@ -28,9 +28,9 @@ var config = struct {
Tests []string Tests []string
}{ }{
Name: "restic", // name of the program executable and directory Name: "restic", // name of the program executable and directory
Namespace: "", // subdir of GOPATH, e.g. "github.com/foo/bar" Namespace: "github.com/restic/restic", // subdir of GOPATH, e.g. "github.com/foo/bar"
Main: "cmds/restic", // package name for the main package Main: "github.com/restic/restic/cmd/restic", // package name for the main package
Tests: []string{"restic/...", "cmds/..."}, // tests to run Tests: []string{"internal/...", "cmd/..."}, // tests to run
} }
// specialDir returns true if the file begins with a special character ('.' or '_'). // specialDir returns true if the file begins with a special character ('.' or '_').
@ -77,7 +77,12 @@ func excludePath(name string) bool {
// └── restic // └── restic
// └── foo.go // └── foo.go
func updateGopath(dst, src, prefix string) error { func updateGopath(dst, src, prefix string) error {
verbosePrintf("copy contents of %v to %v\n", src, filepath.Join(dst, prefix))
return filepath.Walk(src, func(name string, fi os.FileInfo, err error) error { return filepath.Walk(src, func(name string, fi os.FileInfo, err error) error {
if name == src {
return err
}
if specialDir(name) { if specialDir(name) {
if fi.IsDir() { if fi.IsDir() {
return filepath.SkipDir return filepath.SkipDir
@ -86,6 +91,10 @@ func updateGopath(dst, src, prefix string) error {
return nil return nil
} }
if err != nil {
return err
}
if fi.IsDir() { if fi.IsDir() {
return nil return nil
} }
@ -368,13 +377,13 @@ func main() {
} }
verbosePrintf("create GOPATH at %v\n", gopath) verbosePrintf("create GOPATH at %v\n", gopath)
if err = updateGopath(gopath, filepath.Join(root, "src"), config.Namespace); err != nil { if err = updateGopath(gopath, root, config.Namespace); err != nil {
die("copying files from %v/src to %v/src failed: %v\n", root, gopath, err) die("copying files from %v/src to %v/src failed: %v\n", root, gopath, err)
} }
vendor := filepath.Join(root, "vendor", "src") vendor := filepath.Join(root, "vendor")
if directoryExists(vendor) { if directoryExists(vendor) {
if err = updateGopath(gopath, vendor, ""); err != nil { if err = updateGopath(gopath, vendor, filepath.Join(config.Namespace, "vendor")); err != nil {
die("copying files from %v to %v failed: %v\n", root, gopath, err) die("copying files from %v to %v failed: %v\n", root, gopath, err)
} }
} }