73 lines
1.4 KiB
Go
73 lines
1.4 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/fsnotify/fsnotify"
|
|
"log"
|
|
"os"
|
|
"path/filepath"
|
|
)
|
|
|
|
func startWatcher(cb func(file []*fsnotify.Event)) {
|
|
//debouncer := NewDebouncer(time.Millisecond * 100)
|
|
events := make([]*fsnotify.Event, 0)
|
|
|
|
defer func() {
|
|
if r := recover(); r != nil {
|
|
fmt.Println("Recovered from fatal error:", r)
|
|
// You can log the error here or take other corrective actions
|
|
}
|
|
}()
|
|
// Create new watcher.
|
|
watcher, err := fsnotify.NewWatcher()
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
defer watcher.Close()
|
|
// Start listening for events.
|
|
go func() {
|
|
for {
|
|
select {
|
|
case event, ok := <-watcher.Events:
|
|
if !ok {
|
|
return
|
|
}
|
|
if event.Has(fsnotify.Write) {
|
|
events = append(events, &event)
|
|
go cb(events)
|
|
events = make([]*fsnotify.Event, 0)
|
|
}
|
|
case err, ok := <-watcher.Errors:
|
|
if !ok {
|
|
return
|
|
}
|
|
log.Println("error:", err)
|
|
}
|
|
}
|
|
}()
|
|
|
|
rootDir := "."
|
|
// Walk through the root directory and add all subdirectories to the watcher
|
|
err = filepath.Walk(rootDir, func(path string, info os.FileInfo, err error) error {
|
|
if err != nil {
|
|
return err
|
|
}
|
|
// Only watch directories
|
|
if info.IsDir() {
|
|
err = watcher.Add(path)
|
|
if err != nil {
|
|
log.Println("Error adding directory to watcher:", err)
|
|
} else {
|
|
log.Println("Watching directory:", path)
|
|
}
|
|
}
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
done := RegisterSignals()
|
|
<-done
|
|
println("process exited")
|
|
}
|