forked from panjf2000/gnet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreactor_bsd.go
49 lines (41 loc) · 1.38 KB
/
reactor_bsd.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
// 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 darwin netbsd freebsd openbsd dragonfly
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, filter int16) error {
return svr.acceptNewConnection(fd)
}))
}
func (svr *server) activateSubReactor(el *eventloop) {
defer 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, filter int16) error {
if c, ack := el.connections[fd]; ack {
if filter == netpoll.EVFilterSock {
return el.loopCloseConn(c, nil)
}
switch c.outboundBuffer.IsEmpty() {
// Don't change the ordering of processing EVFILT_WRITE | EVFILT_READ | EV_ERROR/EV_EOF 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 filter == netpoll.EVFilterWrite {
return el.loopWrite(c)
}
return nil
case true:
if filter == netpoll.EVFilterRead {
return el.loopRead(c)
}
return nil
}
}
return nil
}))
}