Browse Source

envexp: bind Reader and Expander

Signed-off-by: Alejandro Mery <[email protected]>
v0.2.x
Alejandro Mery 4 years ago
parent
commit
f88c3f9b0c
  1. 25
      envexp/global.go
  2. 16
      envexp/reader.go

25
envexp/global.go

@ -1,6 +1,7 @@
package envexp package envexp
import ( import (
"io"
"os" "os"
) )
@ -12,3 +13,27 @@ var envExpander = &Expander{
func Expand(s string) string { func Expand(s string) string {
return envExpander.Expand(s) return envExpander.Expand(s)
} }
// NewReaderSize creates a new Reader wrapper with a given buffer size
// using os.GetEnv() for expanding
func NewReaderSize(in io.Reader, size int) *Reader {
return envExpander.NewReaderSize(in, size)
}
// NewReader creates a new Reader wrapper
// using os.GetEnv() for expanding
func NewReader(in io.Reader) *Reader {
return envExpander.NewReader(in)
}
// NewReaderFileSize creates a new Reader for a file
// with a given buffer size using os.GetEnv() for expanding
func NewReaderFileSize(filename string, size int) (*Reader, error) {
return envExpander.NewReaderFileSize(filename, size)
}
// NewReaderFile creates a new Reader for a file
// using os.GetEnv() for expanding
func NewReaderFile(filename string) (*Reader, error) {
return envExpander.NewReaderFile(filename)
}

16
envexp/reader.go

@ -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)
} }

Loading…
Cancel
Save