diff options
| -rw-r--r-- | src/plugins/Input/mpeg/decoder_mpg123.cpp | 17 | ||||
| -rw-r--r-- | src/plugins/Input/mpeg/decoder_mpg123.h | 2 |
2 files changed, 11 insertions, 8 deletions
diff --git a/src/plugins/Input/mpeg/decoder_mpg123.cpp b/src/plugins/Input/mpeg/decoder_mpg123.cpp index f69d05bca..16d442fd0 100644 --- a/src/plugins/Input/mpeg/decoder_mpg123.cpp +++ b/src/plugins/Input/mpeg/decoder_mpg123.cpp @@ -67,7 +67,7 @@ DecoderMPG123::DecoderMPG123(QIODevice *i) : Decoder(i) m_frame_info.bitrate = 0; m_mpg123_encoding = MPG123_ENC_SIGNED_16; m_handle = 0; - m_resync_errors = 0; + m_errors = 0; } DecoderMPG123::~DecoderMPG123() @@ -78,7 +78,7 @@ DecoderMPG123::~DecoderMPG123() bool DecoderMPG123::initialize() { - m_resync_errors = 0; + m_errors = 0; if (input()->isSequential ()) //for streams only { TagExtractor extractor(input()); @@ -166,14 +166,17 @@ qint64 DecoderMPG123::read(unsigned char *data, qint64 size) if(err < 0) { err = mpg123_errcode(m_handle); - if(err == MPG123_RESYNC_FAIL && m_resync_errors < 10) + if(!m_errors) + qWarning("DecoderMPG123: decoder error: %s", mpg123_plain_strerror(err)); + + if(m_errors < 10) { qWarning("DecoderMPG123: skipping resync error..."); - m_resync_errors++; + m_errors++; + if(err == MPG123_RESYNC_FAIL && done > 0) + memset(data, 0, done); return done; } - - qWarning("DecoderMPG123: decoder error: %s", mpg123_plain_strerror(err)); return -1; } else if(err != MPG123_DONE && err != MPG123_OK) @@ -181,7 +184,7 @@ qint64 DecoderMPG123::read(unsigned char *data, qint64 size) qWarning("DecoderMPG123: decoder error: %s", mpg123_plain_strerror(err)); return -1; } - m_resync_errors = 0; + m_errors = 0; mpg123_info(m_handle, &m_frame_info); return done; } diff --git a/src/plugins/Input/mpeg/decoder_mpg123.h b/src/plugins/Input/mpeg/decoder_mpg123.h index b16d7682a..8b19007e0 100644 --- a/src/plugins/Input/mpeg/decoder_mpg123.h +++ b/src/plugins/Input/mpeg/decoder_mpg123.h @@ -49,7 +49,7 @@ private: qint64 m_totalTime; long m_rate; int m_mpg123_encoding; - int m_resync_errors; + int m_errors; }; |
