ioext

package
v0.0.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 13, 2016 License: MPL-2.0 Imports: 8 Imported by: 1

Documentation

Overview

Package ioext contains interfaces and implementations for when the default io types are not sufficient.

Index

Constants

This section is empty.

Variables

View Source
var ErrFileTooBig = errors.New("File is larger than max size given")

ErrFileTooBig is used the indicate that a file is too big.

View Source
var ErrMaxSizeExceeded = errors.New("MaxSize was exceeded before EOF was reached")

ErrMaxSizeExceeded signals that EOF wasn't reached instead max size was was read and, hence, we stopped reading.

View Source
var ErrPipeFull = errors.New("The internal pipe buffer have reached its capacity")

ErrPipeFull is returned from AsyncPipeWriter.Write if the pipes capacity has been reached.

Functions

func AsyncPipe

func AsyncPipe(capacity int, tell chan<- int) (*AsyncPipeReader, *AsyncPipeWriter)

AsyncPipe is similar to io.Pipe() except that writes isn't blocking, instead data will be added to an internal buffer that can grow up to specified capacity. Additionally, you may supply a channel tell that will be told whenever N bytes have been read, so that more bytes can be requested to be written.

This pipe kind is useful when implementing congestion control.

func BlockedPipe

func BlockedPipe() (*PipeReader, *PipeWriter)

BlockedPipe is similar to io.Pipe() except the pipe is blocked until PipeReader.Unblock(n) is called to unblock n bytes. This is useful when implementing congestion control.

Note: PipeReader.Unblock(-1) will permanently unblock the pipe, PipeReader.Close() will break the pipe, either one must be called unless the pipe is read EOF. Otherwise, the pipe will remain blocked and you may leak a go routine.

func BoundedReadAll

func BoundedReadAll(r io.Reader, maxBytes int) ([]byte, error)

BoundedReadAll will read up to maxBytes from r, and returns ErrFileTooBig if the file is larger.

func BoundedReadFile

func BoundedReadFile(filename string, maxBytes int) ([]byte, error)

BoundedReadFile will read up to maxBytes from filename, and returns ErrFileTooBig if the file is larger, and *os.PathError if file doesn't exist.

func CopyAndClose

func CopyAndClose(w io.WriteCloser, r io.Reader) (int64, error)

CopyAndClose will copy from r to w and close w, returning the number of bytes copied and the first error, if any, this always closes regardless of error.

func IsFileLessThan

func IsFileLessThan(filePath string, maxSize int64) bool

IsFileLessThan returns true if filePath is a file less than maxSize

func IsPlainFile

func IsPlainFile(filePath string) bool

IsPlainFile returns an true if filePath is a plain file, not a directory, symlink, device, etc.

func IsPlainFileInfo

func IsPlainFileInfo(info os.FileInfo) bool

IsPlainFileInfo returns true, if info is for a plain file, not a dictionary, symlink, device, etc.

func NopConn

func NopConn(conn io.ReadWriteCloser) net.Conn

NopConn wraps conn so that it provides a trivial implementation of net.Conn. This is only useful for testing, deadlines are ignored and address methods will return nil.

func ReadAtMost

func ReadAtMost(r io.Reader, maxSize int64) ([]byte, error)

ReadAtMost will read at-most maxSize bytes from r and return an error if we didn't reach EOF. Returns ErrMaxSizeExceeded if r contains more than maxSize bytes. If maxSize is -1 ReadAtMost will read everything.

This utility is useful when reading HTTP requests, in particular if reading from untrusted sources. If using io.ReadAll it's easy to run the server out of memory, a maxSize of 2MiB is usually sane and prevents such attacks.

func WatchPipe

func WatchPipe(pipe io.ReadWriteCloser, onClose func(error)) io.ReadWriteCloser

WatchPipe will wrap an io.ReadWriteCloser such that onClose is called when the first read or write error happens, or after close() is called.

The onClose callback will be called with the error from read, write or close. To allow for locking for example to remove the pipe from a list when closed, the onClose callback is always called on in separate go-routine.

func WriteNopCloser

func WriteNopCloser(w io.Writer) io.WriteCloser

WriteNopCloser wraps an io.Writer and creates a io.WriteCloser where Close is a noop.

Types

type AsyncPipeReader

type AsyncPipeReader struct {
	*AsyncPipeWriter
}

AsyncPipeReader is a reading side of an AsyncPipe, similar to io.PipeReader.

func (*AsyncPipeReader) Close

func (r *AsyncPipeReader) Close() error

Close the pipe reader

func (*AsyncPipeReader) Read

func (r *AsyncPipeReader) Read(p []byte) (int, error)

type AsyncPipeWriter

type AsyncPipeWriter struct {
	// contains filtered or unexported fields
}

AsyncPipeWriter is a writing side of a BlockedPipe, similar to io.PipeWriter.

func (*AsyncPipeWriter) Close

func (w *AsyncPipeWriter) Close() error

Close will close the stream

func (*AsyncPipeWriter) Write

func (w *AsyncPipeWriter) Write(p []byte) (int, error)

type PipeReader

type PipeReader struct {
	// contains filtered or unexported fields
}

PipeReader is a reading side of a BlockedPipe, similar to io.PipeReader.

func (*PipeReader) Close

func (r *PipeReader) Close() error

Close mirrors io.PipeReader.Close()

func (*PipeReader) CloseWithError

func (r *PipeReader) CloseWithError(err error) error

CloseWithError mirrors io.PipeReader.CloseWithError()

func (*PipeReader) Read

func (r *PipeReader) Read(data []byte) (int, error)

Read mirrors io.PipeReader.Read() except it won't read more bytes than have been unblocked by calling r.Unblock().

func (*PipeReader) Unblock

func (r *PipeReader) Unblock(n int64)

Unblock allows n bytes to traverse through the pipe. Typically, this pipe is used when implementing congestion control and r.Unblock(n) is then called when the remote side have acknowledged n bytes. This way the network isn't congested with lots of outstanding bytes.

As a special case n = -1 permanently unblocks the pipe.

Note: That with this reader it is important to call r.Close() when cleaning up or r.Unblock(-1) as w.Close() won't propagate unless enough bytes are unblocked, and this could otherwise leave the pipe permanently blocked, which easily leaves you leaking go routines.

type PipeWriter

type PipeWriter struct {
	// contains filtered or unexported fields
}

PipeWriter is a writing side of a BlockedPipe, similar to io.PipeWriter.

func (*PipeWriter) Close

func (w *PipeWriter) Close() error

Close mirrors io.PipeWriter.Close()

func (*PipeWriter) CloseWithError

func (w *PipeWriter) CloseWithError(err error) error

CloseWithError mirrors io.CloseWithError.CloseWithError()

func (*PipeWriter) Write

func (w *PipeWriter) Write(data []byte) (int, error)

type ReadSeekCloser

type ReadSeekCloser interface {
	io.Reader
	io.Seeker
	io.Closer
}

ReadSeekCloser implements io.Reader, io.Seeker, and io.Closer. It is trivially implemented by os.File.

func NopCloser

func NopCloser(r io.ReadSeeker) ReadSeekCloser

NopCloser wraps a io.ReadSeeker as ReadSeekCloser with Close being a noop. This is useful for compliance with interface, if you don't care about closing.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL