mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 12:08:58 +01:00
audio/mp3: Remove all exports to C
This commit is contained in:
parent
02e284ea9d
commit
51a2507430
@ -124,19 +124,18 @@ func getBytes(buf []int) (int, error) {
|
|||||||
return len(buf), nil
|
return len(buf), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
//export Get_Filepos
|
func getFilepos() int {
|
||||||
func Get_Filepos() C.unsigned {
|
|
||||||
if len(readerCache) == 0 && readerEOF {
|
if len(readerCache) == 0 && readerEOF {
|
||||||
return eof
|
return eof
|
||||||
}
|
}
|
||||||
return C.unsigned(readerPos)
|
return readerPos
|
||||||
}
|
}
|
||||||
|
|
||||||
func decode(r io.Reader, w io.Writer) error {
|
func decode(r io.Reader, w io.Writer) error {
|
||||||
// TODO: Decoder should know number of channels
|
// TODO: Decoder should know number of channels
|
||||||
reader = r
|
reader = r
|
||||||
writer = w
|
writer = w
|
||||||
for Get_Filepos() != eof {
|
for getFilepos() != eof {
|
||||||
err := readFrame()
|
err := readFrame()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
if err := decodeL3(); err != nil {
|
if err := decodeL3(); err != nil {
|
||||||
@ -144,7 +143,7 @@ func decode(r io.Reader, w io.Writer) error {
|
|||||||
}
|
}
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if Get_Filepos() == eof {
|
if getFilepos() == eof {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
return err
|
return err
|
||||||
|
@ -71,7 +71,7 @@ func readMainL3() error {
|
|||||||
}
|
}
|
||||||
for gr := 0; gr < 2; gr++ {
|
for gr := 0; gr < 2; gr++ {
|
||||||
for ch := 0; ch < nch; ch++ {
|
for ch := 0; ch < nch; ch++ {
|
||||||
part_2_start := int(Get_Main_Pos())
|
part_2_start := getMainPos()
|
||||||
/* Number of bits in the bitstream for the bands */
|
/* Number of bits in the bitstream for the bands */
|
||||||
slen1 := mpeg1_scalefac_sizes[C.g_side_info.scalefac_compress[gr][ch]][0]
|
slen1 := mpeg1_scalefac_sizes[C.g_side_info.scalefac_compress[gr][ch]][0]
|
||||||
slen2 := mpeg1_scalefac_sizes[C.g_side_info.scalefac_compress[gr][ch]][1]
|
slen2 := mpeg1_scalefac_sizes[C.g_side_info.scalefac_compress[gr][ch]][1]
|
||||||
@ -270,18 +270,15 @@ func getMainBits(num int) int {
|
|||||||
return int(tmp)
|
return int(tmp)
|
||||||
}
|
}
|
||||||
|
|
||||||
//export Get_Main_Pos
|
func getMainPos() int {
|
||||||
func Get_Main_Pos() C.unsigned {
|
|
||||||
pos := theMainDataBytes.pos
|
pos := theMainDataBytes.pos
|
||||||
pos *= 8 /* Multiply by 8 to get number of bits */
|
pos *= 8 /* Multiply by 8 to get number of bits */
|
||||||
pos += theMainDataBytes.idx /* Add current bit index */
|
pos += theMainDataBytes.idx /* Add current bit index */
|
||||||
return C.unsigned(pos)
|
return pos
|
||||||
}
|
}
|
||||||
|
|
||||||
//export Set_Main_Pos
|
func setMainPos(bit_pos int) {
|
||||||
func Set_Main_Pos(bit_pos C.unsigned) C.int {
|
|
||||||
theMainDataBytes.ptr = theMainDataBytes.vec[bit_pos>>3:]
|
theMainDataBytes.ptr = theMainDataBytes.vec[bit_pos>>3:]
|
||||||
theMainDataBytes.pos = int(bit_pos) >> 3
|
theMainDataBytes.pos = int(bit_pos) >> 3
|
||||||
theMainDataBytes.idx = int(bit_pos) & 0x7
|
theMainDataBytes.idx = int(bit_pos) & 0x7
|
||||||
return C.OK
|
|
||||||
}
|
}
|
||||||
|
@ -84,9 +84,4 @@ typedef struct { /* Scale factor band indices,for long and short windows */
|
|||||||
}
|
}
|
||||||
t_sf_band_indices;
|
t_sf_band_indices;
|
||||||
|
|
||||||
unsigned Get_Filepos(void);
|
|
||||||
|
|
||||||
unsigned Get_Main_Pos(void);
|
|
||||||
int Set_Main_Pos(unsigned bit_pos);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -148,23 +148,23 @@ func readHeader() error {
|
|||||||
/* Check for invalid values and impossible combinations */
|
/* Check for invalid values and impossible combinations */
|
||||||
if C.g_frame_header.id != 3 {
|
if C.g_frame_header.id != 3 {
|
||||||
return fmt.Errorf("mp3: ID must be 3\nHeader word is 0x%08x at file pos %d",
|
return fmt.Errorf("mp3: ID must be 3\nHeader word is 0x%08x at file pos %d",
|
||||||
header, C.Get_Filepos())
|
header, getFilepos())
|
||||||
}
|
}
|
||||||
if C.g_frame_header.bitrate_index == 0 {
|
if C.g_frame_header.bitrate_index == 0 {
|
||||||
return fmt.Errorf("mp3: Free bitrate format NIY!\nHeader word is 0x%08x at file pos %d",
|
return fmt.Errorf("mp3: Free bitrate format NIY!\nHeader word is 0x%08x at file pos %d",
|
||||||
header, Get_Filepos())
|
header, getFilepos())
|
||||||
}
|
}
|
||||||
if C.g_frame_header.bitrate_index == 15 {
|
if C.g_frame_header.bitrate_index == 15 {
|
||||||
return fmt.Errorf("mp3: bitrate_index = 15 is invalid!\nHeader word is 0x%08x at file pos %d",
|
return fmt.Errorf("mp3: bitrate_index = 15 is invalid!\nHeader word is 0x%08x at file pos %d",
|
||||||
header, Get_Filepos())
|
header, getFilepos())
|
||||||
}
|
}
|
||||||
if C.g_frame_header.sampling_frequency == 3 {
|
if C.g_frame_header.sampling_frequency == 3 {
|
||||||
return fmt.Errorf("mp3: sampling_frequency = 3 is invalid! Header word is 0x%08x at file pos %d",
|
return fmt.Errorf("mp3: sampling_frequency = 3 is invalid! Header word is 0x%08x at file pos %d",
|
||||||
header, Get_Filepos())
|
header, getFilepos())
|
||||||
}
|
}
|
||||||
if C.g_frame_header.layer == 0 {
|
if C.g_frame_header.layer == 0 {
|
||||||
return fmt.Errorf("mp3: layer = 0 is invalid! Header word is 0x%08x at file pos %d",
|
return fmt.Errorf("mp3: layer = 0 is invalid! Header word is 0x%08x at file pos %d",
|
||||||
header, Get_Filepos())
|
header, getFilepos())
|
||||||
}
|
}
|
||||||
C.g_frame_header.layer = 4 - C.g_frame_header.layer
|
C.g_frame_header.layer = 4 - C.g_frame_header.layer
|
||||||
return nil
|
return nil
|
||||||
@ -217,7 +217,7 @@ func readHuffman(part_2_start, gr, ch int) error {
|
|||||||
/* Read small values until is_pos = 576 or we run out of huffman data */
|
/* Read small values until is_pos = 576 or we run out of huffman data */
|
||||||
table_num := int(C.g_side_info.count1table_select[gr][ch]) + 32
|
table_num := int(C.g_side_info.count1table_select[gr][ch]) + 32
|
||||||
is_pos := int(C.g_side_info.big_values[gr][ch]) * 2
|
is_pos := int(C.g_side_info.big_values[gr][ch]) * 2
|
||||||
for ; (is_pos <= 572) && (int(Get_Main_Pos()) <= bit_pos_end); is_pos++ {
|
for ; (is_pos <= 572) && (getMainPos() <= bit_pos_end); is_pos++ {
|
||||||
/* Get next Huffman coded words */
|
/* Get next Huffman coded words */
|
||||||
x, y, v, w, err := huffmanDecode(table_num)
|
x, y, v, w, err := huffmanDecode(table_num)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -241,7 +241,7 @@ func readHuffman(part_2_start, gr, ch int) error {
|
|||||||
C.g_main_data.is[gr][ch][is_pos] = C.float(y)
|
C.g_main_data.is[gr][ch][is_pos] = C.float(y)
|
||||||
}
|
}
|
||||||
/* Check that we didn't read past the end of this section */
|
/* Check that we didn't read past the end of this section */
|
||||||
if int(C.Get_Main_Pos()) > (bit_pos_end + 1) {
|
if getMainPos() > (bit_pos_end + 1) {
|
||||||
/* Remove last words read */
|
/* Remove last words read */
|
||||||
is_pos -= 4
|
is_pos -= 4
|
||||||
}
|
}
|
||||||
@ -252,6 +252,6 @@ func readHuffman(part_2_start, gr, ch int) error {
|
|||||||
C.g_main_data.is[gr][ch][is_pos] = 0.0
|
C.g_main_data.is[gr][ch][is_pos] = 0.0
|
||||||
}
|
}
|
||||||
/* Set the bitpos to point to the next part to read */
|
/* Set the bitpos to point to the next part to read */
|
||||||
C.Set_Main_Pos(C.unsigned(bit_pos_end) + 1)
|
setMainPos(bit_pos_end + 1)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -149,7 +149,7 @@ func getSideinfo(size int) error {
|
|||||||
return fmt.Errorf("mp3: unexpected EOF at getSideinfo")
|
return fmt.Errorf("mp3: unexpected EOF at getSideinfo")
|
||||||
}
|
}
|
||||||
return fmt.Errorf("mp3: couldn't read sideinfo %d bytes at pos %d: %v",
|
return fmt.Errorf("mp3: couldn't read sideinfo %d bytes at pos %d: %v",
|
||||||
size, Get_Filepos(), err)
|
size, getFilepos(), err)
|
||||||
}
|
}
|
||||||
theSideInfo.vec = buf[:n]
|
theSideInfo.vec = buf[:n]
|
||||||
theSideInfo.idx = 0
|
theSideInfo.idx = 0
|
||||||
|
Loading…
Reference in New Issue
Block a user