Documentation ¶
Overview ¶
Package buffer implements a series of Buffers which can be composed to implement complicated buffering strategies
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type Buffer ¶
type Buffer interface { Len() int64 // How much data is Buffered in bytes Cap() int64 // How much data can be Buffered at once in bytes. io.Reader // Read() will read from the top of the buffer [io.EOF if empty] io.Writer // Write() will write to the end of the buffer [io.ErrShortWrite if not enough space] Reset() // Truncates the buffer, Len() == 0. }
Buffer is used to Write() data which will be Read() later.
var Discard Buffer = discard{}
Discard is a Buffer which writes to ioutil.Discard and read's return 0, io.EOF. All of its methods are concurrent safe.
func NewMulti ¶
NewMulti returns a Buffer which is the logical concatenation of the passed buffers. The data in the buffers is shifted such that there is no non-empty buffer following a non-full buffer, this process is also run after every Read. If no buffers are passed, the returned Buffer is nil.
func NewPartition ¶
NewPartition returns a Buffer which uses a Pool to extend or shrink its size as needed. It automatically allocates new buffers with pool.Get() to extend is length, and pool.Put() to release unused buffers as it shrinks.
func NewRing ¶
NewRing returns a Ring Buffer from a BufferAt. It overwrites old data in the Buffer when needed (when its full).
func NewSpill ¶
NewSpill returns a Buffer which writes data to w when there's an error writing to buf. Such as when buf is full, or the disk is full, etc.
func NewSwap ¶
NewSwap creates a Buffer which writes to a until you write past a.Cap() then it io.Copy's from a to b and writes to b. Once the Buffer is empty again, it starts over writing to a. Note that if b.Cap() <= a.Cap() it will cause a panic, b is expected to be larger in order to accomodate writes past a.Cap().
func NewUnboundedBuffer ¶
NewUnboundedBuffer returns a Buffer which buffers "mem" bytes to memory and then creates file's of size "file" to buffer above "mem" bytes.
type BufferAt ¶
BufferAt is a buffer which supports io.ReaderAt and io.WriterAt
func NewMultiAt ¶
NewMultiAt returns a BufferAt which is the logical concatenation of the passed BufferAts. The data in the buffers is shifted such that there is no non-empty buffer following a non-full buffer, this process is also run after every Read. If no buffers are passed, the returned Buffer is nil.
func NewSwapAt ¶
NewSwapAt creates a BufferAt which writes to a until you write past a.Cap() then it io.Copy's from a to b and writes to b. Once the Buffer is empty again, it starts over writing to a. Note that if b.Cap() <= a.Cap() it will cause a panic, b is expected to be larger in order to accomodate writes past a.Cap().
type File ¶
type File interface { Name() string Stat() (fi os.FileInfo, err error) io.ReaderAt io.WriterAt Close() error }
File is used as the backing resource for a the NewFile BufferAt.
type List ¶
type List []Buffer
List is a slice of Buffers, it's the backing for NewPartition
type Pool ¶
type Pool interface { Get() (Buffer, error) // Allocate a Buffer Put(buf Buffer) error // Release or Reuse a Buffer }
Pool provides a way to Allocate and Release Buffer objects Pools mut be concurrent-safe for calls to Get() and Put().
func NewFilePool ¶
NewFilePool returns a Pool, Get() returns a file-based buffer of max size N. Put() closes and deletes the underlying file for the buffer. Get() may return an error if it fails to create a file for the buffer. Put() may return an error if it fails to delete the file.
func NewMemPool ¶
NewMemPool returns a Pool, Get() returns an in memory buffer of max size N. Put() returns the buffer to the pool after resetting it. Get() and Put() errors will always be nil.