mirror of https://github.com/docker/docs.git
Merge pull request #6643 from kzys/freebsd-cp
cp's -T and --reflink=auto are only available on GNU coreutils
This commit is contained in:
commit
6d8e95557c
|
@ -1,6 +1,7 @@
|
||||||
package vfs
|
package vfs
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/dotcloud/docker/daemon/graphdriver"
|
"github.com/dotcloud/docker/daemon/graphdriver"
|
||||||
"os"
|
"os"
|
||||||
|
@ -35,8 +36,24 @@ func (d *Driver) Cleanup() error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func isGNUcoreutils() bool {
|
||||||
|
if stdout, err := exec.Command("cp", "--version").Output(); err == nil {
|
||||||
|
return bytes.Contains(stdout, []byte("GNU coreutils"))
|
||||||
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
func copyDir(src, dst string) error {
|
func copyDir(src, dst string) error {
|
||||||
if output, err := exec.Command("cp", "-aT", "--reflink=auto", src, dst).CombinedOutput(); err != nil {
|
argv := make([]string, 0, 4)
|
||||||
|
|
||||||
|
if isGNUcoreutils() {
|
||||||
|
argv = append(argv, "-aT", "--reflink=auto", src, dst)
|
||||||
|
} else {
|
||||||
|
argv = append(argv, "-a", src+"/.", dst+"/.")
|
||||||
|
}
|
||||||
|
|
||||||
|
if output, err := exec.Command("cp", argv...).CombinedOutput(); err != nil {
|
||||||
return fmt.Errorf("Error VFS copying directory: %s (%s)", err, output)
|
return fmt.Errorf("Error VFS copying directory: %s (%s)", err, output)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
|
Loading…
Reference in New Issue