| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 | package netimport (	"io"	"net"	"time")var (	emptyTime time.Time)type TimeOutReader struct {	timeout    int	connection net.Conn	worker     io.Reader}func NewTimeOutReader(timeout int /* seconds */, connection net.Conn) *TimeOutReader {	reader := &TimeOutReader{		connection: connection,		timeout:    -100,	}	reader.SetTimeOut(timeout)	return reader}func (reader *TimeOutReader) Read(p []byte) (int, error) {	return reader.worker.Read(p)}func (reader *TimeOutReader) GetTimeOut() int {	return reader.timeout}func (reader *TimeOutReader) SetTimeOut(value int) {	if value == reader.timeout {		return	}	reader.timeout = value	if value > 0 {		reader.worker = &timedReaderWorker{			timeout:    value,			connection: reader.connection,		}	} else {		reader.worker = &noOpReaderWorker{			connection: reader.connection,		}	}}func (reader *TimeOutReader) Release() {	reader.connection = nil	reader.worker = nil}type timedReaderWorker struct {	timeout    int	connection net.Conn}func (this *timedReaderWorker) Read(p []byte) (int, error) {	deadline := time.Duration(this.timeout) * time.Second	this.connection.SetReadDeadline(time.Now().Add(deadline))	nBytes, err := this.connection.Read(p)	this.connection.SetReadDeadline(emptyTime)	return nBytes, err}type noOpReaderWorker struct {	connection net.Conn}func (this *noOpReaderWorker) Read(p []byte) (int, error) {	return this.connection.Read(p)}
 |