aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/plugins/Input/mpeg/decoder_mpg123.cpp17
-rw-r--r--src/plugins/Input/mpeg/decoder_mpg123.h2
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;
};