bee/watch.go

109 lines
1.7 KiB
Go
Raw Normal View History

2012-12-15 16:56:28 +00:00
package main
import (
"fmt"
"github.com/howeyc/fsnotify"
"log"
"os"
"os/exec"
2013-07-06 07:30:57 +00:00
"sync"
"time"
"strings"
2012-12-15 16:56:28 +00:00
)
var (
2013-07-06 08:13:30 +00:00
cmd *exec.Cmd
state sync.Mutex
eventTime = make(map[string]time.Time)
2012-12-15 16:56:28 +00:00
)
func NewWatcher(paths []string) {
watcher, err := fsnotify.NewWatcher()
if err != nil {
log.Fatal(err)
}
go func() {
for {
select {
case e := <-watcher.Event:
2013-07-06 07:30:57 +00:00
isbuild := true
if t, ok := eventTime[e.String()]; ok {
2013-07-06 08:13:30 +00:00
// if 500ms change many times, then ignore it.
// for liteide often gofmt code after save.
2013-07-06 07:30:57 +00:00
if t.Add(time.Millisecond * 500).After(time.Now()) {
isbuild = false
}
}
eventTime[e.String()] = time.Now()
if isbuild {
fmt.Println(e)
go Autobuild()
}
2012-12-15 16:56:28 +00:00
case err := <-watcher.Error:
log.Fatal("error:", err)
}
}
}()
for _, path := range paths {
fmt.Println(path)
err = watcher.Watch(path)
if err != nil {
log.Fatal(err)
}
}
}
func Autobuild() {
2013-07-06 08:13:30 +00:00
state.Lock()
defer state.Unlock()
2012-12-15 16:56:28 +00:00
2013-07-06 08:13:30 +00:00
fmt.Println("start autobuild")
2012-12-15 16:56:28 +00:00
path, _ := os.Getwd()
os.Chdir(path)
bcmd := exec.Command("go", "build")
2013-07-06 07:30:57 +00:00
bcmd.Stdout = os.Stdout
bcmd.Stderr = os.Stderr
2012-12-15 16:56:28 +00:00
err := bcmd.Run()
2013-07-06 08:13:30 +00:00
2012-12-15 16:56:28 +00:00
if err != nil {
2013-07-06 08:13:30 +00:00
fmt.Println("============== build failed ===================")
2013-07-06 07:30:57 +00:00
return
2012-12-15 16:56:28 +00:00
}
2013-07-06 08:13:30 +00:00
fmt.Println("build success")
2013-07-06 07:30:57 +00:00
Restart(appname)
2012-12-15 16:56:28 +00:00
}
func Kill() {
2013-07-06 08:13:30 +00:00
defer func() {
if e := recover(); e != nil {
fmt.Println("Kill -> ", e)
}
}()
if cmd != nil {
cmd.Process.Kill()
2012-12-15 16:56:28 +00:00
}
}
2013-07-06 07:30:57 +00:00
func Restart(appname string) {
2013-07-06 08:13:30 +00:00
Debugf("kill running process")
2013-07-06 07:30:57 +00:00
Kill()
2013-07-06 08:13:30 +00:00
go Start(appname)
2013-07-06 07:30:57 +00:00
}
2013-07-06 08:13:30 +00:00
2012-12-15 16:56:28 +00:00
func Start(appname string) {
fmt.Println("start", appname)
if strings.Index(appname, "./") == -1 {
appname = "./" + appname
}
2013-07-06 07:30:57 +00:00
2012-12-15 16:56:28 +00:00
cmd = exec.Command(appname)
2013-07-06 07:30:57 +00:00
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
2013-07-06 08:13:30 +00:00
go cmd.Run()
2012-12-15 16:56:28 +00:00
}