Simplify Design

pull/238/head
Shelikhoo 2016-08-15 21:36:37 +08:00
parent 45d801b922
commit 32e8deb6e8
No known key found for this signature in database
GPG Key ID: 7791BDB0709ABD21
1 changed files with 4 additions and 34 deletions

View File

@ -6,54 +6,24 @@ import (
) )
type StoppableListener struct { type StoppableListener struct {
net.Listener //Wrapped listener net.Listener //Wrapped listener
stop chan int //Channel used only to indicate listener should shutdown
} }
func NewStoppableListener(l net.Listener) (*StoppableListener, error) { func NewStoppableListener(l net.Listener) (*StoppableListener, error) {
/*
tcpL, ok := l.(*net.TCPListener)
if !ok {
return nil, errors.New("Cannot wrap listener")
}
*/
retval := &StoppableListener{} retval := &StoppableListener{}
retval.Listener = l retval.Listener = l
retval.stop = make(chan int)
return retval, nil return retval, nil
} }
var StoppedError = errors.New("Listener stopped") var StoppedError = errors.New("Listener stopped")
func (sl *StoppableListener) Accept() (net.Conn, error) { func (sl *StoppableListener) Accept() (net.Conn, error) {
newConn, err := sl.Listener.Accept()
return newConn, err
for {
newConn, err := sl.Listener.Accept()
//Check for the channel being closed
select {
case <-sl.stop:
return nil, StoppedError
default:
//If the channel is still open, continue as normal
}
if err != nil {
netErr, ok := err.(net.Error)
//If this is a timeout, then continue to wait for
//new connections
if ok && netErr.Timeout() && netErr.Temporary() {
continue
}
}
return newConn, err
}
} }
func (sl *StoppableListener) Stop() { func (sl *StoppableListener) Stop() {
close(sl.stop) sl.Listener.Close()
} }