1
/* === This file is part of Tomahawk Player - <http://tomahawk-player.org> ===
3
* Copyright 2010-2011, Leo Franchi <lfranchi@kde.org>
5
* Tomahawk is free software: you can redistribute it and/or modify
6
* it under the terms of the GNU General Public License as published by
7
* the Free Software Foundation, either version 3 of the License, or
8
* (at your option) any later version.
10
* Tomahawk is distributed in the hope that it will be useful,
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
* GNU General Public License for more details.
15
* You should have received a copy of the GNU General Public License
16
* along with Tomahawk. If not, see <http://www.gnu.org/licenses/>.
19
#include "DatabaseGenerator.h"
21
#include "DatabaseControl.h"
22
#include "utils/Logger.h"
24
#include "database/DatabaseCommand_GenericSelect.h"
25
#include "database/Database.h"
27
using namespace Tomahawk;
31
DatabaseFactory::create()
33
return new DatabaseGenerator();
38
DatabaseFactory::createControl ( const QString& controlType )
40
return dyncontrol_ptr( new DatabaseControl( controlType, typeSelectors() ) );
45
DatabaseFactory::createControl ( const QString& sql, DatabaseCommand_GenericSelect::QueryType type, const QString& summary )
47
dyncontrol_ptr control = dyncontrol_ptr( new DatabaseControl( sql, summary, typeSelectors() ) );
48
control->setMatch( QString::number( type ) );
54
DatabaseFactory::typeSelectors() const
56
return QStringList() << "SQL" << "Artist" << "Album" << "Title";
60
DatabaseGenerator::DatabaseGenerator ( QObject* parent )
61
: GeneratorInterface ( parent )
66
// m_logo.load( RESPATH "images )
70
DatabaseGenerator::~DatabaseGenerator()
76
DatabaseGenerator::logo()
83
DatabaseGenerator::dynamicFetched()
89
DatabaseGenerator::dynamicStarted()
95
DatabaseGenerator::generate( int number )
97
tLog() << "Generating" << number << "tracks for this database dynamic playlist with" << m_controls.size() << "controls:";
98
if ( m_controls.isEmpty() )
100
qWarning() << "No controls, can't generate...!";
101
emit error( "Failed to generate tracks", "No controls!" );
105
foreach ( const dyncontrol_ptr& ctrl, m_controls )
106
qDebug() << ctrl->selectedType() << ctrl->match() << ctrl->input();
108
// TODO for now, we just support the special "SQL" control, not meant to be shown to the user. Just does a raw query.
110
bool hasOther = false;
111
foreach ( const dyncontrol_ptr& ctrl, m_controls )
113
if ( ctrl->selectedType() == "SQL" )
118
if ( hasSql == hasOther )
120
qWarning() << "Cannot mix sql and non-sql controls!";
121
emit error( "Failed to generate tracks", "Cannot mix sql and non-sql controls" );
125
// TODO for now we just support 1 sql query if we're a sql type
128
dyncontrol_ptr control = m_controls.first();
130
tDebug() << "Generated sql query:" << control.dynamicCast< DatabaseControl >()->sql();
131
DatabaseCommand_GenericSelect* cmd = new DatabaseCommand_GenericSelect( control.dynamicCast< DatabaseControl >()->sql(),
132
static_cast< DatabaseCommand_GenericSelect::QueryType >( control->match().toInt() ),
136
connect( cmd, SIGNAL( tracks( QList<Tomahawk::query_ptr> ) ), this, SLOT( tracksGenerated( QList<Tomahawk::query_ptr> ) ) );
137
Database::instance()->enqueue( QSharedPointer< DatabaseCommand >( cmd ) );
146
DatabaseGenerator::tracksGenerated ( const QList< query_ptr >& tracks )
148
emit generated( tracks );
153
DatabaseGenerator::createControl( const QString& type )
155
m_controls << dyncontrol_ptr( new DatabaseControl( type, GeneratorFactory::typeSelectors( m_type ) ) );
156
return m_controls.last();
161
DatabaseGenerator::createControl ( const QString& sql, DatabaseCommand_GenericSelect::QueryType type, const QString& summary )
163
m_controls << dyncontrol_ptr( new DatabaseControl( sql, summary, GeneratorFactory::typeSelectors( m_type ) ) );
164
m_controls.last()->setMatch( QString::number( type ) );
165
return m_controls.last();
170
DatabaseGenerator::fetchNext( int /* rating */ )
176
DatabaseGenerator::sentenceSummary()
178
if( m_controls.count() && m_controls.first()->type() == "SQL" )
179
return m_controls.first()->summary();
187
DatabaseGenerator::startOnDemand()