From b2576ddc181d3758e3a57d9cac871ee7d7e2ef06 Mon Sep 17 00:00:00 2001 From: trialuser02 Date: Wed, 14 Jun 2017 20:24:58 +0000 Subject: improved playlist formats support git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@7237 90c681e8-e032-0410-971d-27865f9a5e38 --- src/qmmpui/playlistparser.cpp | 73 +++++++++++++++++++++++++++++-------------- 1 file changed, 49 insertions(+), 24 deletions(-) (limited to 'src/qmmpui/playlistparser.cpp') diff --git a/src/qmmpui/playlistparser.cpp b/src/qmmpui/playlistparser.cpp index 70c3c3fe9..736a400cc 100644 --- a/src/qmmpui/playlistparser.cpp +++ b/src/qmmpui/playlistparser.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2008-2014 by Ilya Kotov * + * Copyright (C) 2008-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -23,7 +23,6 @@ #include #include #include -#include #include #include "playlistformat.h" #include "playlistparser.h" @@ -32,13 +31,13 @@ QList *PlayListParser::m_formats = 0; QList PlayListParser::formats() { - checkFormats(); + loadFormats(); return *m_formats; } QStringList PlayListParser::nameFilters() { - checkFormats(); + loadFormats(); QStringList filters; foreach(PlayListFormat* format, *m_formats) { @@ -47,9 +46,20 @@ QStringList PlayListParser::nameFilters() return filters; } +bool PlayListParser::isPlayList(const QString &url) +{ + foreach (QString filter, nameFilters()) + { + QRegExp r(filter, Qt::CaseInsensitive, QRegExp::Wildcard); + if(r.exactMatch(url)) + return true; + } + return false; +} + PlayListFormat *PlayListParser::findByMime(const QString &mime) { - checkFormats(); + loadFormats(); foreach(PlayListFormat* format, *m_formats) { if(format->properties().contentTypes.contains(mime)) @@ -60,7 +70,7 @@ PlayListFormat *PlayListParser::findByMime(const QString &mime) PlayListFormat *PlayListParser::findByPath(const QString &filePath) { - checkFormats(); + loadFormats(); foreach(PlayListFormat* format, *m_formats) { foreach(QString filter, format->properties().filters) @@ -89,50 +99,65 @@ void PlayListParser::savePlayList(QList tracks, const QString & QFile file(f_name); if (file.open(QIODevice::WriteOnly)) { - QTextStream ts(&file); - ts << prs->encode(tracks, QFileInfo(f_name).canonicalFilePath()); + file.write(prs->encode(tracks, QFileInfo(f_name).canonicalFilePath())); file.close(); } else qWarning("PlayListParser: unable to save playlist, error: %s", qPrintable(file.errorString())); } -QStringList PlayListParser::loadPlaylist(const QString &f_name) +QList PlayListParser::loadPlaylist(const QString &f_name) { - QStringList list; if(!QFile::exists(f_name)) - return list; + return QList(); PlayListFormat* prs = PlayListParser::findByPath(f_name); if(!prs) - return list; + return QList(); QFile file(f_name); if (!file.open(QIODevice::ReadOnly)) { qWarning("PlayListParser: unable to open playlist, error: %s", qPrintable(file.errorString())); - return list; + return QList(); } - list = prs->decode(QTextStream(&file).readAll()); - if(list.isEmpty()) + QList tracks = prs->decode(file.readAll()); + + if(tracks.isEmpty()) + { qWarning("PlayListParser: error opening %s",qPrintable(f_name)); + return tracks; + } - for (int i = 0; i < list.size(); ++i) + QString url; + foreach (PlayListTrack *t, tracks) { - if(list.at(i).contains("://")) + url = t->value(Qmmp::URL); + + if(url.contains("://")) continue; - if (QFileInfo(list.at(i)).isRelative()) - list[i].prepend(QFileInfo(f_name).canonicalPath () + "/"); + if(QFileInfo(url).isRelative()) + url.prepend(QFileInfo(f_name).canonicalPath () + "/"); - list[i].replace("\\","/"); - list[i].replace("//","/"); + url.replace("\\","/"); + url.replace("//","/"); + t->insert(Qmmp::URL, url); + } + return tracks; +} + +QList PlayListParser::loadPlaylist(const QString &fmt, const QByteArray &contents) +{ + foreach (PlayListFormat *p, *m_formats) + { + if(p->properties().shortName == fmt) + return p->decode(contents); } - file.close(); - return list; + return QList(); } -void PlayListParser::checkFormats() +void PlayListParser::loadFormats() { if (m_formats) return; -- cgit v1.2.3-13-gbd6f