diff options
| author | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2010-10-19 17:53:51 +0000 |
|---|---|---|
| committer | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2010-10-19 17:53:51 +0000 |
| commit | 07b5999701908598ef1ce868c060723a3a2b2d44 (patch) | |
| tree | 88d4a87fe7293f47d87d69ddbd931f90bf8b4396 /src/plugins/Input/vorbis/vorbismetadatamodel.cpp | |
| parent | 168cb1c5a8f708218ed869032c65dfbbcde48404 (diff) | |
| download | qmmp-07b5999701908598ef1ce868c060723a3a2b2d44.tar.gz qmmp-07b5999701908598ef1ce868c060723a3a2b2d44.tar.bz2 qmmp-07b5999701908598ef1ce868c060723a3a2b2d44.zip | |
fixed memory leak, added taglib bug workaround
git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@1948 90c681e8-e032-0410-971d-27865f9a5e38
Diffstat (limited to 'src/plugins/Input/vorbis/vorbismetadatamodel.cpp')
| -rw-r--r-- | src/plugins/Input/vorbis/vorbismetadatamodel.cpp | 27 |
1 files changed, 18 insertions, 9 deletions
diff --git a/src/plugins/Input/vorbis/vorbismetadatamodel.cpp b/src/plugins/Input/vorbis/vorbismetadatamodel.cpp index a7751b30d..321906f42 100644 --- a/src/plugins/Input/vorbis/vorbismetadatamodel.cpp +++ b/src/plugins/Input/vorbis/vorbismetadatamodel.cpp @@ -44,13 +44,16 @@ QHash<QString, QString> VorbisMetaDataModel::audioProperties() { QHash<QString, QString> ap; TagLib::Ogg::Vorbis::File f (m_path.toLocal8Bit()); - QString text = QString("%1").arg(f.audioProperties()->length()/60); - text +=":"+QString("%1").arg(f.audioProperties()->length()%60,2,10,QChar('0')); - ap.insert(tr("Length"), text); - ap.insert(tr("Sample rate"), QString("%1 " + tr("Hz")).arg(f.audioProperties()->sampleRate())); - ap.insert(tr("Channels"), QString("%1").arg(f.audioProperties()->channels())); - ap.insert(tr("Bitrate"), QString("%1 " + tr("kbps")).arg(f.audioProperties()->bitrate())); - ap.insert(tr("File size"), QString("%1 "+tr("KB")).arg(f.length()/1024)); + if(f.audioProperties()) + { + QString text = QString("%1").arg(f.audioProperties()->length()/60); + text +=":"+QString("%1").arg(f.audioProperties()->length()%60,2,10,QChar('0')); + ap.insert(tr("Length"), text); + ap.insert(tr("Sample rate"), QString("%1 " + tr("Hz")).arg(f.audioProperties()->sampleRate())); + ap.insert(tr("Channels"), QString("%1").arg(f.audioProperties()->channels())); + ap.insert(tr("Bitrate"), QString("%1 " + tr("kbps")).arg(f.audioProperties()->bitrate())); + ap.insert(tr("File size"), QString("%1 "+tr("KB")).arg(f.length()/1024)); + } return ap; } @@ -108,7 +111,7 @@ ulong VorbisMetaDataModel::readPictureBlockField(QByteArray data, int offset) VorbisCommentModel::VorbisCommentModel(const QString &path) : TagModel(TagModel::Save) { - m_file = new TagLib::Ogg::Vorbis::File (path.toLocal8Bit().constData()); + m_file = new TagLib::Ogg::Vorbis::File (path.toLocal8Bit().constData()); m_tag = m_file->tag(); } @@ -200,5 +203,11 @@ void VorbisCommentModel::setValue(Qmmp::MetaData key, const QString &value) void VorbisCommentModel::save() { - m_file->save(); + if(m_tag) + m_file->save(); + //taglib bug workarround + QString path = QString::fromLocal8Bit(m_file->name()); + delete m_file; + m_file = new TagLib::Ogg::Vorbis::File(path.toLocal8Bit()); + m_tag = m_file->tag(); } |
