-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtcp_ctrl.go
90 lines (77 loc) · 1.56 KB
/
tcp_ctrl.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
80
81
82
83
84
85
86
87
88
89
90
package gtcp
import (
"context"
)
// All TCPCtrl Type should implement TCPCtrlInterface
type TCPCtrlInterface interface {
TCPBox
InstallActor(actor Actor)
}
// Get a new TCPCtrl
func NewTCPCtrl(actor Actor) *TCPCtrl {
return &TCPCtrl{Actor: actor}
}
// if Pool is open, and there are some TCPCtrl in it, get a TCPCtrl pointer from it
// else return a new TCPCtrl
func GetTCPCtrl(actor Actor) *TCPCtrl {
tcpCtrl, ok := GetCtrlFromPool(actor)
if ok {
return tcpCtrl
}
return NewTCPCtrl(actor)
}
// TCPCtrl struct
type TCPCtrl struct {
Actor
}
// Executed only once in a life cycle
func (t *TCPCtrl) CloseOnce() {
defer SendCtrlToPool(t)
err := t.OnClose()
for err != nil {
err = t.OnError(err)
}
}
// Replace embedded actor
func (t *TCPCtrl) InstallActor(actor Actor) {
t.Close()
SendActorToPool(t.Actor)
t.Actor = actor
}
// Go Scan
func (t *TCPCtrl) Start() {
t.InstallCtx(context.Background())
go t.Scan()
}
// Go Scan with father ctx
func (t *TCPCtrl) StartWithCtx(ctx context.Context) {
t.InstallCtx(ctx)
go t.Scan()
}
// Get data from TCPConn and execute OnConnect, OnMessage, OnError and OnClose event function.
func (t *TCPCtrl) Scan() {
defer t.CloseOnce()
err := t.OnConnect()
for err != nil {
err = t.OnError(err)
}
go t.Actor.Scan()
dataChan := t.GetDataChan()
errChan := t.GetErrChan()
Circle:
for {
select {
case <-t.Done():
break Circle
case data := <-dataChan:
err := t.OnMessage(data)
for err != nil {
err = t.OnError(err)
}
case err := <-errChan:
for err != nil {
err = t.OnError(err)
}
}
}
}