/***************************************************************************
* Copyright (C) 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 <QSettings>
#include <QDir>
#include <qmmp/decoder.h>
#include "playlistitem.h"
PlayListItem::PlayListItem() : SongInfo(), m_flag(FREE)
{
m_info = 0;
}
//PlayListItem::PlayListItem(const QString& path) : SongInfo(), m_flag(FREE)
PlayListItem::PlayListItem(FileInfo *info, QSettings *settings) : SongInfo(), m_flag(FREE)
{
m_selected = FALSE;
m_current = FALSE;
m_info = info;
setValue(SongInfo::PATH, info->path()); //TODO path?
setValue(SongInfo::STREAM, path().startsWith("http://")); //TODO do this inside SongInfo
//use external settings or create new
QSettings *s = settings;
if (!s)
s = new QSettings (QDir::homePath() +"/.qmmp/qmmprc", QSettings::IniFormat);
m_use_meta = s->value ("PlayList/load_metadata", TRUE).toBool(); //TODO move to libqmmp
//format
m_format = s->value("PlayList/title_format", "%p - %t").toString();
//other properties
m_convertUnderscore = s->value ("PlayList/convert_underscore", TRUE).toBool();
m_convertTwenty = s->value ("PlayList/convert_twenty", TRUE).toBool();
m_fullStreamPath = s->value ("PlayList/full_stream_path", FALSE).toBool();
if (!settings) //delete created settings only
delete s;
if (m_use_meta && !path().startsWith("http://"))
{
//m_info = Decoder::createFileInfo(path);
readMetadata();
}
else if (path().startsWith("http://") && m_fullStreamPath)
m_title = path();
else
m_title = path().split('/',QString::SkipEmptyParts).takeLast ();
}
PlayListItem::~PlayListItem()
{
if (m_info)
delete m_info;
}
void PlayListItem::setSelected(bool yes)
{
m_selected = yes;
}
bool PlayListItem::isSelected() const
{
return m_selected;
}
void PlayListItem::setCurrent(bool yes)
{
m_current = yes;
}
bool PlayListItem::isCurrent() const
{
return m_current;
}
void PlayListItem::setFlag(FLAGS f)
{
m_flag = f;
}
PlayListItem::FLAGS PlayListItem::flag() const
{
return m_flag;
}
void PlayListItem::updateMetaData(const QMap <Qmmp::MetaData, QString> &metaData)
{
if (!m_info)
m_info = new FileInfo();
m_info->setMetaData(metaData);
m_use_meta = TRUE;
readMetadata();
}
void PlayListItem::updateTags()
{
if (path().startsWith("http://"))
return;
if (m_info)
{
delete m_info;
m_info = 0;
}
//m_info = Decoder::createFileInfo(path());
m_info = Decoder::createPlayList(path()).at(0);
readMetadata();
}
const QString PlayListItem::text() const
{
return m_title;
}
void PlayListItem::setText(const QString &title)
{
m_title = title;
}
void PlayListItem::readMetadata()
{
//clear();
m_title.clear();
if (m_info) //read length first //TODO fix this
setValue(SongInfo::LENGTH, uint(m_info->length()));
if (m_use_meta && m_info && !m_info->isEmpty())
{
//fill SongInfo //TODO optimize
setValue(SongInfo::TITLE, m_info->metaData(Qmmp::TITLE));
setValue(SongInfo::ARTIST, m_info->metaData(Qmmp::ARTIST));
setValue(SongInfo::ALBUM, m_info->metaData(Qmmp::ALBUM));
setValue(SongInfo::COMMENT, m_info->metaData(Qmmp::COMMENT));
setValue(SongInfo::GENRE, m_info->metaData(Qmmp::GENRE));
setValue(SongInfo::YEAR, m_info->metaData(Qmmp::YEAR).toUInt());
setValue(SongInfo::TRACK, m_info->metaData(Qmmp::TRACK).toUInt());
//generate playlist string
m_title = m_format;
m_title = printTag(m_title, "%p", artist());
m_title = printTag(m_title, "%a", album());
m_title = printTag(m_title, "%t", title());
m_title = printTag(m_title, "%n", QString("%1").arg(track()));
m_title = printTag(m_title, "%g", genre());
m_title = printTag(m_title, "%f", path().section('/',-1));
m_title = printTag(m_title, "%F", path());
m_title = printTag(m_title, "%y", QString("%1").arg(year ()));
}
if (m_title.isEmpty())
{
if (path().startsWith("http://") && m_fullStreamPath)
m_title = path();
else
m_title = path().split('/',QString::SkipEmptyParts).takeLast ();
}
if (m_info)
delete m_info;
m_info = 0;
if (m_convertUnderscore)
m_title.replace("_", " ");
if (m_convertTwenty)
m_title.replace("%20", " ");
}
QString PlayListItem::printTag(QString str, QString regExp, QString tagStr)
{
if (!tagStr.isEmpty())
str.replace(regExp, tagStr);
else
{
//remove unused separators
int regExpPos = str.indexOf(regExp);
if (regExpPos < 0)
return str;
int nextPos = str.indexOf("%", regExpPos + 1);
if (nextPos < 0)
{
//last separator
regExpPos = m_format.lastIndexOf(regExp);
nextPos = m_format.lastIndexOf("%", regExpPos - 1);
QString lastSep = m_format.right (m_format.size() - nextPos - 2);
str.remove(lastSep);
str.remove(regExp);
}
else
str.remove ( regExpPos, nextPos - regExpPos);
}
return str;
}