forked from Shiloh/githaven
49 lines
1.3 KiB
Go
49 lines
1.3 KiB
Go
|
// Package buffer implements a series of Buffers which can be composed to implement complicated buffering strategies
|
||
|
package buffer
|
||
|
|
||
|
import (
|
||
|
"io"
|
||
|
"os"
|
||
|
)
|
||
|
|
||
|
// Buffer is used to Write() data which will be Read() later.
|
||
|
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.
|
||
|
}
|
||
|
|
||
|
// BufferAt is a buffer which supports io.ReaderAt and io.WriterAt
|
||
|
type BufferAt interface {
|
||
|
Buffer
|
||
|
io.ReaderAt
|
||
|
io.WriterAt
|
||
|
}
|
||
|
|
||
|
func len64(p []byte) int64 {
|
||
|
return int64(len(p))
|
||
|
}
|
||
|
|
||
|
// Gap returns buf.Cap() - buf.Len()
|
||
|
func Gap(buf Buffer) int64 {
|
||
|
return buf.Cap() - buf.Len()
|
||
|
}
|
||
|
|
||
|
// Full returns true iff buf.Len() == buf.Cap()
|
||
|
func Full(buf Buffer) bool {
|
||
|
return buf.Len() == buf.Cap()
|
||
|
}
|
||
|
|
||
|
// Empty returns false iff buf.Len() == 0
|
||
|
func Empty(buf Buffer) bool {
|
||
|
return buf.Len() == 0
|
||
|
}
|
||
|
|
||
|
// NewUnboundedBuffer returns a Buffer which buffers "mem" bytes to memory
|
||
|
// and then creates file's of size "file" to buffer above "mem" bytes.
|
||
|
func NewUnboundedBuffer(mem, file int64) Buffer {
|
||
|
return NewMulti(New(mem), NewPartition(NewFilePool(file, os.TempDir())))
|
||
|
}
|