2015-08-05 01:35:09 +03:00
|
|
|
package markdown
|
|
|
|
|
2015-08-05 11:55:04 +03:00
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"time"
|
|
|
|
)
|
2015-08-05 01:35:09 +03:00
|
|
|
|
2015-10-10 01:35:34 +03:00
|
|
|
// DefaultInterval is the default interval at which the markdown watcher
|
|
|
|
// checks for changes.
|
2015-08-05 03:00:53 +03:00
|
|
|
const DefaultInterval = time.Second * 60
|
2015-08-05 01:35:09 +03:00
|
|
|
|
|
|
|
// Watch monitors the configured markdown directory for changes. It calls GenerateLinks
|
|
|
|
// when there are changes.
|
|
|
|
func Watch(md Markdown, c *Config, interval time.Duration) (stopChan chan struct{}) {
|
|
|
|
return TickerFunc(interval, func() {
|
2015-08-05 11:55:04 +03:00
|
|
|
if err := GenerateStatic(md, c); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
2015-08-05 01:35:09 +03:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2015-08-05 11:55:04 +03:00
|
|
|
// TickerFunc runs f at interval. A message to the returned channel will stop the
|
|
|
|
// executing goroutine.
|
2015-08-05 01:35:09 +03:00
|
|
|
func TickerFunc(interval time.Duration, f func()) chan struct{} {
|
|
|
|
stopChan := make(chan struct{})
|
|
|
|
|
2015-08-05 02:41:04 +03:00
|
|
|
ticker := time.NewTicker(interval)
|
|
|
|
go func() {
|
|
|
|
loop:
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-ticker.C:
|
|
|
|
f()
|
|
|
|
case <-stopChan:
|
|
|
|
ticker.Stop()
|
|
|
|
break loop
|
2015-08-05 01:35:09 +03:00
|
|
|
}
|
2015-08-05 02:41:04 +03:00
|
|
|
}
|
|
|
|
}()
|
2015-08-05 01:35:09 +03:00
|
|
|
|
|
|
|
return stopChan
|
|
|
|
}
|