aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAqua-sama <aqua@iserlohn-fortress.net>2018-06-07 21:18:49 +0200
committerAqua-sama <aqua@iserlohn-fortress.net>2018-06-07 21:18:49 +0200
commitf180021aefbeaddcef6db74e9d0f088a14daa623 (patch)
treefde9c8378d0eadc53f11dbded5bcd60b9e7b21f9
parentSplit webengine/webprofile into lib/web (diff)
downloadsmolbote-f180021aefbeaddcef6db74e9d0f088a14daa623.tar.xz
Improve plugin loading
- load plugins last - plugin.path can now also be a path to a single plugin, not just a folder
-rw-r--r--src/browser.cpp89
1 files changed, 57 insertions, 32 deletions
diff --git a/src/browser.cpp b/src/browser.cpp
index bb29ff7..99ddcc3 100644
--- a/src/browser.cpp
+++ b/src/browser.cpp
@@ -22,30 +22,54 @@
#include <QFileInfoList>
#include <QPluginLoader>
-inline QVector<Plugin> loadPlugins(const QString &location)
+inline Plugin loadPluginFromPath(const QString &path)
{
- QDir pluginsDir(location);
- QVector<Plugin> list;
+ Plugin p;
+ QPluginLoader loader(path);
- if(pluginsDir.exists()) {
- const QStringList entries = pluginsDir.entryList(QDir::Files | QDir::Readable);
+ if(loader.load()) {
+#ifdef QT_DEBUG
+ qDebug("Loading plugin: %s [ok]", qUtf8Printable(path));
+#endif
- for(const QString &name : entries) {
- QPluginLoader loader(pluginsDir.absoluteFilePath(name));
+ p.instance = std::shared_ptr<QObject>(loader.instance());
- if(loader.load()) {
#ifdef QT_DEBUG
- qDebug("Loading plugin: %s [ok]", qUtf8Printable(pluginsDir.absoluteFilePath(name)));
+ } else {
+ qDebug("Loading pluing: %s [failed]", qUtf8Printable(path));
#endif
- Plugin p;
- p.instance = std::shared_ptr<QObject>(loader.instance());
+ }
+
+ return p;
+}
+
+inline QVector<Plugin> loadPlugins(const QString &path)
+{
+ QVector<Plugin> list;
+ QFileInfo location(path);
+ if(!location.exists()) {
+ return list;
+ }
+
+ if(location.isFile()) {
+ // only load this one plugin
+ auto p = loadPluginFromPath(location.absoluteFilePath());
+ if(p.instance)
+ list.append(p);
+
+ } else if(location.isDir()) {
+ // load all profiles from this directory
+ const auto entries = QDir(location.absoluteFilePath()).entryInfoList(QDir::Files | QDir::Readable);
+ for(const auto &f : entries) {
+ auto p = loadPluginFromPath(f.absoluteFilePath());
+ if(p.instance)
list.append(p);
- } else {
+ }
+
+ } else {
#ifdef QT_DEBUG
- qDebug("Loading plugin: %s [failed]", qUtf8Printable(name));
+ qDebug("Path is neither file nor folder: %s", qUtf8Printable(path));
#endif
- }
- }
}
return list;
@@ -113,7 +137,24 @@ void Browser::setup(const QString &defaultProfile)
}
}
- // plugins
+ // 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
+
+ // bookmarks
+ m_bookmarks = std::make_shared<BookmarksWidget>(QString::fromStdString(m_config->value<std::string>("bookmarks.path").value()));
+ 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()));
+ connect(WebProfile::defaultProfile(), &WebProfile::downloadRequested, m_downloads.get(), &DownloadsWidget::addDownload);
+
+ // load plugins last
m_plugins.append(loadPlugins(QString::fromStdString(m_config->value<std::string>("plugins.path").value())));
// register commands
@@ -132,22 +173,6 @@ void Browser::setup(const QString &defaultProfile)
}
}
- // 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
-
- // bookmarks
- m_bookmarks = std::make_shared<BookmarksWidget>(QString::fromStdString(m_config->value<std::string>("bookmarks.path").value()));
- 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()));
- connect(WebProfile::defaultProfile(), &WebProfile::downloadRequested, m_downloads.get(), &DownloadsWidget::addDownload);
}
WebProfile *Browser::profile(const QString &name) const