From 6d095aca7f59dff26df0e2b5283d926feff5b477 Mon Sep 17 00:00:00 2001 From: Aqua-sama Date: Wed, 16 May 2018 18:20:25 +0200 Subject: Plugin command-line parameters --- lib/configuration/configuration.cpp | 3 +++ plugins/ProfileEditor/profileeditorplugin.cpp | 10 ++++++++++ plugins/ProfileEditor/profileeditorplugin.h | 1 + plugins/interfaces.h | 3 ++- src/browser.cpp | 17 +++++++++++++++++ src/browser.h | 8 ++++++++ src/main.cpp | 16 ++++++++++++++-- 7 files changed, 55 insertions(+), 3 deletions(-) diff --git a/lib/configuration/configuration.cpp b/lib/configuration/configuration.cpp index def997d..f2ec417 100644 --- a/lib/configuration/configuration.cpp +++ b/lib/configuration/configuration.cpp @@ -50,6 +50,9 @@ Configuration::Configuration() ("config,c", po::value()->default_value(defaultUserConfigLocation()), "Set the configuration file.") ("socket,s", po::value()->default_value(defaultSocketPath()), "Local server socket") + ("command", po::value(), "Run a plugin command") + ("commands", "List all plugin commands") + ("url", po::value>(), "URLs") ; diff --git a/plugins/ProfileEditor/profileeditorplugin.cpp b/plugins/ProfileEditor/profileeditorplugin.cpp index 7a92e51..fc65350 100644 --- a/plugins/ProfileEditor/profileeditorplugin.cpp +++ b/plugins/ProfileEditor/profileeditorplugin.cpp @@ -8,6 +8,16 @@ #include "profileeditorplugin.h" #include "forms/profileview.h" +#include + +QHash> ProfileEditorPlugin::commands() +{ + QHash> hash; + hash.insert("profileEditor:about", []() { + qDebug("ProfileEditor for smolbote"); + }); + return hash; +} QDialog *ProfileEditorPlugin::createWidget(QWebEngineProfile *profile, QWidget *parent) { diff --git a/plugins/ProfileEditor/profileeditorplugin.h b/plugins/ProfileEditor/profileeditorplugin.h index 899c51a..88a0783 100644 --- a/plugins/ProfileEditor/profileeditorplugin.h +++ b/plugins/ProfileEditor/profileeditorplugin.h @@ -21,6 +21,7 @@ class ProfileEditorPlugin : public QObject, public PluginInterface, public Profi public: // PluginInterface + QHash> commands() override; // ProfileInterface QDialog *createWidget(QWebEngineProfile *profile, QWidget *parent) override; diff --git a/plugins/interfaces.h b/plugins/interfaces.h index 46cf24a..ad3df97 100644 --- a/plugins/interfaces.h +++ b/plugins/interfaces.h @@ -11,6 +11,7 @@ #include #include +#include class QString; class QAction; @@ -26,13 +27,13 @@ class PluginInterface { public: virtual ~PluginInterface() = default; + virtual QHash> commands() = 0; }; class ProfileInterface { public: virtual ~ProfileInterface() = default; - virtual QDialog *createWidget(QWebEngineProfile *profile, QWidget *parent) = 0; }; diff --git a/src/browser.cpp b/src/browser.cpp index 09db2d1..91ba4f8 100644 --- a/src/browser.cpp +++ b/src/browser.cpp @@ -82,6 +82,14 @@ void Browser::setup(const QString &defaultProfile) // plugins m_plugins.append(loadPlugins(QString::fromStdString(m_config->value("plugins.path").value()))); + // register commands + for(Plugin p : m_plugins) { + auto *plugin = qobject_cast(p.instance.get()); + if(plugin) { + m_commands.unite(plugin->commands()); + } + } + // url request filter m_urlFilter = std::make_shared(QString::fromStdString(m_config->value("filter.path").value())); @@ -113,6 +121,15 @@ void Browser::setup(const QString &defaultProfile) } } +void Browser::command(const QString &command) +{ + if(m_commands.contains(command)) { + m_commands.value(command)(); + } else { + qWarning("No such command: %s", qUtf8Printable(command)); + } +} + void Browser::createSession(const QString &profileName, bool newWindow, const QStringList &urls) { if(m_windows.isEmpty()) { diff --git a/src/browser.h b/src/browser.h index 01de9bb..e5df9de 100644 --- a/src/browser.h +++ b/src/browser.h @@ -14,6 +14,7 @@ #include #include #include +#include QVector loadPlugins(const QString &location); @@ -34,6 +35,12 @@ public: void setConfiguration(std::shared_ptr &config); void setup(const QString &defaultProfile); + void command(const QString &command); + QStringList commands() const + { + return m_commands.keys(); + } + public slots: void createSession(const QString &profileName, bool newWindow, const QStringList &urls); MainWindow *createWindow(); @@ -46,6 +53,7 @@ private: QVector m_windows; QVector m_plugins; + QHash> m_commands; }; #endif // SMOLBOTE_BROWSER_H diff --git a/src/main.cpp b/src/main.cpp index f1ac1ae..d578d24 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -49,6 +49,20 @@ int main(int argc, char **argv) app.setAttribute(Qt::AA_DontCreateNativeWidgetSiblings, true); app.setConfiguration(config); + app.setup(QString::fromStdString(config->value("profile.default").value())); + + if(config->exists("commands")) { + for(const QString &cmd : app.commands()) { + std::cout << cmd.toStdString() << std::endl; + } + return 0; + } + + if(config->exists("command")) { + app.command(QString::fromStdString(config->value("command").value())); + return 0; + } + // set up socket bool isSingleInstance = app.bindLocalSocket(QString::fromStdString(config->value("socket").value())); #ifdef QT_DEBUG @@ -66,12 +80,10 @@ int main(int argc, char **argv) } } - app.setup(QString::fromStdString(config->value("profile.default").value())); QObject::connect(&app, &Browser::messageAvailable, &app, &Browser::createSession); } app.sendMessage("", false, config->positionalArguments()); - if(isSingleInstance) return app.exec(); else -- cgit v1.2.1