mirror of
https://github.com/foxcpp/maddy.git
synced 2025-04-05 14:07:38 +03:00
The intention is to keep to repo root clean while the list of packages is slowly growing. Additionally, a bunch of small (~30 LoC) files in the repo root is merged into a single maddy.go file, for the same reason. Most of the internal code is moved into the internal/ directory. Go toolchain will make it impossible to import these packages from external applications. Some packages are renamed and moved into the pkg/ directory in the root. According to https://github.com/golang-standards/project-layout this is the de-facto standard to place "library code that's ok to use by external applications" in. To clearly define the purpose of top-level directories, README.md files are added to each.
48 lines
1.2 KiB
Go
48 lines
1.2 KiB
Go
package buffer
|
|
|
|
import (
|
|
"bytes"
|
|
)
|
|
|
|
// TODO: Remove this interface from here, it is no longer necessary.
|
|
type Byter interface {
|
|
Bytes() []byte
|
|
}
|
|
|
|
// BytesReader is a wrapper for bytes.Reader that stores the original []byte
|
|
// value and allows to retrieve it.
|
|
//
|
|
// It is meant for passing to libraries that expect a io.Reader
|
|
// but apply certain optimizations when the Reader implements
|
|
// Bytes() interface.
|
|
type BytesReader struct {
|
|
*bytes.Reader
|
|
value []byte
|
|
}
|
|
|
|
// Bytes returns the unread portion of underlying slice used to construct
|
|
// BytesReader.
|
|
func (br BytesReader) Bytes() []byte {
|
|
return br.value[int(br.Size())-br.Len():]
|
|
}
|
|
|
|
// Copy returns the BytesReader reading from the same slice as br at the same
|
|
// position.
|
|
func (br BytesReader) Copy() BytesReader {
|
|
return NewBytesReader(br.Bytes())
|
|
}
|
|
|
|
// Close is a dummy method for implementation of io.Closer so BytesReader can
|
|
// be used in MemoryBuffer directly.
|
|
func (br BytesReader) Close() error {
|
|
return nil
|
|
}
|
|
|
|
func NewBytesReader(b []byte) BytesReader {
|
|
// BytesReader and not *BytesReader because BytesReader already wraps two
|
|
// pointers and double indirection would be pointless.
|
|
return BytesReader{
|
|
Reader: bytes.NewReader(b),
|
|
value: b,
|
|
}
|
|
}
|