73 lines
2.8 KiB
Go
73 lines
2.8 KiB
Go
|
// Package channel defines a communications channel that can encode/transmit
|
||
|
// and decode/receive data records with a configurable framing discipline, and
|
||
|
// provides some simple framing implementations.
|
||
|
//
|
||
|
// Channels
|
||
|
//
|
||
|
// A Channel represents the ability to send and received framed records,
|
||
|
// comprising the methods:
|
||
|
//
|
||
|
// Send([]byte) error // send a single complete record
|
||
|
// Recv() ([]byte, error) // receive a single complete record
|
||
|
// Close() error // close the channel
|
||
|
//
|
||
|
// Each record passed to Send is available for Recv. Record contents are not
|
||
|
// interpreted (except as noted below), and it is up to the implementation to
|
||
|
// decide how records are framed for transport. A channel must support use by
|
||
|
// one sender and one receiver concurrently, but is not otherwise required to
|
||
|
// be safe for concurrent use.
|
||
|
//
|
||
|
// Framing
|
||
|
//
|
||
|
// A Framing function adapts a pair of io.Reader and io.WriteCloser to a
|
||
|
// Channel by imposing a particular message-framing discipline. This package
|
||
|
// provides several framing implementations, for example:
|
||
|
//
|
||
|
// ch := channel.LSP(r, wc)
|
||
|
//
|
||
|
// creates a channel that reads from r and writes to wc using the Language
|
||
|
// Server Protocol (LSP) framing defined by
|
||
|
// https://microsoft.github.io/language-server-protocol/specification.
|
||
|
//
|
||
|
package channel
|
||
|
|
||
|
import "strings"
|
||
|
|
||
|
// A Sender represents the ability to transmit a message on a channel.
|
||
|
type Sender interface {
|
||
|
// Send transmits a record on the channel. Each call to Send transmits one
|
||
|
// complete record.
|
||
|
Send([]byte) error
|
||
|
}
|
||
|
|
||
|
// A Receiver represents the ability to receive a message from a channel.
|
||
|
type Receiver interface {
|
||
|
// Recv returns the next available record from the channel. If no further
|
||
|
// messages are available, it returns nil, io.EOF. Each call to Recv
|
||
|
// fetches a single complete record.
|
||
|
Recv() ([]byte, error)
|
||
|
}
|
||
|
|
||
|
// A Channel represents the ability to transmit and receive data records. A
|
||
|
// channel does not interpret the contents of a record, but may add and remove
|
||
|
// framing so that records can be embedded in higher-level protocols.
|
||
|
//
|
||
|
// One sender and one receiver may use a Channel concurrently, but the methods
|
||
|
// of a Channel are not otherwise required to be safe for concurrent use.
|
||
|
type Channel interface {
|
||
|
Sender
|
||
|
Receiver
|
||
|
|
||
|
// Close shuts down the channel, after which no further records may be
|
||
|
// sent or received.
|
||
|
Close() error
|
||
|
}
|
||
|
|
||
|
// IsErrClosing reports whether err is the internal error returned by a read
|
||
|
// from a pipe or socket that is closed. This is false for err == nil.
|
||
|
func IsErrClosing(err error) bool {
|
||
|
// That we must check the string here appears to be working as intended, or at least
|
||
|
// there is no intent to make it better. https://github.com/golang/go/issues/4373
|
||
|
return err != nil && strings.Contains(err.Error(), "use of closed network connection")
|
||
|
}
|