2018-08-16 20:53:47 +02:00
|
|
|
package watch
|
|
|
|
|
2019-07-11 23:54:50 +02:00
|
|
|
import (
|
|
|
|
"expvar"
|
2019-07-13 20:13:24 +02:00
|
|
|
"fmt"
|
|
|
|
"path/filepath"
|
2019-07-11 23:54:50 +02:00
|
|
|
|
2020-05-15 16:34:39 +02:00
|
|
|
"github.com/tilt-dev/tilt/pkg/logger"
|
2019-07-11 23:54:50 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
numberOfWatches = expvar.NewInt("watch.naive.numberOfWatches")
|
|
|
|
)
|
2019-07-11 17:40:40 +02:00
|
|
|
|
2018-08-22 21:33:06 +02:00
|
|
|
type FileEvent struct {
|
2019-07-13 20:13:24 +02:00
|
|
|
path string
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewFileEvent(p string) FileEvent {
|
|
|
|
if !filepath.IsAbs(p) {
|
|
|
|
panic(fmt.Sprintf("NewFileEvent only accepts absolute paths. Actual: %s", p))
|
|
|
|
}
|
|
|
|
return FileEvent{path: p}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e FileEvent) Path() string {
|
|
|
|
return e.path
|
2018-08-22 21:33:06 +02:00
|
|
|
}
|
2018-08-16 20:53:47 +02:00
|
|
|
|
|
|
|
type Notify interface {
|
2019-07-11 17:40:40 +02:00
|
|
|
// Start watching the paths set at init time
|
|
|
|
Start() error
|
|
|
|
|
|
|
|
// Stop watching and close all channels
|
2018-08-16 20:53:47 +02:00
|
|
|
Close() error
|
2019-07-11 17:40:40 +02:00
|
|
|
|
|
|
|
// A channel to read off incoming file changes
|
2018-08-22 21:33:06 +02:00
|
|
|
Events() chan FileEvent
|
2019-07-11 17:40:40 +02:00
|
|
|
|
|
|
|
// A channel to read off show-stopping errors
|
2018-08-16 20:53:47 +02:00
|
|
|
Errors() chan error
|
|
|
|
}
|
2019-07-11 17:40:40 +02:00
|
|
|
|
|
|
|
// When we specify directories to watch, we often want to
|
|
|
|
// ignore some subset of the files under those directories.
|
|
|
|
//
|
|
|
|
// For example:
|
|
|
|
// - Watch /src/repo, but ignore /src/repo/.git
|
|
|
|
// - Watch /src/repo, but ignore everything in /src/repo/bazel-bin except /src/repo/bazel-bin/app-binary
|
|
|
|
//
|
|
|
|
// The PathMatcher inteface helps us manage these ignores.
|
|
|
|
type PathMatcher interface {
|
|
|
|
Matches(file string) (bool, error)
|
2019-07-16 22:23:05 +02:00
|
|
|
|
|
|
|
// If this matches the entire dir, we can often optimize filetree walks a bit.
|
|
|
|
MatchesEntireDir(file string) (bool, error)
|
2019-07-11 17:40:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type EmptyMatcher struct {
|
|
|
|
}
|
|
|
|
|
2019-07-16 22:23:05 +02:00
|
|
|
func (EmptyMatcher) Matches(f string) (bool, error) { return false, nil }
|
|
|
|
func (EmptyMatcher) MatchesEntireDir(f string) (bool, error) { return false, nil }
|
2019-07-11 17:40:40 +02:00
|
|
|
|
|
|
|
var _ PathMatcher = EmptyMatcher{}
|
|
|
|
|
|
|
|
func NewWatcher(paths []string, ignore PathMatcher, l logger.Logger) (Notify, error) {
|
|
|
|
return newWatcher(paths, ignore, l)
|
|
|
|
}
|