|  | @@ -6,54 +6,24 @@ import (
 | 
	
		
			
				|  |  |  )
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  type StoppableListener struct {
 | 
	
		
			
				|  |  | -	net.Listener          //Wrapped listener
 | 
	
		
			
				|  |  | -	stop         chan int //Channel used only to indicate listener should shutdown
 | 
	
		
			
				|  |  | +	net.Listener //Wrapped listener
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  func NewStoppableListener(l net.Listener) (*StoppableListener, error) {
 | 
	
		
			
				|  |  | -	/*
 | 
	
		
			
				|  |  | -		tcpL, ok := l.(*net.TCPListener)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -		if !ok {
 | 
	
		
			
				|  |  | -			return nil, errors.New("Cannot wrap listener")
 | 
	
		
			
				|  |  | -		}
 | 
	
		
			
				|  |  | -	*/
 | 
	
		
			
				|  |  |  	retval := &StoppableListener{}
 | 
	
		
			
				|  |  |  	retval.Listener = l
 | 
	
		
			
				|  |  | -	retval.stop = make(chan int)
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  	return retval, nil
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  var StoppedError = errors.New("Listener stopped")
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  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() {
 | 
	
		
			
				|  |  | -	close(sl.stop)
 | 
	
		
			
				|  |  | +	sl.Listener.Close()
 | 
	
		
			
				|  |  |  }
 |