/*************************************************************************** * This file is part of awesome-widgets * * * * awesome-widgets 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 3 of the * * License, or (at your option) any later version. * * * * awesome-widgets 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 awesome-widgets. If not, see http://www.gnu.org/licenses/ * ***************************************************************************/ #include "extscript.h" #include "ui_extscript.h" #include #include #include #include #include #include #include #include #include "version.h" ExtScript::ExtScript(QWidget *parent, const QString scriptName, const QStringList directories, const bool debugCmd) : AbstractExtItem(parent, scriptName, directories, debugCmd), debug(debugCmd), ui(new Ui::ExtScript) { readConfiguration(); readJsonFilters(); ui->setupUi(this); value[QString("value")] = QString(""); process = new QProcess(this); connect(process, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(updateValue())); process->waitForFinished(0); } ExtScript::~ExtScript() { if (debug) qDebug() << PDEBUG; process->kill(); delete process; delete ui; } ExtScript *ExtScript::copy(const QString fileName, const int number) { if (debug) qDebug() << PDEBUG; ExtScript *item = new ExtScript(static_cast(parent()), fileName, directories(), debug); item->setActive(isActive()); item->setApiVersion(apiVersion()); item->setComment(comment()); item->setExecutable(executable()); item->setHasOutput(hasOutput()); item->setInterval(interval()); item->setName(name()); item->setNumber(number); item->setPrefix(prefix()); item->setRedirect(redirect()); return item; } QString ExtScript::executable() const { if (debug) qDebug() << PDEBUG; return m_executable; } QStringList ExtScript::filters() const { if (debug) qDebug() << PDEBUG; return m_filters; } bool ExtScript::hasOutput() const { if (debug) qDebug() << PDEBUG; return m_output; } QString ExtScript::prefix() const { if (debug) qDebug() << PDEBUG; return m_prefix; } ExtScript::Redirect ExtScript::redirect() const { if (debug) qDebug() << PDEBUG; return m_redirect; } QString ExtScript::uniq() const { if (debug) qDebug() << PDEBUG; return m_executable; } QString ExtScript::strRedirect() const { if (debug) qDebug() << PDEBUG; QString value; switch (m_redirect) { case stdout2stderr: value = QString("stdout2stderr"); break; case stderr2stdout: value = QString("stderr2stdout"); break; case nothing: default: value = QString("nothing"); break; } return value; } void ExtScript::setExecutable(const QString _executable) { if (debug) qDebug() << PDEBUG; if (debug) qDebug() << PDEBUG << ":" << "Executable" << _executable; m_executable = _executable; } void ExtScript::setFilters(const QStringList _filters) { if (debug) qDebug() << PDEBUG; if (debug) qDebug() << PDEBUG << ":" << "Filters" << _filters; for (int i=0; i<_filters.count(); i++) updateFilter(_filters[i]); } void ExtScript::setHasOutput(const bool _state) { if (debug) qDebug() << PDEBUG; if (debug) qDebug() << PDEBUG << ":" << "State" << _state; m_output = _state; } void ExtScript::setPrefix(const QString _prefix) { if (debug) qDebug() << PDEBUG; if (debug) qDebug() << PDEBUG << ":" << "Prefix" << _prefix; m_prefix = _prefix; } void ExtScript::setRedirect(const Redirect _redirect) { if (debug) qDebug() << PDEBUG; if (debug) qDebug() << PDEBUG << ":" << "Redirect" << _redirect; m_redirect = _redirect; } void ExtScript::setStrRedirect(const QString _redirect) { if (debug) qDebug() << PDEBUG; if (debug) qDebug() << PDEBUG << ":" << "Redirect" << _redirect; if (_redirect == QString("stdout2sdterr")) m_redirect = stdout2stderr; else if (_redirect == QString("stderr2sdtout")) m_redirect = stderr2stdout; else m_redirect = nothing; } QString ExtScript::applyFilters(QString _value) const { if (debug) qDebug() << PDEBUG; if (debug) qDebug() << PDEBUG << ":" << "Value" << _value; for (int i=0; i=0; i--) { if (!QDir(directories()[i]).entryList(QDir::Files).contains(fileName())) continue; QSettings settings(QString("%1/%2").arg(directories()[i]).arg(fileName()), QSettings::IniFormat); settings.beginGroup(QString("Desktop Entry")); setExecutable(settings.value(QString("Exec"), m_executable).toString()); setPrefix(settings.value(QString("X-AW-Prefix"), m_prefix).toString()); setHasOutput(settings.value(QString("X-AW-Output"), QVariant(m_output)).toString() == QString("true")); setStrRedirect(settings.value(QString("X-AW-Redirect"), strRedirect()).toString()); // api == 3 setFilters(settings.value(QString("X-AW-Filters"), m_filters).toString() .split(QChar(','), QString::SkipEmptyParts)); settings.endGroup(); } if (!m_output) setRedirect(stdout2stderr); // update for current API if ((apiVersion() > 0) && (apiVersion() < AWESAPI)) { setApiVersion(AWESAPI); writeConfiguration(); } } void ExtScript::readJsonFilters() { if (debug) qDebug() << PDEBUG; QString fileName = QStandardPaths::locate(QStandardPaths::GenericDataLocation, QString("awesomewidgets/scripts/awesomewidgets-extscripts-filters.json")); if (debug) qDebug() << PDEBUG << ":" << "Configuration file" << fileName; QFile jsonFile(fileName); if (!jsonFile.open(QIODevice::ReadOnly | QIODevice::Text)) return; QString jsonText = jsonFile.readAll(); jsonFile.close(); QJsonParseError error; QJsonDocument jsonDoc = QJsonDocument::fromJson(jsonText.toUtf8(), &error); if (debug) qDebug() << PDEBUG << ":" << "Json parse error" << error.errorString(); if (error.error != QJsonParseError::NoError) return; jsonFilters = jsonDoc.toVariant().toMap(); if (debug) qDebug() << PDEBUG << ":" << "Filters" << jsonFilters; } QVariantMap ExtScript::run() { if (debug) qDebug() << PDEBUG; if (!isActive()) return value; if ((times == 1) && (process->state() == QProcess::NotRunning)) { QStringList cmdList; if (!m_prefix.isEmpty()) cmdList.append(m_prefix); cmdList.append(m_executable); if (debug) qDebug() << PDEBUG << ":" << "cmd" << cmdList.join(QChar(' ')); process->start(cmdList.join(QChar(' '))); } else if (times >= interval()) times = 0; times++; return value; } int ExtScript::showConfiguration(const QVariant args) { Q_UNUSED(args) if (debug) qDebug() << PDEBUG; ui->lineEdit_name->setText(name()); ui->lineEdit_comment->setText(comment()); ui->label_numberValue->setText(QString("%1").arg(number())); ui->lineEdit_command->setText(m_executable); ui->lineEdit_prefix->setText(m_prefix); ui->checkBox_active->setCheckState(isActive() ? Qt::Checked : Qt::Unchecked); ui->checkBox_output->setCheckState(m_output ? Qt::Checked : Qt::Unchecked); ui->comboBox_redirect->setCurrentIndex(static_cast(m_redirect)); ui->spinBox_interval->setValue(interval()); // filters ui->checkBox_colorFilter->setCheckState(m_filters.contains(QString("color")) ? Qt::Checked : Qt::Unchecked); ui->checkBox_linesFilter->setCheckState(m_filters.contains(QString("newline")) ? Qt::Checked : Qt::Unchecked); ui->checkBox_spaceFilter->setCheckState(m_filters.contains(QString("space")) ? Qt::Checked : Qt::Unchecked); int ret = exec(); if (ret != 1) return ret; setName(ui->lineEdit_name->text()); setComment(ui->lineEdit_comment->text()); setNumber(ui->label_numberValue->text().toInt()); setApiVersion(AWESAPI); setExecutable(ui->lineEdit_command->text()); setPrefix(ui->lineEdit_prefix->text()); setActive(ui->checkBox_active->checkState() == Qt::Checked); setHasOutput(ui->checkBox_output->checkState() == Qt::Checked); setStrRedirect(ui->comboBox_redirect->currentText()); setInterval(ui->spinBox_interval->value()); // filters updateFilter(QString("color"), ui->checkBox_colorFilter->checkState() == Qt::Checked); updateFilter(QString("newline"), ui->checkBox_linesFilter->checkState() == Qt::Checked); updateFilter(QString("space"), ui->checkBox_spaceFilter->checkState() == Qt::Checked); writeConfiguration(); return ret; } void ExtScript::writeConfiguration() const { if (debug) qDebug() << PDEBUG; AbstractExtItem::writeConfiguration(); QSettings settings(QString("%1/%2").arg(directories()[0]).arg(fileName()), QSettings::IniFormat); if (debug) qDebug() << PDEBUG << ":" << "Configuration file" << settings.fileName(); settings.beginGroup(QString("Desktop Entry")); settings.setValue(QString("Exec"), m_executable); settings.setValue(QString("X-AW-Prefix"), m_prefix); settings.setValue(QString("X-AW-Output"), QVariant(m_output).toString()); settings.setValue(QString("X-AW-Redirect"), strRedirect()); settings.setValue(QString("X-AW-Filters"), m_filters.join(QChar(','))); settings.endGroup(); settings.sync(); } void ExtScript::updateValue() { if (debug) qDebug() << PDEBUG; if (debug) qDebug() << PDEBUG << ":" << "Cmd returns" << process->exitCode(); QString qdebug = QTextCodec::codecForMib(106)->toUnicode(process->readAllStandardError()).trimmed(); if (debug) qDebug() << PDEBUG << ":" << "Error" << qdebug; QString qoutput = QTextCodec::codecForMib(106)->toUnicode(process->readAllStandardOutput()).trimmed(); switch (m_redirect) { case stdout2stderr: if (debug) qDebug() << PDEBUG << ":" << "Debug" << qdebug; if (debug) qDebug() << PDEBUG << ":" << "Output" << qoutput; break; case stderr2stdout: value[QString("value")] = QString("%1\n%2").arg(qdebug).arg(qoutput); break; case nothing: default: if (debug) qDebug() << PDEBUG << ":" << "Debug" << qdebug; value[QString("value")] = qoutput; break; } // filters value[QString("value")] = applyFilters(value[QString("value")].toString()); }