forked from panjf2000/gnet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
reactor_linux.go
52 lines (44 loc) · 1.34 KB
/
reactor_linux.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
// Copyright 2019 Andy Pan. All rights reserved.
// Use of this source code is governed by an MIT-style
// license that can be found in the LICENSE file.
// +build linux
package gnet
import "github.com/panjf2000/gnet/internal/netpoll"
func (svr *server) activateMainReactor() {
defer svr.signalShutdown()
svr.logger.Printf("main reactor exits with error:%v\n", svr.mainLoop.poller.Polling(func(fd int, ev uint32) error {
return svr.acceptNewConnection(fd)
}))
}
func (svr *server) activateSubReactor(el *eventloop) {
defer func() {
el.closeAllConns()
if el.idx == 0 && svr.opts.Ticker {
close(svr.ticktock)
}
svr.signalShutdown()
}()
if el.idx == 0 && svr.opts.Ticker {
go el.loopTicker()
}
svr.logger.Printf("event-loop:%d exits with error:%v\n", el.idx, el.poller.Polling(func(fd int, ev uint32) error {
if c, ack := el.connections[fd]; ack {
switch c.outboundBuffer.IsEmpty() {
// Don't change the ordering of processing EPOLLOUT | EPOLLRDHUP / EPOLLIN unless you're 100%
// sure what you're doing!
// Re-ordering can easily introduce bugs and bad side-effects, as I found out painfully in the past.
case false:
if ev&netpoll.OutEvents != 0 {
return el.loopWrite(c)
}
return nil
case true:
if ev&netpoll.InEvents != 0 {
return el.loopRead(c)
}
return nil
}
}
return nil
}))
}