1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
package coding
import (
"bytes"
"io"
"io/fs"
"github.com/dromara/dongle/internal/utils"
)
// Encoder defines a Encoder struct.
type Encoder struct {
src []byte
dst []byte
reader io.Reader
Error error
}
// NewEncoder returns a new Encoder instance.
func NewEncoder() Encoder {
return Encoder{}
}
// FromString encodes from string.
func (e Encoder) FromString(s string) Encoder {
e.src = utils.String2Bytes(s)
return e
}
// FromBytes encodes from byte slice.
func (e Encoder) FromBytes(b []byte) Encoder {
e.src = b
return e
}
// FromFile encodes from file.
func (e Encoder) FromFile(f fs.File) Encoder {
e.reader = f
return e
}
// ToString outputs as string.
func (e Encoder) ToString() string {
if len(e.dst) == 0 || e.Error != nil {
return ""
}
return utils.Bytes2String(e.dst)
}
// ToBytes outputs as byte slice.
func (e Encoder) ToBytes() []byte {
if len(e.dst) == 0 || e.Error != nil {
return []byte{}
}
return e.dst
}
func (e Encoder) stream(fn func(io.Writer) io.WriteCloser) ([]byte, error) {
var buf bytes.Buffer
encoder := fn(&buf)
// Try to reset the reader position if it's a seeker
if seeker, ok := e.reader.(io.Seeker); ok {
seeker.Seek(0, io.SeekStart)
}
if _, err := io.CopyBuffer(encoder, e.reader, make([]byte, BufferSize)); err != nil && err != io.EOF {
encoder.Close()
return []byte{}, err
}
if err := encoder.Close(); err != nil {
return []byte{}, err
}
if buf.Len() == 0 {
return []byte{}, nil
}
return buf.Bytes(), nil
}
|