mirror of
https://github.com/ZDoom/qzdoom-gpl.git
synced 2024-11-27 14:12:28 +00:00
Removed homebrew MP3 format detection
It didn't work for all files so let libmpg123 handle all quirks for us See https://mantis.zdoom.org/view.php?id=60
This commit is contained in:
parent
c317a4cbf3
commit
c4aaeef6b1
2 changed files with 5 additions and 47 deletions
|
@ -14,25 +14,22 @@ static bool inited = false;
|
||||||
|
|
||||||
off_t MPG123Decoder::file_lseek(void *handle, off_t offset, int whence)
|
off_t MPG123Decoder::file_lseek(void *handle, off_t offset, int whence)
|
||||||
{
|
{
|
||||||
MPG123Decoder *self = reinterpret_cast<MPG123Decoder*>(handle);
|
FileReader *reader = reinterpret_cast<MPG123Decoder*>(handle)->Reader;
|
||||||
FileReader *reader = self->Reader;
|
|
||||||
|
|
||||||
if(whence == SEEK_SET)
|
if(whence == SEEK_CUR)
|
||||||
offset += self->StartOffset;
|
|
||||||
else if(whence == SEEK_CUR)
|
|
||||||
{
|
{
|
||||||
if(offset < 0 && reader->Tell()+offset < self->StartOffset)
|
if(offset < 0 && reader->Tell()+offset < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
else if(whence == SEEK_END)
|
else if(whence == SEEK_END)
|
||||||
{
|
{
|
||||||
if(offset < 0 && reader->GetLength()+offset < self->StartOffset)
|
if(offset < 0 && reader->GetLength()+offset < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(reader->Seek(offset, whence) != 0)
|
if(reader->Seek(offset, whence) != 0)
|
||||||
return -1;
|
return -1;
|
||||||
return reader->Tell() - self->StartOffset;
|
return reader->Tell();
|
||||||
}
|
}
|
||||||
|
|
||||||
ssize_t MPG123Decoder::file_read(void *handle, void *buffer, size_t bytes)
|
ssize_t MPG123Decoder::file_read(void *handle, void *buffer, size_t bytes)
|
||||||
|
@ -71,45 +68,7 @@ bool MPG123Decoder::open(FileReader *reader)
|
||||||
}
|
}
|
||||||
|
|
||||||
Reader = reader;
|
Reader = reader;
|
||||||
StartOffset = 0;
|
|
||||||
|
|
||||||
char data[10];
|
|
||||||
if(file_read(this, data, 10) != 10)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
int start_offset = 0;
|
|
||||||
// Check for ID3 tags and skip them
|
|
||||||
if(memcmp(data, "ID3", 3) == 0 &&
|
|
||||||
(BYTE)data[3] <= 4 && (BYTE)data[4] != 0xff &&
|
|
||||||
(data[5]&0x0f) == 0 && (data[6]&0x80) == 0 &&
|
|
||||||
(data[7]&0x80) == 0 && (data[8]&0x80) == 0 &&
|
|
||||||
(data[9]&0x80) == 0)
|
|
||||||
{
|
|
||||||
// ID3v2
|
|
||||||
start_offset = (data[6]<<21) | (data[7]<<14) |
|
|
||||||
(data[8]<< 7) | (data[9] );
|
|
||||||
start_offset += ((data[5]&0x10) ? 20 : 10);
|
|
||||||
}
|
|
||||||
|
|
||||||
StartOffset = start_offset;
|
|
||||||
if(file_lseek(this, 0, SEEK_SET) != 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// Check for a frame header
|
|
||||||
bool frame_ok = false;
|
|
||||||
if(file_read(this, data, 3) == 3)
|
|
||||||
{
|
|
||||||
if((BYTE)data[0] == 0xff &&
|
|
||||||
((data[1]&0xfe) == 0xfa/*MPEG-1*/ || (data[1]&0xfe) == 0xf2/*MPEG-2*/))
|
|
||||||
{
|
|
||||||
int brate_idx = (data[2]>>4) & 0x0f;
|
|
||||||
int srate_idx = (data[2]>>2) & 0x03;
|
|
||||||
if(brate_idx != 0 && brate_idx != 15 && srate_idx != 3)
|
|
||||||
frame_ok = (file_lseek(this, 0, SEEK_SET) == 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(frame_ok)
|
|
||||||
{
|
{
|
||||||
MPG123 = mpg123_new(NULL, NULL);
|
MPG123 = mpg123_new(NULL, NULL);
|
||||||
if(mpg123_replace_reader_handle(MPG123, file_read, file_lseek, NULL) == MPG123_OK &&
|
if(mpg123_replace_reader_handle(MPG123, file_read, file_lseek, NULL) == MPG123_OK &&
|
||||||
|
|
|
@ -30,7 +30,6 @@ private:
|
||||||
bool Done;
|
bool Done;
|
||||||
|
|
||||||
FileReader *Reader;
|
FileReader *Reader;
|
||||||
int StartOffset;
|
|
||||||
static off_t file_lseek(void *handle, off_t offset, int whence);
|
static off_t file_lseek(void *handle, off_t offset, int whence);
|
||||||
static ssize_t file_read(void *handle, void *buffer, size_t bytes);
|
static ssize_t file_read(void *handle, void *buffer, size_t bytes);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue