|
|
@ -12,6 +12,7 @@ const ( |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
type Reader struct { |
|
|
|
type Reader struct { |
|
|
|
|
|
|
|
exp *Expander |
|
|
|
in io.Reader |
|
|
|
in io.Reader |
|
|
|
buf *bytes.Buffer |
|
|
|
buf *bytes.Buffer |
|
|
|
out *bytes.Buffer |
|
|
|
out *bytes.Buffer |
|
|
@ -31,32 +32,33 @@ func (rd *Reader) Close() error { |
|
|
|
//
|
|
|
|
//
|
|
|
|
// Constructors
|
|
|
|
// Constructors
|
|
|
|
//
|
|
|
|
//
|
|
|
|
func NewReaderSize(in io.Reader, size int) *Reader { |
|
|
|
func (exp *Expander) NewReaderSize(in io.Reader, size int) *Reader { |
|
|
|
if size < MinimumBufferSize { |
|
|
|
if size < MinimumBufferSize { |
|
|
|
size = DefaultBufferSize |
|
|
|
size = DefaultBufferSize |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return &Reader{ |
|
|
|
return &Reader{ |
|
|
|
|
|
|
|
exp: exp, |
|
|
|
in: in, |
|
|
|
in: in, |
|
|
|
buf: bytes.NewBuffer(make([]byte, 0, size)), |
|
|
|
buf: bytes.NewBuffer(make([]byte, 0, size)), |
|
|
|
out: bytes.NewBuffer(make([]byte, 0, size)), |
|
|
|
out: bytes.NewBuffer(make([]byte, 0, size)), |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func NewReader(in io.Reader) *Reader { |
|
|
|
func (exp *Expander) NewReader(in io.Reader) *Reader { |
|
|
|
return NewReaderSize(in, DefaultBufferSize) |
|
|
|
return exp.NewReaderSize(in, DefaultBufferSize) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func NewReaderFileSize(filename string, size int) (*Reader, error) { |
|
|
|
func (exp *Expander) NewReaderFileSize(filename string, size int) (*Reader, error) { |
|
|
|
f, err := os.Open(filename) |
|
|
|
f, err := os.Open(filename) |
|
|
|
if err != nil { |
|
|
|
if err != nil { |
|
|
|
return nil, err |
|
|
|
return nil, err |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
rd := NewReaderSize(f, size) |
|
|
|
rd := exp.NewReaderSize(f, size) |
|
|
|
return rd, nil |
|
|
|
return rd, nil |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func NewReaderFile(filename string) (*Reader, error) { |
|
|
|
func (exp *Expander) NewReaderFile(filename string) (*Reader, error) { |
|
|
|
return NewReaderFileSize(filename, DefaultBufferSize) |
|
|
|
return exp.NewReaderFileSize(filename, DefaultBufferSize) |
|
|
|
} |
|
|
|
} |
|
|
|