/* Copyright 2011 Aaron Seigo This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library 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 Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include "runnermodel.h" #include #include #include #include #include RunnerModel::RunnerModel(QObject *parent) : QAbstractListModel(parent), m_manager(0), m_startQueryTimer(new QTimer(this)), m_runningChangedTimeout(new QTimer(this)), m_running(false) { QHash roles; roles.insert(Qt::DisplayRole, "label"); roles.insert(Qt::DecorationRole, "icon"); roles.insert(Type, "type"); roles.insert(Relevance, "relevance"); roles.insert(Data, "data"); roles.insert(Id, "id"); roles.insert(SubText, "description"); roles.insert(Enabled, "enabled"); roles.insert(RunnerId, "runnerid"); roles.insert(RunnerName, "runnerName"); roles.insert(Actions, "actions"); setRoleNames(roles); m_startQueryTimer->setSingleShot(true); m_startQueryTimer->setInterval(10); connect(m_startQueryTimer, SIGNAL(timeout()), this, SLOT(startQuery())); //FIXME: HACK: some runners stay in a running but finished state, not possible to say if it's actually over m_runningChangedTimeout->setSingleShot(true); connect(m_runningChangedTimeout, SIGNAL(timeout()), this, SLOT(queryHasFinished())); } int RunnerModel::rowCount(const QModelIndex& index) const { return index.isValid() ? 0 : m_matches.count(); } int RunnerModel::count() const { return m_matches.count(); } QStringList RunnerModel::runners() const { return m_manager ? m_manager->allowedRunners() : QStringList(); } void RunnerModel::setRunners(const QStringList &allowedRunners) { if (m_manager) { m_manager->setAllowedRunners(allowedRunners); //automagically enter single runner mode if there's only 1 allowed runner m_manager->setSingleMode(allowedRunners.count() == 1); emit runnersChanged(); } else { m_pendingRunnersList = allowedRunners; } } void RunnerModel::run(int index) { if (index >= 0 && index < m_matches.count()) { m_manager->run(m_matches.at(index)); } } bool RunnerModel::isRunning() const { return m_running; } QVariant RunnerModel::data(const QModelIndex &index, int role) const { if (!index.isValid() || index.parent().isValid() || index.column() > 0 || index.row() < 0 || index.row() >= m_matches.count()) { // index requested must be valid, but we have no child items! //kDebug() << "invalid index requested"; return QVariant(); } if (role == Qt::DisplayRole) { return m_matches.at(index.row()).text(); } else if (role == Qt::DecorationRole) { return m_matches.at(index.row()).icon(); } else if (role == Type) { return m_matches.at(index.row()).type(); } else if (role == Relevance) { return m_matches.at(index.row()).relevance(); } else if (role == Data) { return m_matches.at(index.row()).data(); } else if (role == Id) { return m_matches.at(index.row()).id(); } else if (role == SubText) { return m_matches.at(index.row()).subtext(); } else if (role == Enabled) { return m_matches.at(index.row()).isEnabled(); } else if (role == RunnerId) { return m_matches.at(index.row()).runner()->id(); } else if (role == RunnerName) { return m_matches.at(index.row()).runner()->name(); } else if (role == Actions) { QVariantList actions; Plasma::QueryMatch amatch = m_matches.at(index.row()); QList theactions = m_manager->actionsForMatch(amatch); foreach(QAction* action, theactions) { actions += qVariantFromValue(action); } return actions; } return QVariant(); } QString RunnerModel::currentQuery() const { return m_manager ? m_manager->query() : QString(); } void RunnerModel::scheduleQuery(const QString &query) { m_pendingQuery = query; m_startQueryTimer->start(); } void RunnerModel::startQuery() { if (!m_manager && m_pendingQuery.isEmpty()) { // avoid creating a manager just so we can run nothing return; } //kDebug() << "booooooo yah!!!!!!!!!!!!!" << query; createManager(); // if (m_pendingQuery != m_manager->query()) { //kDebug() << "running query" << query; m_manager->launchQuery(m_pendingQuery); emit queryChanged(); m_running = true; emit runningChanged(true); // } } void RunnerModel::createManager() { if (!m_manager) { m_manager = new Plasma::RunnerManager(this); connect(m_manager, SIGNAL(matchesChanged(QList)), this, SLOT(matchesChanged(QList))); connect(m_manager, SIGNAL(queryFinished()), this, SLOT(queryHasFinished())); if (!m_pendingRunnersList.isEmpty()) { m_manager->setAllowedRunners(m_pendingRunnersList); m_manager->setSingleMode(m_pendingRunnersList.count() == 1); m_pendingRunnersList.clear(); } //connect(m_manager, SIGNAL(queryFinished()), this, SLOT(queryFinished())); } } void RunnerModel::matchesChanged(const QList &matches) { //kDebug() << "got matches:" << matches.count(); beginResetModel(); m_matches = matches; endResetModel(); emit countChanged(); m_runningChangedTimeout->start(3000); } void RunnerModel::queryHasFinished() { m_running = false; emit runningChanged(false); } #include "runnermodel.moc"