mirror of
https://github.com/denoland/deno.git
synced 2025-01-21 13:00:36 -05:00
Organize modules: timers, os
This commit is contained in:
parent
08307fb841
commit
51692a5825
4 changed files with 44 additions and 34 deletions
3
Makefile
3
Makefile
|
@ -15,10 +15,11 @@ GO_FILES = \
|
|||
assets.go \
|
||||
deno_dir.go \
|
||||
dispatch.go \
|
||||
handlers.go \
|
||||
main.go \
|
||||
main_test.go \
|
||||
msg.pb.go \
|
||||
os.go \
|
||||
timers.go \
|
||||
util.go
|
||||
|
||||
deno: $(GO_FILES)
|
||||
|
|
4
main.go
4
main.go
|
@ -55,7 +55,9 @@ func main() {
|
|||
|
||||
createDirs()
|
||||
createWorker()
|
||||
InitHandlers()
|
||||
|
||||
InitOS()
|
||||
InitTimers()
|
||||
|
||||
main_js := stringAsset("main.js")
|
||||
check(worker.Load("/main.js", main_js))
|
||||
|
|
|
@ -5,12 +5,11 @@ import (
|
|||
"io/ioutil"
|
||||
"os"
|
||||
"strings"
|
||||
"time"
|
||||
)
|
||||
|
||||
const assetPrefix string = "/$asset$/"
|
||||
|
||||
func InitHandlers() {
|
||||
func InitOS() {
|
||||
Sub("os", func(buf []byte) []byte {
|
||||
msg := &Msg{}
|
||||
check(proto.Unmarshal(buf, msg))
|
||||
|
@ -30,18 +29,6 @@ func InitHandlers() {
|
|||
}
|
||||
return nil
|
||||
})
|
||||
|
||||
Sub("timers", func(buf []byte) []byte {
|
||||
msg := &Msg{}
|
||||
check(proto.Unmarshal(buf, msg))
|
||||
switch msg.Payload.(type) {
|
||||
case *Msg_TimerStart:
|
||||
payload := msg.GetTimerStart()
|
||||
return HandleTimerStart(payload.Id, payload.Interval, payload.Duration)
|
||||
default:
|
||||
panic("[timers] Unexpected message " + string(buf))
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
func HandleSourceCodeFetch(moduleSpecifier string, containingFile string) (out []byte) {
|
||||
|
@ -110,21 +97,3 @@ func HandleSourceCodeCache(filename string, sourceCode string,
|
|||
check(err)
|
||||
return out
|
||||
}
|
||||
|
||||
func HandleTimerStart(id int32, interval bool, duration int32) []byte {
|
||||
wg.Add(1)
|
||||
go func() {
|
||||
defer wg.Done()
|
||||
time.Sleep(time.Duration(duration) * time.Millisecond)
|
||||
payload, err := proto.Marshal(&Msg{
|
||||
Payload: &Msg_TimerReady{
|
||||
TimerReady: &TimerReadyMsg{
|
||||
Id: id,
|
||||
},
|
||||
},
|
||||
})
|
||||
check(err)
|
||||
Pub("timers", payload)
|
||||
}()
|
||||
return nil
|
||||
}
|
38
timers.go
Normal file
38
timers.go
Normal file
|
@ -0,0 +1,38 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"github.com/golang/protobuf/proto"
|
||||
"time"
|
||||
)
|
||||
|
||||
func InitTimers() {
|
||||
Sub("timers", func(buf []byte) []byte {
|
||||
msg := &Msg{}
|
||||
check(proto.Unmarshal(buf, msg))
|
||||
switch msg.Payload.(type) {
|
||||
case *Msg_TimerStart:
|
||||
payload := msg.GetTimerStart()
|
||||
return HandleTimerStart(payload.Id, payload.Interval, payload.Duration)
|
||||
default:
|
||||
panic("[timers] Unexpected message " + string(buf))
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
func HandleTimerStart(id int32, interval bool, duration int32) []byte {
|
||||
wg.Add(1)
|
||||
go func() {
|
||||
defer wg.Done()
|
||||
time.Sleep(time.Duration(duration) * time.Millisecond)
|
||||
payload, err := proto.Marshal(&Msg{
|
||||
Payload: &Msg_TimerReady{
|
||||
TimerReady: &TimerReadyMsg{
|
||||
Id: id,
|
||||
},
|
||||
},
|
||||
})
|
||||
check(err)
|
||||
Pub("timers", payload)
|
||||
}()
|
||||
return nil
|
||||
}
|
Loading…
Add table
Reference in a new issue