mirror of https://bitbucket.org/ausocean/av.git
av/stream/flac/decode.go: wrote func headers
This commit is contained in:
parent
28e26cd151
commit
5f3bf33213
|
@ -1,3 +1,29 @@
|
||||||
|
/*
|
||||||
|
NAME
|
||||||
|
decode.go
|
||||||
|
|
||||||
|
DESCRIPTION
|
||||||
|
decode.go provides functionality for the decoding of FLAC compressed audio
|
||||||
|
|
||||||
|
AUTHOR
|
||||||
|
Saxon Nelson-Milton <saxon@ausocean.org>
|
||||||
|
|
||||||
|
LICENSE
|
||||||
|
decode.go is Copyright (C) 2017-2019 the Australian Ocean Lab (AusOcean)
|
||||||
|
|
||||||
|
It is free software: you can redistribute it and/or modify them
|
||||||
|
under the terms of the GNU General Public License as published by the
|
||||||
|
Free Software Foundation, either version 3 of the License, or (at your
|
||||||
|
option) any later version.
|
||||||
|
|
||||||
|
It is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with revid in gpl.txt. If not, see http://www.gnu.org/licenses.
|
||||||
|
*/
|
||||||
package flac
|
package flac
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
@ -10,59 +36,72 @@ import (
|
||||||
"github.com/mewkiz/flac"
|
"github.com/mewkiz/flac"
|
||||||
)
|
)
|
||||||
|
|
||||||
const wavAudioFormat = 1
|
const wavFormat = 1
|
||||||
|
|
||||||
type WriterSeeker struct {
|
// writeSeeker implements a memory based io.WriteSeeker.
|
||||||
|
type writeSeeker struct {
|
||||||
buf []byte
|
buf []byte
|
||||||
pos int
|
pos int
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ws *WriterSeeker) Bytes() []byte {
|
// Bytes returns the bytes contained in the writeSeekers buffer.
|
||||||
|
func (ws *writeSeeker) Bytes() []byte {
|
||||||
return ws.buf
|
return ws.buf
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *WriterSeeker) Write(p []byte) (n int, err error) {
|
// Write writes len(p) bytes from p to the writeSeeker's buf and returns the number
|
||||||
minCap := m.pos + len(p)
|
// of bytes written. If less than len(p) bytes are written, an error is returned.
|
||||||
if minCap > cap(m.buf) { // Make sure buf has enough capacity:
|
func (ws *writeSeeker) Write(p []byte) (n int, err error) {
|
||||||
buf2 := make([]byte, len(m.buf), minCap+len(p)) // add some extra
|
minCap := ws.pos + len(p)
|
||||||
copy(buf2, m.buf)
|
if minCap > cap(ws.buf) { // Make sure buf has enough capacity:
|
||||||
m.buf = buf2
|
buf2 := make([]byte, len(ws.buf), minCap+len(p)) // add some extra
|
||||||
|
copy(buf2, ws.buf)
|
||||||
|
ws.buf = buf2
|
||||||
}
|
}
|
||||||
if minCap > len(m.buf) {
|
if minCap > len(ws.buf) {
|
||||||
m.buf = m.buf[:minCap]
|
ws.buf = ws.buf[:minCap]
|
||||||
}
|
}
|
||||||
copy(m.buf[m.pos:], p)
|
copy(ws.buf[ws.pos:], p)
|
||||||
m.pos += len(p)
|
ws.pos += len(p)
|
||||||
return len(p), nil
|
return len(p), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *WriterSeeker) Seek(offset int64, whence int) (int64, error) {
|
// Seek sets the offset for the next Read or Write to offset, interpreted according
|
||||||
|
// to whence: SeekStart means relative to the start of the file, SeekCurrent means
|
||||||
|
// relative to the current offset, and SeekEnd means relative to the end. Seek returns
|
||||||
|
// the new offset relative to the start of the file and an error, if any.
|
||||||
|
func (ws *writeSeeker) Seek(offset int64, whence int) (int64, error) {
|
||||||
newPos, offs := 0, int(offset)
|
newPos, offs := 0, int(offset)
|
||||||
switch whence {
|
switch whence {
|
||||||
case io.SeekStart:
|
case io.SeekStart:
|
||||||
newPos = offs
|
newPos = offs
|
||||||
case io.SeekCurrent:
|
case io.SeekCurrent:
|
||||||
newPos = m.pos + offs
|
newPos = ws.pos + offs
|
||||||
case io.SeekEnd:
|
case io.SeekEnd:
|
||||||
newPos = len(m.buf) + offs
|
newPos = len(ws.buf) + offs
|
||||||
}
|
}
|
||||||
if newPos < 0 {
|
if newPos < 0 {
|
||||||
return 0, errors.New("negative result pos")
|
return 0, errors.New("negative result pos")
|
||||||
}
|
}
|
||||||
m.pos = newPos
|
ws.pos = newPos
|
||||||
return int64(newPos), nil
|
return int64(newPos), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Decode takes a slice of flac and decodes to wav
|
// Decode takes buf, a slice of FLAC, and decodes to WAV. If complete decoding
|
||||||
|
// fails, an error is returned.
|
||||||
func Decode(buf []byte) ([]byte, error) {
|
func Decode(buf []byte) ([]byte, error) {
|
||||||
|
// Lex and decode the FLAC into a stream to hold audio and properties.
|
||||||
r := bytes.NewReader(buf)
|
r := bytes.NewReader(buf)
|
||||||
stream, err := flac.Parse(r)
|
stream, err := flac.Parse(r)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.New("Could not parse FLAC")
|
return nil, errors.New("Could not parse FLAC")
|
||||||
}
|
}
|
||||||
ws := &WriterSeeker{}
|
|
||||||
enc := wav.NewEncoder(ws, int(stream.Info.SampleRate), int(stream.Info.BitsPerSample), int(stream.Info.NChannels), wavAudioFormat)
|
// Create WAV encoder and pass writeSeeker that will store output WAV.
|
||||||
|
ws := &writeSeeker{}
|
||||||
|
enc := wav.NewEncoder(ws, int(stream.Info.SampleRate), int(stream.Info.BitsPerSample), int(stream.Info.NChannels), wavFormat)
|
||||||
defer enc.Close()
|
defer enc.Close()
|
||||||
|
|
||||||
var data []int
|
var data []int
|
||||||
for {
|
for {
|
||||||
// Decode FLAC audio samples.
|
// Decode FLAC audio samples.
|
||||||
|
|
|
@ -1,3 +1,29 @@
|
||||||
|
/*
|
||||||
|
NAME
|
||||||
|
flac_test.go
|
||||||
|
|
||||||
|
DESCRIPTION
|
||||||
|
flac_test.go provides utilities to test FLAC audio decoding
|
||||||
|
|
||||||
|
AUTHOR
|
||||||
|
Saxon Nelson-Milton <saxon@ausocean.org>
|
||||||
|
|
||||||
|
LICENSE
|
||||||
|
flac_test.go is Copyright (C) 2017-2019 the Australian Ocean Lab (AusOcean)
|
||||||
|
|
||||||
|
It is free software: you can redistribute it and/or modify them
|
||||||
|
under the terms of the GNU General Public License as published by the
|
||||||
|
Free Software Foundation, either version 3 of the License, or (at your
|
||||||
|
option) any later version.
|
||||||
|
|
||||||
|
It is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with revid in gpl.txt. If not, see http://www.gnu.org/licenses.
|
||||||
|
*/
|
||||||
package flac
|
package flac
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
|
Loading…
Reference in New Issue