envexp: bind Reader and Expander

Signed-off-by: Alejandro Mery <amery@jpi.io>
This commit is contained in:
2021-06-26 20:41:44 +01:00
parent 3e2356a3f6
commit f88c3f9b0c
2 changed files with 34 additions and 7 deletions
+25
View File
@@ -1,6 +1,7 @@
package envexp
import (
"io"
"os"
)
@@ -12,3 +13,27 @@ var envExpander = &Expander{
func Expand(s string) string {
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)
}
+9 -7
View File
@@ -12,6 +12,7 @@ const (
)
type Reader struct {
exp *Expander
in io.Reader
buf *bytes.Buffer
out *bytes.Buffer
@@ -31,32 +32,33 @@ func (rd *Reader) Close() error {
//
// Constructors
//
func NewReaderSize(in io.Reader, size int) *Reader {
func (exp *Expander) NewReaderSize(in io.Reader, size int) *Reader {
if size < MinimumBufferSize {
size = DefaultBufferSize
}
return &Reader{
exp: exp,
in: in,
buf: bytes.NewBuffer(make([]byte, 0, size)),
out: bytes.NewBuffer(make([]byte, 0, size)),
}
}
func NewReader(in io.Reader) *Reader {
return NewReaderSize(in, DefaultBufferSize)
func (exp *Expander) NewReader(in io.Reader) *Reader {
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)
if err != nil {
return nil, err
}
rd := NewReaderSize(f, size)
rd := exp.NewReaderSize(f, size)
return rd, nil
}
func NewReaderFile(filename string) (*Reader, error) {
return NewReaderFileSize(filename, DefaultBufferSize)
func (exp *Expander) NewReaderFile(filename string) (*Reader, error) {
return exp.NewReaderFileSize(filename, DefaultBufferSize)
}