aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--plugins/ProfileEditor/profileeditorplugin.cpp7
-rw-r--r--plugins/ProfileEditor/profileeditorplugin.h2
-rw-r--r--plugins/interfaces.h2
-rw-r--r--src/browser.cpp41
-rw-r--r--src/browser.h4
-rw-r--r--src/main.cpp5
6 files changed, 33 insertions, 28 deletions
diff --git a/plugins/ProfileEditor/profileeditorplugin.cpp b/plugins/ProfileEditor/profileeditorplugin.cpp
index fc65350..b5e772f 100644
--- a/plugins/ProfileEditor/profileeditorplugin.cpp
+++ b/plugins/ProfileEditor/profileeditorplugin.cpp
@@ -10,11 +10,12 @@
#include "forms/profileview.h"
#include <QHash>
-QHash<QString, std::function<void()>> ProfileEditorPlugin::commands()
+QHash<QString, std::function<int ()> > ProfileEditorPlugin::commands()
{
- QHash<QString, std::function<void()>> hash;
- hash.insert("profileEditor:about", []() {
+ QHash<QString, std::function<int()>> hash;
+ hash.insert("profileEditor:about", []() -> int {
qDebug("ProfileEditor for smolbote");
+ return 0;
});
return hash;
}
diff --git a/plugins/ProfileEditor/profileeditorplugin.h b/plugins/ProfileEditor/profileeditorplugin.h
index 88a0783..4f88e1b 100644
--- a/plugins/ProfileEditor/profileeditorplugin.h
+++ b/plugins/ProfileEditor/profileeditorplugin.h
@@ -21,7 +21,7 @@ class ProfileEditorPlugin : public QObject, public PluginInterface, public Profi
public:
// PluginInterface
- QHash<QString, std::function<void()>> commands() override;
+ QHash<QString, std::function<int()>> commands() override;
// ProfileInterface
QDialog *createWidget(QWebEngineProfile *profile, QWidget *parent) override;
diff --git a/plugins/interfaces.h b/plugins/interfaces.h
index ad3df97..196da0b 100644
--- a/plugins/interfaces.h
+++ b/plugins/interfaces.h
@@ -27,7 +27,7 @@ class PluginInterface
{
public:
virtual ~PluginInterface() = default;
- virtual QHash<QString, std::function<void()>> commands() = 0;
+ virtual QHash<QString, std::function<int()>> commands() = 0;
};
class ProfileInterface
diff --git a/src/browser.cpp b/src/browser.cpp
index 8c2b010..512f207 100644
--- a/src/browser.cpp
+++ b/src/browser.cpp
@@ -79,6 +79,16 @@ void Browser::setup(const QString &defaultProfile)
{
Q_ASSERT_X(m_config, "Browser::setup", "Configuration not set");
+ // load profiles
+ if(defaultProfile == "") {
+ auto *p = new WebProfile(this);
+ p->loadProfile(m_config->section("profile"));
+ WebProfile::setDefaultProfile(p);
+ } else {
+ auto *p = new WebProfile(defaultProfile, this);
+ WebProfile::setDefaultProfile(p);
+ }
+
// plugins
m_plugins.append(loadPlugins(QString::fromStdString(m_config->value<std::string>("plugins.path").value())));
@@ -88,10 +98,18 @@ void Browser::setup(const QString &defaultProfile)
if(plugin) {
m_commands.unite(plugin->commands());
}
+ if(p.instance->inherits("ProfileInterface")) {
+ auto *profileEditor = qobject_cast<ProfileInterface *>(p.instance.get());
+ Q_ASSERT_X(profileEditor != nullptr, "Browser::setup", "profile interface cast failed");
+ m_commands.insert("profileEditor:editDefaultProfile", [profileEditor]() -> int {
+ return profileEditor->createWidget(WebProfile::defaultProfile(), nullptr)->exec();
+ });
+ }
}
// url request filter
m_urlFilter = std::make_shared<UrlRequestInterceptor>(QString::fromStdString(m_config->value<std::string>("filter.path").value()));
+ WebProfile::defaultProfile()->setRequestInterceptor(m_urlFilter.get());
// cookie request filter
@@ -100,33 +118,20 @@ void Browser::setup(const QString &defaultProfile)
connect(m_bookmarks.get(), &BookmarksWidget::openUrl, this, [this](const QUrl &url) {
m_windows.last()->createTab(url);
});
+ connect(WebProfile::defaultProfile(), &WebProfile::addBookmarkRequested, m_bookmarks.get(), &BookmarksWidget::addBookmark);
// downloads
m_downloads = std::make_shared<DownloadsWidget>(QString::fromStdString(m_config->value<std::string>("downloads.path").value()));
-
- // load profiles
- if(defaultProfile == "") {
- auto *p = new WebProfile(this);
- p->loadProfile(m_config->section("profile"));
- p->setRequestInterceptor(m_urlFilter.get());
- connect(p, &WebProfile::addBookmarkRequested, m_bookmarks.get(), &BookmarksWidget::addBookmark);
- connect(p, &WebProfile::downloadRequested, m_downloads.get(), &DownloadsWidget::addDownload);
- WebProfile::setDefaultProfile(p);
- } else {
- auto *p = new WebProfile(defaultProfile, this);
- p->setRequestInterceptor(m_urlFilter.get());
- connect(p, &WebProfile::addBookmarkRequested, m_bookmarks.get(), &BookmarksWidget::addBookmark);
- connect(p, &WebProfile::downloadRequested, m_downloads.get(), &DownloadsWidget::addDownload);
- WebProfile::setDefaultProfile(p);
- }
+ connect(WebProfile::defaultProfile(), &WebProfile::downloadRequested, m_downloads.get(), &DownloadsWidget::addDownload);
}
-void Browser::command(const QString &command)
+int Browser::command(const QString &command)
{
if(m_commands.contains(command)) {
- m_commands.value(command)();
+ return m_commands.value(command)();
} else {
qWarning("No such command: %s", qUtf8Printable(command));
+ return -1;
}
}
diff --git a/src/browser.h b/src/browser.h
index e5df9de..0a0d956 100644
--- a/src/browser.h
+++ b/src/browser.h
@@ -35,7 +35,7 @@ public:
void setConfiguration(std::shared_ptr<Configuration> &config);
void setup(const QString &defaultProfile);
- void command(const QString &command);
+ int command(const QString &command);
QStringList commands() const
{
return m_commands.keys();
@@ -53,7 +53,7 @@ private:
QVector<MainWindow *> m_windows;
QVector<Plugin> m_plugins;
- QHash<QString, std::function<void()>> m_commands;
+ QHash<QString, std::function<int()>> m_commands;
};
#endif // SMOLBOTE_BROWSER_H
diff --git a/src/main.cpp b/src/main.cpp
index 89f3005..c9b6007 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -59,12 +59,11 @@ int main(int argc, char **argv)
for(const QString &cmd : app.commands()) {
std::cout << cmd.toStdString() << std::endl;
}
- return 0;
+ exit(0);
}
if(config->exists("command")) {
- app.command(QString::fromStdString(config->value<std::string>("command").value()));
- return 0;
+ exit(app.command(QString::fromStdString(config->value<std::string>("command").value())));
}
// set up socket