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