-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtimer.go
79 lines (71 loc) · 1.74 KB
/
timer.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*********************************************
_ooOoo_
o8888888o
88" . "88
(| -_- |)
O\ = /O
____/`---'\____
.' \\| |// `.
/ \\||| : |||// \
/ _||||| -:- |||||- \
| | \\\ - /// | |
| \_| ''\---/'' | |
\ .-\__ `-` ___/-. /
___`. .' /--.--\ `. . __
."" '< `.___\_<|>_/___.' >'"".
| | : `- \`.;`\ _ /`;.`/ - ` : | |
\ \ `-. \_ __\ /__ _/ .-` / /
======`-.____`-.___\_____/___.-`____.-'======
`=---='
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
佛祖保佑 永无BUG
心外无法 法外无心
三宝弟子 飞猪宏愿
*********************************************/
package main
import (
"log"
"time"
)
// startTimers - 启动所有定时器
func startTimers() error {
for _, name := range macrosManager.Names() {
m := macrosManager.Get(name)
if m.HasTimer() {
err := m.StartTimer()
if err != nil {
return err
}
}
}
return nil
}
// HasTimer - 是否有定时器
func (m *Macro) HasTimer() bool {
return m.Timer != nil && m.Timer.Inteval > 0
}
// StartTimer - 启动定时器
func (m *Macro) StartTimer() error {
if !m.HasTimer() {
return nil
}
if *flagDebug > 2 {
log.Printf("call %s timer", m.name)
}
go func(m *Macro) {
t := time.NewTicker(time.Duration(m.Timer.Inteval) * time.Second)
for {
if *flagDebug > 2 {
log.Printf("wait %s timer run...", m.name)
}
select {
case <-t.C:
err := m.TimerCall()
if err != nil {
log.Printf("%s timer call error: %v", m.name, err)
}
}
}
}(m)
return nil
}