2013-05-30 05:32:59 +08:00
|
|
|
package watch
|
|
|
|
|
|
|
|
type FileChanges struct {
|
2013-11-14 09:38:23 +08:00
|
|
|
Modified chan bool // Channel to get notified of modifications
|
2013-05-30 05:32:59 +08:00
|
|
|
Truncated chan bool // Channel to get notified of truncations
|
2013-11-14 09:38:23 +08:00
|
|
|
Deleted chan bool // Channel to get notified of deletions/renames
|
2013-05-30 05:32:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewFileChanges() *FileChanges {
|
|
|
|
return &FileChanges{
|
2016-08-01 14:47:06 +08:00
|
|
|
make(chan bool, 1), make(chan bool, 1), make(chan bool, 1)}
|
2013-05-30 05:32:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func (fc *FileChanges) NotifyModified() {
|
|
|
|
sendOnlyIfEmpty(fc.Modified)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (fc *FileChanges) NotifyTruncated() {
|
|
|
|
sendOnlyIfEmpty(fc.Truncated)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (fc *FileChanges) NotifyDeleted() {
|
|
|
|
sendOnlyIfEmpty(fc.Deleted)
|
|
|
|
}
|
|
|
|
|
|
|
|
// sendOnlyIfEmpty sends on a bool channel only if the channel has no
|
|
|
|
// backlog to be read by other goroutines. This concurrency pattern
|
|
|
|
// can be used to notify other goroutines if and only if they are
|
|
|
|
// looking for it (i.e., subsequent notifications can be compressed
|
|
|
|
// into one).
|
|
|
|
func sendOnlyIfEmpty(ch chan bool) {
|
|
|
|
select {
|
|
|
|
case ch <- true:
|
|
|
|
default:
|
|
|
|
}
|
2013-11-14 09:38:23 +08:00
|
|
|
}
|