diff options
Diffstat (limited to 'src/ui')
| -rw-r--r-- | src/ui/CMakeLists.txt | 3 | ||||
| -rw-r--r-- | src/ui/addurldialog.cpp | 32 | ||||
| -rw-r--r-- | src/ui/mainwindow.cpp | 8 | ||||
| -rw-r--r-- | src/ui/playlistformat.cpp | 292 | ||||
| -rw-r--r-- | src/ui/playlistformat.h | 116 | ||||
| -rw-r--r-- | src/ui/playlistmodel.cpp | 104 | ||||
| -rw-r--r-- | src/ui/playlistmodel.h | 25 | ||||
| -rw-r--r-- | src/ui/ui.pro | 4 |
8 files changed, 51 insertions, 533 deletions
diff --git a/src/ui/CMakeLists.txt b/src/ui/CMakeLists.txt index e7047a5a0..e03881bd9 100644 --- a/src/ui/CMakeLists.txt +++ b/src/ui/CMakeLists.txt @@ -7,7 +7,6 @@ if(COMMAND cmake_policy) cmake_policy(SET CMP0005 OLD) endif(COMMAND cmake_policy) -SET(QT_USE_QTXML TRUE) SET(QT_USE_QTNETWORK TRUE) INCLUDE(UsePkgConfig) @@ -64,7 +63,6 @@ SET(ui_SRCS pixmapwidget.cpp playlistcontrol.cpp playlist.cpp - playlistformat.cpp playlistmodel.cpp playlistslider.cpp playlisttitlebar.cpp @@ -118,7 +116,6 @@ SET(ui_MOC_HDRS number.h pixmapwidget.h playlistcontrol.h - playlistformat.h playlist.h playlistmodel.h playlistslider.h diff --git a/src/ui/addurldialog.cpp b/src/ui/addurldialog.cpp index fd460ba01..3ace76065 100644 --- a/src/ui/addurldialog.cpp +++ b/src/ui/addurldialog.cpp @@ -24,7 +24,8 @@ #include <QUrl> #include <QMessageBox> #include "addurldialog.h" -#include "playlistformat.h" +#include <qmmpui/playlistparser.h> +#include <qmmpui/playlistformat.h> #include "playlistmodel.h" #define HISTORY_SIZE 10 @@ -74,18 +75,15 @@ void AddUrlDialog::accept( ) s.prepend("http://"); m_history.removeAll(s); m_history.prepend(s); - //TODO this code should be removed - foreach(PlaylistFormat* prs, m_model->registeredPlaylistFormats()) + PlaylistFormat* prs = PlaylistParser::instance()->findByPath(s); + if (prs) { - if (prs->hasFormat(QFileInfo(s).suffix().toLower())) - { - //download playlist; - QUrl url(s); - m_http->setHost(url.host(), url.port(80)); - m_http->get(url.path()); //TODO proxy support - addButton->setEnabled(FALSE); - return; - } + //download playlist; + QUrl url(s); + m_http->setHost(url.host(), url.port(80)); + m_http->get(url.path()); //TODO proxy support + addButton->setEnabled(FALSE); + return; } m_model->addFile(s); } @@ -104,13 +102,11 @@ void AddUrlDialog::processResponse(int, bool error) void AddUrlDialog::readResponse(const QHttpResponseHeader&) { QString s = urlComboBox->currentText(); - foreach(PlaylistFormat* prs, m_model->registeredPlaylistFormats()) + PlaylistFormat* prs = PlaylistParser::instance()->findByPath(s); + if (prs) { - if (prs->hasFormat(QFileInfo(s).suffix().toLower())) - { - m_model->addFiles(prs->decode(m_http->readAll())); - break; - } + m_model->addFiles(prs->decode(m_http->readAll())); + return; } QDialog::accept(); } diff --git a/src/ui/mainwindow.cpp b/src/ui/mainwindow.cpp index ff77f6b38..1f18ac97f 100644 --- a/src/ui/mainwindow.cpp +++ b/src/ui/mainwindow.cpp @@ -28,6 +28,8 @@ #include <qmmp/soundcore.h> #include <qmmpui/generalhandler.h> #include <qmmpui/general.h> +#include <qmmpui/playlistparser.h> +#include <qmmpui/playlistformat.h> #include "textscroller.h" #include "mainwindow.h" @@ -39,7 +41,6 @@ #include "dock.h" #include "eqwidget.h" #include "mainvisual.h" -#include "playlistformat.h" #include "jumptotrackdialog.h" #include "aboutdialog.h" #include "addurldialog.h" @@ -76,6 +77,7 @@ MainWindow::MainWindow(const QStringList& args,CommandLineOptionManager* option_ m_playlistName = tr("Default"); + new PlaylistParser(this); m_playlist = new PlayList(this); connect (m_playlist,SIGNAL(next()),SLOT(next())); @@ -692,7 +694,7 @@ void MainWindow::newPlaylist() void MainWindow::loadPlaylist() { QStringList l; - QList<PlaylistFormat*> p_list = m_playListModel->registeredPlaylistFormats(); + QList<PlaylistFormat*> p_list = PlaylistParser::instance()->formats(); if (!p_list.isEmpty()) { foreach(PlaylistFormat* fmt,p_list) @@ -734,7 +736,7 @@ void MainWindow::loadPlaylist() void MainWindow::savePlaylist() { QStringList l; - QList<PlaylistFormat*> p_list = m_playListModel->registeredPlaylistFormats(); + QList<PlaylistFormat*> p_list = PlaylistParser::instance()->formats(); if (!p_list.isEmpty()) { foreach(PlaylistFormat* fmt,p_list) diff --git a/src/ui/playlistformat.cpp b/src/ui/playlistformat.cpp deleted file mode 100644 index 0486d7f78..000000000 --- a/src/ui/playlistformat.cpp +++ /dev/null @@ -1,292 +0,0 @@ -/*************************************************************************** -* Copyright (C) 2006-2008 by Ilya Kotov * -* forkotov02@hotmail.ru * -* * -* This program is free software; you can redistribute it and/or modify * -* it under the terms of the GNU General Public License as published by * -* the Free Software Foundation; either version 2 of the License, or * -* (at your option) any later version. * -* * -* This program is distributed in the hope that it will be useful, * -* but WITHOUT ANY WARRANTY; without even the implied warranty of * -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * -* GNU General Public License for more details. * -* * -* You should have received a copy of the GNU General Public License * -* along with this program; if not, write to the * -* Free Software Foundation, Inc., * -* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * - ***************************************************************************/ - -#include <QFileInfo> - -#ifndef XSPF_PLUGIN -#include <QDomDocument> -#include <QDomElement> -#include <QUrl> -#include "version.h" -#endif - -#include "playlistformat.h" - -#include "playlistitem.h" - -bool PLSPlaylistFormat::hasFormat(const QString & f) -{ - foreach(QString s,m_supported_formats) - if (f == s) - return true; - - return false; -} - -QStringList PLSPlaylistFormat::getExtensions() const -{ - return m_supported_formats; -} - -PLSPlaylistFormat::PLSPlaylistFormat() -{ - m_supported_formats << "pls"; -} - -QString PLSPlaylistFormat::name() const -{ - return "PLSPlaylistFormat"; -} - - -QStringList PLSPlaylistFormat::decode(const QString & contents) -{ - QStringList out; - QStringList splitted = contents.split("\n"); - if (!splitted.isEmpty()) - { - if (splitted.takeAt(0).toLower().contains("[playlist]")) - { - foreach(QString str, splitted) - { - if (str.startsWith("File")) - { - QString unverified = str.remove(0,str.indexOf(QChar('=')) + 1); - unverified = unverified.trimmed(); - if (unverified.startsWith("http://")) - { - out << unverified; - } - else if (QFileInfo(unverified).exists()) - out << QFileInfo(unverified).absoluteFilePath(); - else - qWarning("File %s does not exist", qPrintable(unverified)); - } - } - return out; - } - } - else - qWarning("Error parsing PLS format"); - - return QStringList(); -} - -QString PLSPlaylistFormat::encode(const QList< PlayListItem * > & contents) -{ - QStringList out; - out << QString("[playlist]"); - int counter = 1; - foreach(PlayListItem* f,contents) - { - QString begin = "File" + QString::number(counter) + "="; - out.append(begin + f->path()); - begin = "Title" + QString::number(counter) + "="; - out.append(begin + f->title()); - begin = "Length" + QString::number(counter) + "="; - out.append(begin + QString::number(f->length())); - counter ++; - } - out << "NumberOfEntries=" + QString::number(contents.count()); - return out.join("\n"); -} - - - - -bool M3UPlaylistFormat::hasFormat(const QString & f) -{ - foreach(QString s,m_supported_formats) - if (f == s) - return true; - - return false; -} - -QStringList M3UPlaylistFormat::getExtensions() const -{ - return m_supported_formats; -} - -M3UPlaylistFormat::M3UPlaylistFormat() -{ - m_supported_formats << "m3u"; -} - -QStringList M3UPlaylistFormat::decode(const QString & contents) -{ - QStringList out; - QStringList splitted = contents.split("\n"); - if (!splitted.isEmpty()) - { - foreach(QString str, splitted) - { - str = str.trimmed (); - if (str.startsWith("#EXTM3U") || str.startsWith("#EXTINF:") || str.isEmpty()) - ;//TODO: Let's skip it for now... - else if (str.startsWith("http://")) - out << str; - else if (QFileInfo(str).exists()) - out << QFileInfo(str).absoluteFilePath(); - else - qWarning("File %s does not exist", qPrintable(str)); - } - return out; - } - else - qWarning("Error parsing M3U format"); - - return QStringList(); -} - -QString M3UPlaylistFormat::encode(const QList< PlayListItem * > & contents) -{ - QStringList out; - out << QString("#EXTM3U"); - foreach(PlayListItem* f,contents) - { - QString info = "#EXTINF:" + QString::number(f->length()) + "," + f->title(); - out.append(info); - out.append(f->path()); - } - return out.join("\n"); -} - -QString M3UPlaylistFormat::name() const -{ - return "M3UPlaylistFormat"; -} - - -// Needs more work - it's better use libSpiff there and put it as plugin. - -QStringList XSPFPlaylistFormat::decode(const QString & contents) -{ - QStringList out; - QDomDocument doc; - QString errorMsg; - int errorCol; - int errorRow; - bool ok = doc.setContent(contents, &errorMsg, &errorRow, &errorCol); - - if (!ok) - qDebug("Parse Error: %s\tRow:%d\tCol%d", - qPrintable(errorMsg), errorRow, errorCol ); - - QDomElement rootElement = doc.firstChildElement("playlist"); - if (rootElement.isNull()) - qWarning("Error parsing XSPF: can't find 'playlist' element"); - - QDomElement tracklistElement = rootElement.firstChildElement("trackList"); - if (tracklistElement.isNull()) - qWarning("Error parsing XSPF: can't find 'trackList' element"); - - QDomElement child = tracklistElement.firstChildElement("track"); - - while (!child.isNull()) - { - QString str = QUrl(child.firstChildElement("location").text()).toString(QUrl::RemoveScheme); - out << str; - child = child.nextSiblingElement(); - } - - return out; -} - -// Needs more work - it's better use libSpiff there and put it as plugin. - -QString XSPFPlaylistFormat::encode(const QList< PlayListItem * > & files) -{ - QDomDocument doc; - QDomElement root = doc.createElement("playlist"); - root.setAttribute("version",QString("1")); - root.setAttribute("xmlns",QString("http://xspf.org/ns/0")); - - QDomElement creator = doc.createElement("creator"); - QDomText text = doc.createTextNode("qmmp-" + QString(QMMP_STR_VERSION)); - creator.appendChild(text); - root.appendChild(creator); - - QDomElement tracklist = doc.createElement("trackList"); - - int counter = 1; - foreach(PlayListItem* f,files) - { - QDomElement track = doc.createElement("track"); - - QDomElement ch = doc.createElement("location"); - QDomText text = doc.createTextNode(/*QString("file://") + */QFileInfo(f->path()).absoluteFilePath()); - ch.appendChild(text); - track.appendChild(ch); - - ch = doc.createElement("title"); - text = doc.createTextNode(f->title()); - ch.appendChild(text); - track.appendChild(ch); - - ch = doc.createElement("trackNum"); - text = doc.createTextNode(QString::number(counter)); - ch.appendChild(text); - track.appendChild(ch); - - ch = doc.createElement("year"); - text = doc.createTextNode(QString::number(f->year())); - ch.appendChild(text); - track.appendChild(ch); - - tracklist.appendChild(track); - counter ++; - } - - root.appendChild(tracklist); - doc.appendChild( root ); - QString xml_header("<?xml version='1.0' encoding='UTF-8'?>\n"); - return doc.toString().prepend(xml_header); -} - -XSPFPlaylistFormat::XSPFPlaylistFormat() -{ - m_supported_formats << "xspf"; -} - -bool XSPFPlaylistFormat::hasFormat(const QString & f) -{ - foreach(QString s,m_supported_formats) - if (f == s) - return true; - - return false; -} - -QStringList XSPFPlaylistFormat::getExtensions() const -{ - return m_supported_formats; -} - - -QString XSPFPlaylistFormat::name() const -{ - return "XSPFPlaylistFormat"; -} - - - - - diff --git a/src/ui/playlistformat.h b/src/ui/playlistformat.h deleted file mode 100644 index 4e1de00f1..000000000 --- a/src/ui/playlistformat.h +++ /dev/null @@ -1,116 +0,0 @@ -/*************************************************************************** - * Copyright (C) 2006 by Ilya Kotov * - * forkotov02@hotmail.ru * - * * - * This program is free software; you can redistribute it and/or modify * - * it under the terms of the GNU General Public License as published by * - * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * - * * - * This program is distributed in the hope that it will be useful, * - * but WITHOUT ANY WARRANTY; without even the implied warranty of * - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * - * GNU General Public License for more details. * - * * - * You should have received a copy of the GNU General Public License * - * along with this program; if not, write to the * - * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * - ***************************************************************************/ - -#ifndef _PALYLISTFORMAT_H -#define _PALYLISTFORMAT_H -#include <QStringList> - - -class PlayListItem; -/*! - * Abstract interface for playlist formats. - * - * @author Vladimir Kuznetsov <vovanec@gmail.com> - */ -class PlaylistFormat -{ -public: - virtual ~PlaylistFormat(){;} - /*! - * Takes raw contents of playlist file, should return string list of - * ready file pathes to fill the playlist. - */ - virtual QStringList decode(const QString& contents) = 0; - - /*! - * Takes the list of PlayListItem objects, should return string of - * encoded playlist file - */ - virtual QString encode(const QList<PlayListItem*>& contents) = 0; - - /*! - * Returns list of file extensions that current format supports - */ - virtual QStringList getExtensions()const = 0; - - /*! - * Verifies is the \b ext file extension supported by current playlist format. - */ - virtual bool hasFormat(const QString& ext) = 0; - - /// Unique name of playlist format. - virtual QString name()const = 0; -}; - -Q_DECLARE_INTERFACE(PlaylistFormat,"PlaylistFormatInterface/1.0"); - -/*! - * Class for PLS playlist format parsing - */ -class PLSPlaylistFormat : public PlaylistFormat -{ -public: - PLSPlaylistFormat(); - virtual QStringList getExtensions()const; - virtual bool hasFormat(const QString&); - virtual QStringList decode(const QString& contents); - virtual QString encode(const QList<PlayListItem*>& contents); - virtual QString name()const; -protected: - QStringList m_supported_formats; - -}; - - - -/*! - * Class for M3U playlist format parsing - */ -class M3UPlaylistFormat : public PlaylistFormat -{ - public: - M3UPlaylistFormat(); - virtual QStringList getExtensions()const; - virtual bool hasFormat(const QString&); - virtual QStringList decode(const QString& contents); - virtual QString encode(const QList<PlayListItem*>& contents); - virtual QString name()const; -protected: - QStringList m_supported_formats; -}; - - -/*! - * Class for XSPF playlist format parsing - */ -class XSPFPlaylistFormat : public PlaylistFormat -{ - public: - XSPFPlaylistFormat(); - virtual QStringList getExtensions()const; - virtual bool hasFormat(const QString&); - virtual QStringList decode(const QString& contents); - virtual QString encode(const QList<PlayListItem*>& contents); - virtual QString name()const; - protected: - QStringList m_supported_formats; -}; - -#endif diff --git a/src/ui/playlistmodel.cpp b/src/ui/playlistmodel.cpp index 22371d283..f26f843d1 100644 --- a/src/ui/playlistmodel.cpp +++ b/src/ui/playlistmodel.cpp @@ -32,11 +32,12 @@ #include <qmmp/decoder.h> #include <qmmp/decoderfactory.h> +#include <qmmpui/playlistparser.h> +#include <qmmpui/playlistformat.h> #include "fileloader.h" #include "playlistmodel.h" #include "playlistitem.h" -#include "playlistformat.h" #include "playstate.h" #include <QMetaType> @@ -52,7 +53,7 @@ TagUpdater::TagUpdater(QObject* o,PlayListItem* item):m_observable(o),m_item(ite void TagUpdater::updateTag() { - if(m_item->flag() == PlayListItem::SCHEDULED_FOR_DELETION) + if (m_item->flag() == PlayListItem::SCHEDULED_FOR_DELETION) { delete m_item; m_item = NULL; @@ -75,13 +76,6 @@ PlayListModel::PlayListModel ( QObject *parent ) is_repeatable_list = false; m_play_state = new NormalPlayState(this); //readSettings(); - - registerPlaylistFormat( new PLSPlaylistFormat); - registerPlaylistFormat( new M3UPlaylistFormat); -#ifndef XSPF_PLUGIN - registerPlaylistFormat( new XSPFPlaylistFormat); -#endif - loadExternalPlaylistFormats(); } PlayListModel::~PlayListModel() @@ -89,7 +83,7 @@ PlayListModel::~PlayListModel() writeSettings(); clear(); delete m_play_state; - qDeleteAll(m_registered_pl_formats); + //qDeleteAll(m_registered_pl_formats); foreach(GuardedFileLoader l,m_running_loaders) { @@ -180,11 +174,11 @@ void PlayListModel::clear() { PlayListItem* mf = m_items.takeFirst(); - if(mf->flag() == PlayListItem::FREE) + if (mf->flag() == PlayListItem::FREE) { delete mf; } - else if(mf->flag() == PlayListItem::EDITING) + else if (mf->flag() == PlayListItem::EDITING) { mf->setFlag(PlayListItem::SCHEDULED_FOR_DELETION); } @@ -259,12 +253,12 @@ void PlayListModel::removeSelection(bool inverted) if (m_total_length < 0) m_total_length = 0; - if(f->flag() == PlayListItem::FREE) + if (f->flag() == PlayListItem::FREE) { delete f; f = NULL; } - else if(f->flag() == PlayListItem::EDITING) + else if (f->flag() == PlayListItem::EDITING) f->setFlag(PlayListItem::SCHEDULED_FOR_DELETION); select_after_delete = i; @@ -313,7 +307,7 @@ void PlayListModel::showDetails() if ( fact ) { QObject* o = fact->showDetails ( 0, m_items.at ( i )->path() ); - if(o) + if (o) { TagUpdater *updater = new TagUpdater(o,m_items.at(i)); m_editing_items.append(m_items.at(i)); @@ -347,7 +341,7 @@ void PlayListModel::readSettings() file.close (); - if(m_current > files.count() - 1) + if (m_current > files.count() - 1) m_current = 0; int preload = (files.count() < 100) ? files.count() : 100; @@ -814,76 +808,40 @@ void PlayListModel::setUpdatesEnabled(bool yes) void PlayListModel::loadPlaylist(const QString & f_name) { - - foreach(PlaylistFormat* prs,m_registered_pl_formats.values()) + PlaylistFormat* prs = PlaylistParser::instance()->findByPath(f_name); + if (prs) { - if (prs->hasFormat(QFileInfo(f_name).suffix().toLower())) + QFile file(f_name); + if (file.open(QIODevice::ReadOnly)) { - QFile file(f_name); - if (file.open(QIODevice::ReadOnly)) - { - clear(); - addFiles(prs->decode(QTextStream(&file).readAll())); - file.close(); - } - else - qWarning("Error opening %s",f_name.toLocal8Bit().data()); + clear(); + addFiles(prs->decode(QTextStream(&file).readAll())); + file.close(); } + else + qWarning("Error opening %s",f_name.toLocal8Bit().data()); } } void PlayListModel::savePlaylist(const QString & f_name) { - foreach(PlaylistFormat* prs,m_registered_pl_formats.values()) + PlaylistFormat* prs = PlaylistParser::instance()->findByPath(f_name); + if (prs) { - if (prs->hasFormat(QFileInfo(f_name).suffix().toLower())) + QFile file(f_name); + if (file.open(QIODevice::WriteOnly)) { - QFile file(f_name); - if (file.open(QIODevice::WriteOnly)) - { - QTextStream ts(&file); - ts << prs->encode(m_items); - file.close(); - } - else - qWarning("Error opening %s",f_name.toLocal8Bit().data()); + QTextStream ts(&file); + QList <SongInfo *> songs; + foreach(PlayListItem* item, m_items) + songs << item; + ts << prs->encode(songs); + file.close(); } + else + qWarning("Error opening %s",f_name.toLocal8Bit().data()); } -} - - -void PlayListModel::loadExternalPlaylistFormats() -{ - QDir pluginsDir (QDir::homePath()+"/.qmmp/plugins/PlaylistFormats"); - //pluginsDir.cdUp(); - //pluginsDir.cd("plugins/PlaylistFormats"); - foreach (QString fileName, pluginsDir.entryList(QDir::Files)) - { - QPluginLoader loader(pluginsDir.absoluteFilePath(fileName)); - QObject *plugin = loader.instance(); - if (loader.isLoaded()) - qDebug("PlaylistFormat: plugin loaded - %s", qPrintable(fileName)); - - PlaylistFormat *fmt = 0; - if (plugin) - fmt = qobject_cast<PlaylistFormat *>(plugin); - - if (fmt) - if (!registerPlaylistFormat(fmt)) - qDebug("Warning: Plugin with name %s is already registered...", - qPrintable(fmt->name())); - } -} -bool PlayListModel::registerPlaylistFormat(PlaylistFormat* p) -{ - QString name = p->name(); - if (!m_registered_pl_formats.contains(name)) - { - m_registered_pl_formats.insert(name,p); - return true; - } - return false; } bool PlayListModel::isFileLoaderRunning() const diff --git a/src/ui/playlistmodel.h b/src/ui/playlistmodel.h index c8d826021..a5231b44f 100644 --- a/src/ui/playlistmodel.h +++ b/src/ui/playlistmodel.h @@ -177,29 +177,6 @@ public: } /*! - * Registers playlist format parser. - */ - bool registerPlaylistFormat(PlaylistFormat* p); - - /*! - * Checks and loads external playlist format plugins - */ - void loadExternalPlaylistFormats(); - - /*! - * Returns vector of reistered format parsers. - */ - const QList<PlaylistFormat*> registeredPlaylistFormats()const - { - return m_registered_pl_formats.values(); - } - - const QStringList registeredPlaylistFormatNames()const - { - return m_registered_pl_formats.keys(); - } - - /*! * Loads playlist with \b f_name name. */ void loadPlaylist(const QString& f_name); @@ -349,8 +326,6 @@ private: */ QList<PlayListItem*>m_queued_songs; - QMap<QString,PlaylistFormat* > m_registered_pl_formats; - /*! * Is playlist repeatable? */ diff --git a/src/ui/ui.pro b/src/ui/ui.pro index 51d23ede9..f01deb926 100644 --- a/src/ui/ui.pro +++ b/src/ui/ui.pro @@ -44,7 +44,6 @@ HEADERS += mainwindow.h \ balancebar.h \ playstate.h \ symboldisplay.h \ - playlistformat.h \ playlistcontrol.h \ version.h \ qmmpstarter.h \ @@ -98,7 +97,6 @@ SOURCES += mainwindow.cpp \ balancebar.cpp \ playstate.cpp \ symboldisplay.cpp \ - playlistformat.cpp \ playlistcontrol.cpp \ qmmpstarter.cpp \ eqpreset.cpp \ @@ -124,7 +122,7 @@ MOC_DIR =./.build/moc/ OBJECTS_DIR =./.build/obj -QT += network xml +QT += network TARGET = ../../bin/qmmp CONFIG += thread release \ warn_on |
