av/stream/flc: using my own writeSeeker implementation - working

This commit is contained in:
saxon 2019-01-21 17:50:09 +10:30
parent 155134eeed
commit 28e26cd151
1 changed files with 44 additions and 8 deletions

View File

@ -4,16 +4,55 @@ import (
"bytes" "bytes"
"errors" "errors"
"io" "io"
"io/ioutil"
"github.com/go-audio/audio" "github.com/go-audio/audio"
"github.com/go-audio/wav" "github.com/go-audio/wav"
"github.com/mewkiz/flac" "github.com/mewkiz/flac"
"github.com/orcaman/writerseeker"
) )
const wavAudioFormat = 1 const wavAudioFormat = 1
type WriterSeeker struct {
buf []byte
pos int
}
func (ws *WriterSeeker) Bytes() []byte {
return ws.buf
}
func (m *WriterSeeker) Write(p []byte) (n int, err error) {
minCap := m.pos + len(p)
if minCap > cap(m.buf) { // Make sure buf has enough capacity:
buf2 := make([]byte, len(m.buf), minCap+len(p)) // add some extra
copy(buf2, m.buf)
m.buf = buf2
}
if minCap > len(m.buf) {
m.buf = m.buf[:minCap]
}
copy(m.buf[m.pos:], p)
m.pos += len(p)
return len(p), nil
}
func (m *WriterSeeker) Seek(offset int64, whence int) (int64, error) {
newPos, offs := 0, int(offset)
switch whence {
case io.SeekStart:
newPos = offs
case io.SeekCurrent:
newPos = m.pos + offs
case io.SeekEnd:
newPos = len(m.buf) + offs
}
if newPos < 0 {
return 0, errors.New("negative result pos")
}
m.pos = newPos
return int64(newPos), nil
}
// Decode takes a slice of flac and decodes to wav // Decode takes a slice of flac and decodes to wav
func Decode(buf []byte) ([]byte, error) { func Decode(buf []byte) ([]byte, error) {
r := bytes.NewReader(buf) r := bytes.NewReader(buf)
@ -21,7 +60,7 @@ func Decode(buf []byte) ([]byte, error) {
if err != nil { if err != nil {
return nil, errors.New("Could not parse FLAC") return nil, errors.New("Could not parse FLAC")
} }
ws := &writerseeker.WriterSeeker{} ws := &WriterSeeker{}
enc := wav.NewEncoder(ws, int(stream.Info.SampleRate), int(stream.Info.BitsPerSample), int(stream.Info.NChannels), wavAudioFormat) enc := wav.NewEncoder(ws, int(stream.Info.SampleRate), int(stream.Info.BitsPerSample), int(stream.Info.NChannels), wavAudioFormat)
defer enc.Close() defer enc.Close()
var data []int var data []int
@ -54,9 +93,6 @@ func Decode(buf []byte) ([]byte, error) {
return nil, err return nil, err
} }
} }
d, err := ioutil.ReadAll(ws.Reader())
if err != nil { return ws.Bytes(), nil
return nil, err
}
return d, nil
} }