Source file src/internal/poll/fd.go

     1  // Copyright 2017 The Go Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  // Package poll supports non-blocking I/O on file descriptors with polling.
     6  // This supports I/O operations that block only a goroutine, not a thread.
     7  // This is used by the net and os packages.
     8  // It uses a poller built into the runtime, with support from the
     9  // runtime scheduler.
    10  package poll
    11  
    12  import (
    13  	"errors"
    14  )
    15  
    16  // errNetClosing is the type of the variable ErrNetClosing.
    17  // This is used to implement the net.Error interface.
    18  type errNetClosing struct{}
    19  
    20  // Error returns the error message for ErrNetClosing.
    21  // Keep this string consistent because of issue #4373:
    22  // since historically programs have not been able to detect
    23  // this error, they look for the string.
    24  func (e errNetClosing) Error() string { return "use of closed network connection" }
    25  
    26  func (e errNetClosing) Timeout() bool   { return false }
    27  func (e errNetClosing) Temporary() bool { return false }
    28  
    29  // ErrNetClosing is returned when a network descriptor is used after
    30  // it has been closed.
    31  var ErrNetClosing = errNetClosing{}
    32  
    33  // ErrFileClosing is returned when a file descriptor is used after it
    34  // has been closed.
    35  var ErrFileClosing = errors.New("use of closed file")
    36  
    37  // ErrNoDeadline is returned when a request is made to set a deadline
    38  // on a file type that does not use the poller.
    39  var ErrNoDeadline = errors.New("file type does not support deadline")
    40  
    41  // Return the appropriate closing error based on isFile.
    42  func errClosing(isFile bool) error {
    43  	if isFile {
    44  		return ErrFileClosing
    45  	}
    46  	return ErrNetClosing
    47  }
    48  
    49  // ErrDeadlineExceeded is returned for an expired deadline.
    50  // This is exported by the os package as os.ErrDeadlineExceeded.
    51  var ErrDeadlineExceeded error = &DeadlineExceededError{}
    52  
    53  // DeadlineExceededError is returned for an expired deadline.
    54  type DeadlineExceededError struct{}
    55  
    56  // Implement the net.Error interface.
    57  // The string is "i/o timeout" because that is what was returned
    58  // by earlier Go versions. Changing it may break programs that
    59  // match on error strings.
    60  func (e *DeadlineExceededError) Error() string   { return "i/o timeout" }
    61  func (e *DeadlineExceededError) Timeout() bool   { return true }
    62  func (e *DeadlineExceededError) Temporary() bool { return true }
    63  
    64  // ErrNotPollable is returned when the file or socket is not suitable
    65  // for event notification.
    66  var ErrNotPollable = errors.New("not pollable")
    67  
    68  // consume removes data from a slice of byte slices, for writev.
    69  func consume(v *[][]byte, n int64) {
    70  	for len(*v) > 0 {
    71  		ln0 := int64(len((*v)[0]))
    72  		if ln0 > n {
    73  			(*v)[0] = (*v)[0][n:]
    74  			return
    75  		}
    76  		n -= ln0
    77  		*v = (*v)[1:]
    78  	}
    79  }
    80  
    81  // TestHookDidWritev is a hook for testing writev.
    82  var TestHookDidWritev = func(wrote int) {}
    83  

View as plain text