mirror of https://github.com/docker/compose.git
81 lines
1.7 KiB
Go
81 lines
1.7 KiB
Go
package watch
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"path/filepath"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/windmilleng/tilt/internal/ospath"
|
|
)
|
|
|
|
func greatestExistingAncestors(paths []string) ([]string, error) {
|
|
result := []string{}
|
|
for _, p := range paths {
|
|
newP, err := greatestExistingAncestor(p)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("Finding ancestor of %s: %v", p, err)
|
|
}
|
|
result = append(result, newP)
|
|
}
|
|
return result, nil
|
|
}
|
|
func greatestExistingAncestor(path string) (string, error) {
|
|
if path == string(filepath.Separator) ||
|
|
path == fmt.Sprintf("%s%s", filepath.VolumeName(path), string(filepath.Separator)) {
|
|
return "", fmt.Errorf("cannot watch root directory")
|
|
}
|
|
|
|
_, err := os.Stat(path)
|
|
if err != nil && !os.IsNotExist(err) {
|
|
return "", errors.Wrapf(err, "os.Stat(%q)", path)
|
|
}
|
|
|
|
if os.IsNotExist(err) {
|
|
return greatestExistingAncestor(filepath.Dir(path))
|
|
}
|
|
|
|
return path, nil
|
|
}
|
|
|
|
// If we're recursively watching a path, it doesn't
|
|
// make sense to watch any of its descendants.
|
|
func dedupePathsForRecursiveWatcher(paths []string) []string {
|
|
result := []string{}
|
|
for _, current := range paths {
|
|
isCovered := false
|
|
hasRemovals := false
|
|
|
|
for i, existing := range result {
|
|
if ospath.IsChild(existing, current) {
|
|
// The path is already covered, so there's no need to include it
|
|
isCovered = true
|
|
break
|
|
}
|
|
|
|
if ospath.IsChild(current, existing) {
|
|
// Mark the element empty fo removal.
|
|
result[i] = ""
|
|
hasRemovals = true
|
|
}
|
|
}
|
|
|
|
if !isCovered {
|
|
result = append(result, current)
|
|
}
|
|
|
|
if hasRemovals {
|
|
// Remove all the empties
|
|
newResult := []string{}
|
|
for _, r := range result {
|
|
if r != "" {
|
|
newResult = append(newResult, r)
|
|
}
|
|
}
|
|
result = newResult
|
|
}
|
|
}
|
|
return result
|
|
}
|