summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--service/reload/service.go13
-rw-r--r--service/reload/watcher.go71
2 files changed, 49 insertions, 35 deletions
diff --git a/service/reload/service.go b/service/reload/service.go
index 461f9430..bb85e15d 100644
--- a/service/reload/service.go
+++ b/service/reload/service.go
@@ -24,10 +24,6 @@ func (s *Service) Init(cfg *Config, c service.Container) (bool, error) {
if !s.reloadConfig.Enabled {
return false, nil
}
- wd, err := os.Getwd()
- if err != nil {
- return false, err
- }
var configs []WatcherConfig
@@ -45,6 +41,10 @@ func (s *Service) Init(cfg *Config, c service.Container) (bool, error) {
if cfg.Services[serviceName].service == nil {
continue
}
+ ignored, err := ConvertIgnored(config.Ignore)
+ if err != nil {
+ return false, err
+ }
configs = append(configs, WatcherConfig{
serviceName: serviceName,
recursive: config.Recursive,
@@ -59,12 +59,13 @@ func (s *Service) Init(cfg *Config, c service.Container) (bool, error) {
return ErrorSkip
},
files: make(map[string]os.FileInfo),
- ignored: ConvertIgnored(wd, config.Ignore),
+ ignored: ignored,
filePatterns: append(config.Patterns, cfg.Patterns...),
})
}
- s.watcher, err = NewWatcher(wd, configs)
+ var err error
+ s.watcher, err = NewWatcher(configs)
if err != nil {
return false, err
}
diff --git a/service/reload/watcher.go b/service/reload/watcher.go
index a9005a00..b466fc91 100644
--- a/service/reload/watcher.go
+++ b/service/reload/watcher.go
@@ -4,7 +4,6 @@ import (
"errors"
"io/ioutil"
"os"
- "path"
"path/filepath"
"sync"
"time"
@@ -38,7 +37,7 @@ type WatcherConfig struct {
// path to file with files
files map[string]os.FileInfo
// ignored directories, used map for O(1) amortized get
- ignored map[string]string
+ ignored map[string]struct{}
// filePatterns to ignore
filePatterns []string
}
@@ -50,12 +49,9 @@ type Watcher struct {
//=============================
mu *sync.Mutex
- wg *sync.WaitGroup
// indicates is walker started or not
started bool
- // working directory, same for all
- workingDir string
// config for each service
// need pointer here to assign files
@@ -66,15 +62,14 @@ type Watcher struct {
type Options func(*Watcher)
// NewWatcher returns new instance of File Watcher
-func NewWatcher(workDir string, configs []WatcherConfig, options ...Options) (*Watcher, error) {
+func NewWatcher(configs []WatcherConfig, options ...Options) (*Watcher, error) {
w := &Watcher{
Event: make(chan Event),
mu: &sync.Mutex{},
- wg: &sync.WaitGroup{},
close: make(chan struct{}),
- workingDir: workDir,
+ //workingDir: workDir,
watcherConfigs: make(map[string]WatcherConfig),
}
@@ -115,19 +110,33 @@ func (w *Watcher) initFs() error {
}
// ConvertIgnored is used to convert slice to map with ignored files
-func ConvertIgnored(workdir string, ignored []string) map[string]string {
- abs, _ := filepath.Abs(workdir)
+func ConvertIgnored(ignored []string) (map[string]struct{}, error) {
if len(ignored) == 0 {
- return nil
+ return nil, nil
}
- ign := make(map[string]string, len(ignored))
+ ign := make(map[string]struct{}, len(ignored))
for i := 0; i < len(ignored); i++ {
- ign[filepath.Join(abs, ignored[i])] = filepath.Join(abs, ignored[i])
+ abs, err := filepath.Abs(ignored[i])
+ if err != nil {
+ return nil, err
+ }
+ ign[abs] = struct{}{}
}
- return ign
+ return ign, nil
+
+}
+
+// GetAllFiles returns all files initialized for particular company
+func (w *Watcher) GetAllFiles(serviceName string) []os.FileInfo {
+ var ret []os.FileInfo
+
+ for _, v := range w.watcherConfigs[serviceName].files {
+ ret = append(ret, v)
+ }
+ return ret
}
// https://en.wikipedia.org/wiki/Inotify
@@ -181,9 +190,11 @@ outer:
}
// if filename does not contain pattern --> ignore that file
- err = w.watcherConfigs[serviceName].filterHooks(fileInfoList[i].Name(), w.watcherConfigs[serviceName].filePatterns)
- if err == ErrorSkip {
- continue outer
+ if w.watcherConfigs[serviceName].filePatterns != nil && w.watcherConfigs[serviceName].filterHooks != nil {
+ err = w.watcherConfigs[serviceName].filterHooks(fileInfoList[i].Name(), w.watcherConfigs[serviceName].filePatterns)
+ if err == ErrorSkip {
+ continue outer
+ }
}
filesList[pathToFile] = fileInfoList[i]
@@ -244,7 +255,10 @@ func (w *Watcher) retrieveFileList(serviceName string, config WatcherConfig) (ma
// walk through directories recursively
for _, dir := range config.directories {
// full path is workdir/relative_path
- fullPath := path.Join(w.workingDir, dir)
+ fullPath, err := filepath.Abs(dir)
+ if err != nil {
+ return nil, err
+ }
list, err := w.retrieveFilesRecursive(serviceName, fullPath)
if err != nil {
return nil, err
@@ -258,14 +272,12 @@ func (w *Watcher) retrieveFileList(serviceName string, config WatcherConfig) (ma
}
for _, dir := range config.directories {
- absPath, err := filepath.Abs(w.workingDir)
+ // full path is workdir/relative_path
+ fullPath, err := filepath.Abs(dir)
if err != nil {
return nil, err
}
- // full path is workdir/relative_path
- fullPath := path.Join(absPath, dir)
-
// list is pathToFiles with files
list, err := w.retrieveFilesSingle(serviceName, fullPath)
@@ -285,22 +297,23 @@ func (w *Watcher) retrieveFilesRecursive(serviceName, root string) (map[string]o
return err
}
- // if filename does not contain pattern --> ignore that file
- err = w.watcherConfigs[serviceName].filterHooks(info.Name(), w.watcherConfigs[serviceName].filePatterns)
- if err == ErrorSkip {
- return nil
- }
-
// If path is ignored and it's a directory, skip the directory. If it's
// ignored and it's a single file, skip the file.
_, ignored := w.watcherConfigs[serviceName].ignored[path]
-
if ignored {
if info.IsDir() {
+ // if it's dir, ignore whole
return filepath.SkipDir
}
return nil
}
+
+ // if filename does not contain pattern --> ignore that file
+ err = w.watcherConfigs[serviceName].filterHooks(info.Name(), w.watcherConfigs[serviceName].filePatterns)
+ if err == ErrorSkip {
+ return nil
+ }
+
// Add the path and it's info to the file list.
fileList[path] = info
return nil