Source File
fd.go
Belonging Package
internal/poll
// Copyright 2017 The Go Authors. All rights reserved.// Use of this source code is governed by a BSD-style// license that can be found in the LICENSE file.// Package poll supports non-blocking I/O on file descriptors with polling.// This supports I/O operations that block only a goroutine, not a thread.// This is used by the net and os packages.// It uses a poller built into the runtime, with support from the// runtime scheduler.package pollimport ()// errNetClosing is the type of the variable ErrNetClosing.// This is used to implement the net.Error interface.type errNetClosing struct{}// Error returns the error message for ErrNetClosing.// Keep this string consistent because of issue #4373:// since historically programs have not been able to detect// this error, they look for the string.func ( errNetClosing) () string { return "use of closed network connection" }func ( errNetClosing) () bool { return false }func ( errNetClosing) () bool { return false }// ErrNetClosing is returned when a network descriptor is used after// it has been closed.var ErrNetClosing = errNetClosing{}// ErrFileClosing is returned when a file descriptor is used after it// has been closed.var ErrFileClosing = errors.New("use of closed file")// ErrNoDeadline is returned when a request is made to set a deadline// on a file type that does not use the poller.var ErrNoDeadline = errors.New("file type does not support deadline")// Return the appropriate closing error based on isFile.func ( bool) error {if {return ErrFileClosing}return ErrNetClosing}// ErrDeadlineExceeded is returned for an expired deadline.// This is exported by the os package as os.ErrDeadlineExceeded.var ErrDeadlineExceeded error = &DeadlineExceededError{}// DeadlineExceededError is returned for an expired deadline.type DeadlineExceededError struct{}// Implement the net.Error interface.// The string is "i/o timeout" because that is what was returned// by earlier Go versions. Changing it may break programs that// match on error strings.func ( *DeadlineExceededError) () string { return "i/o timeout" }func ( *DeadlineExceededError) () bool { return true }func ( *DeadlineExceededError) () bool { return true }// ErrNotPollable is returned when the file or socket is not suitable// for event notification.var ErrNotPollable = errors.New("not pollable")// consume removes data from a slice of byte slices, for writev.func ( *[][]byte, int64) {for len(*) > 0 {:= int64(len((*)[0]))if > {(*)[0] = (*)[0][:]return}-=(*)[0] = nil* = (*)[1:]}}// TestHookDidWritev is a hook for testing writev.var TestHookDidWritev = func( int) {}
![]() |
The pages are generated with Golds v0.6.7. (GOOS=linux GOARCH=amd64) Golds is a Go 101 project developed by Tapir Liu. PR and bug reports are welcome and can be submitted to the issue list. Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds. |