From 477788d7dd83ecac5485f3d7c927229a9885ec27 Mon Sep 17 00:00:00 2001 From: trialuser02 Date: Sat, 17 Sep 2016 18:57:40 +0000 Subject: archive plugin: added metadata model git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@6731 90c681e8-e032-0410-971d-27865f9a5e38 --- .../Input/archive/decoderarchivefactory.cpp | 29 +++++++++++++++++++--- 1 file changed, 25 insertions(+), 4 deletions(-) (limited to 'src/plugins/Input/archive/decoderarchivefactory.cpp') diff --git a/src/plugins/Input/archive/decoderarchivefactory.cpp b/src/plugins/Input/archive/decoderarchivefactory.cpp index b7fa24f85..126d5734b 100644 --- a/src/plugins/Input/archive/decoderarchivefactory.cpp +++ b/src/plugins/Input/archive/decoderarchivefactory.cpp @@ -17,6 +17,7 @@ * Free Software Foundation, Inc., * * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ + #include #include #include @@ -26,9 +27,10 @@ #include "decoder_archive.h" #include "archivetagreader.h" #include "archiveinputdevice.h" +#include "archivemetadatamodel.h" #include "decoderarchivefactory.h" -// DecoderArchiveFileFactory +// DecoderArchiveFactory bool DecoderArchiveFactory::canDecode(QIODevice *) const { return false; @@ -54,7 +56,7 @@ Decoder *DecoderArchiveFactory::create(const QString &url, QIODevice *) return new DecoderArchive(url); } -QList DecoderArchiveFactory::createPlayList(const QString &archivePath, bool useMetaData, QStringList *) +QList DecoderArchiveFactory::createPlayList(const QString &path, bool useMetaData, QStringList *) { QList list; struct archive_entry *entry = 0; @@ -63,6 +65,19 @@ QList DecoderArchiveFactory::createPlayList(const QString &archivePa archive_read_support_filter_all(a); archive_read_support_format_all(a); + QString archivePath, requiredFilePath; + if(path.contains("://")) + { + requiredFilePath = path.section("#", -1); + archivePath = path; + archivePath.remove(QRegExp("^.+://")); + archivePath.remove(QRegExp("#.+$")); + } + else + { + archivePath = path; + } + if(archive_read_open_filename(a, archivePath.toLocal8Bit().constData(), 10240) != ARCHIVE_OK) { qWarning("DecoderArchiveFactory: unable to open archive; libarchive error: %s", archive_error_string(a)); @@ -76,6 +91,12 @@ QList DecoderArchiveFactory::createPlayList(const QString &archivePa if(!filePath.startsWith("/")) filePath.prepend("/"); + if(!requiredFilePath.isEmpty() && filePath != requiredFilePath) + { + archive_read_data_skip(a); + continue; + } + //is this file supported by qmmp? QList filtered = Decoder::findByFileExtension(filePath); foreach (DecoderFactory *f, filtered) @@ -107,9 +128,9 @@ QList DecoderArchiveFactory::createPlayList(const QString &archivePa return list; } -MetaDataModel* DecoderArchiveFactory::createMetaDataModel(const QString&, QObject *) +MetaDataModel* DecoderArchiveFactory::createMetaDataModel(const QString &path, QObject *parent) { - return 0; + return new ArchiveMetaDataModel(path, parent); } void DecoderArchiveFactory::showSettings(QWidget *) -- cgit v1.2.3-13-gbd6f