diff options
-rw-r--r-- | lib/web/profilemanager.cpp | 54 | ||||
-rw-r--r-- | lib/web/profilemanager.h | 10 | ||||
-rw-r--r-- | src/browser.cpp | 58 | ||||
-rw-r--r-- | src/browser.h | 1 | ||||
-rw-r--r-- | src/mainwindow/mainwindow.cpp | 1 | ||||
-rw-r--r-- | src/session.cpp | 3 | ||||
-rw-r--r-- | src/subwindow/subwindow.cpp | 1 | ||||
-rw-r--r-- | src/webengine/webview.cpp | 2 |
8 files changed, 54 insertions, 76 deletions
diff --git a/lib/web/profilemanager.cpp b/lib/web/profilemanager.cpp index 97d5f8d..75fd413 100644 --- a/lib/web/profilemanager.cpp +++ b/lib/web/profilemanager.cpp @@ -11,23 +11,25 @@ #include <QFileInfo> #include <QWebEngineSettings> -ProfileManager *ProfileManager::s_instance = nullptr; - -ProfileManager::ProfileManager(const QHash<QString, QString> &profileSection, QObject *parent) : QObject(parent) - , defaults(profileSection) +ProfileManager::ProfileManager(const QHash<QString, QString> &profileSection, const QString &defaultId, QObject *parent) + : QObject(parent) + , defaults(profileSection) { -} + // load profiles from path + const QDir profilesDir(defaults.value("profile.path")); -void ProfileManager::setInstance(ProfileManager *instance) -{ - Q_CHECK_PTR(instance); - s_instance = instance; -} + if(profilesDir.exists()) { + const auto entries = profilesDir.entryInfoList({ "*.profile" }, QDir::Files | QDir::Readable, QDir::Time); -ProfileManager *ProfileManager::instance() -{ - Q_CHECK_PTR(s_instance); - return s_instance; + for(const QFileInfo &f : entries) { + loadProfile(f.absoluteFilePath()); + } + } + + const QString defaultProfile = defaults.value("profile.default", defaultId); + if(m_profiles.count(defaultProfile) == 0) { + loadProfile(defaultProfile); + } } WebProfile *ProfileManager::loadProfile(const QString &path) @@ -100,9 +102,9 @@ void ProfileManager::deleteProfile(const QString &id) QMenu *ProfileManager::createProfileMenu(std::function<void(WebProfile *)> callback, QWidget *parent) const { - QMenu *menu = new QMenu(parent); - for(auto it = m_profiles.cbegin(); it != m_profiles.cend(); ++it) { - WebProfile *profile = it->second->profile; + auto *menu = new QMenu(parent); + for(const auto &m_profile : m_profiles) { + WebProfile *profile = m_profile.second->profile; QAction *action = menu->addAction(profile->name()); connect(action, &QAction::triggered, [profile, callback]() { callback(profile); @@ -114,17 +116,17 @@ QMenu *ProfileManager::createProfileMenu(std::function<void(WebProfile *)> callb const QStringList ProfileManager::idList() const { QStringList ids; - for(auto it = m_profiles.cbegin(); it != m_profiles.cend(); ++it) { - ids.append(it->first); + for(const auto &m_profile : m_profiles) { + ids.append(m_profile.first); } return ids; } const QString ProfileManager::id(const WebProfile *profile) const { - for(auto it = m_profiles.cbegin(); it != m_profiles.cend(); ++it) { - if(it->second->profile == profile) - return it->first; + for(const auto &m_profile : m_profiles) { + if(m_profile.second->profile == profile) + return m_profile.first; } return QString(); } @@ -136,11 +138,3 @@ WebProfile *ProfileManager::profile(const QString &id) const } return nullptr; } - -const QString ProfileManager::configurationPath(const QString &id) const -{ - if(m_profiles.count(id) > 0) { - return m_profiles.at(id)->path; - } - return QString(); -} diff --git a/lib/web/profilemanager.h b/lib/web/profilemanager.h index 1cb5dd5..9cd2cbd 100644 --- a/lib/web/profilemanager.h +++ b/lib/web/profilemanager.h @@ -20,17 +20,12 @@ #include <map> #include <memory> -#define profileManager ProfileManager::instance() - class WebProfile; class ProfileManager : public QObject { Q_OBJECT public: - explicit ProfileManager(const QHash<QString, QString> &profileSection, QObject *parent = nullptr); - - static void setInstance(ProfileManager *instance); - static ProfileManager *instance(); + explicit ProfileManager(const QHash<QString, QString> &profileSection, const QString &defaultId, QObject *parent = nullptr); WebProfile *loadProfile(const QString &path); void deleteProfile(const QString &id); @@ -40,7 +35,6 @@ public: const QStringList idList() const; const QString id(const WebProfile *profile) const; WebProfile *profile(const QString &id) const; - const QString configurationPath(const QString &id) const; private: struct ProfileData { @@ -68,8 +62,6 @@ private: }; std::map<QString, std::unique_ptr<ProfileData>> m_profiles; - - static ProfileManager *s_instance; const QHash<QString, QString> defaults; }; diff --git a/src/browser.cpp b/src/browser.cpp index 6cdfdab..e93123c 100644 --- a/src/browser.cpp +++ b/src/browser.cpp @@ -16,16 +16,16 @@ #include <QFileInfo> #include <QFileInfoList> #include <QJsonArray> +#include <QJsonDocument> #include <QPluginLoader> +#include <QTimer> #include <about/aboutdialog.h> #include <bookmarks/bookmarkswidget.h> #include <configuration/configuration.h> #include <downloads/downloadswidget.h> #include <version.h> -#include <web/webprofile.h> #include <web/profilemanager.h> -#include <QJsonDocument> -#include <QTimer> +#include <web/webprofile.h> Browser::Browser(int &argc, char *argv[], bool allowSecondary) : SingleApplication(argc, argv, allowSecondary, SingleApplication::User | SingleApplication::SecondaryNotification | SingleApplication::ExcludeAppVersion) @@ -55,11 +55,11 @@ void Browser::about() QPair<QString, WebProfile *> Browser::loadProfile(const QString &id) { - WebProfile *profile = profileManager->loadProfile(id); + WebProfile *profile = m_profileManager->loadProfile(id); connect(profile, &WebProfile::downloadRequested, m_downloads.get(), &DownloadsWidget::addDownload); profile->setRequestInterceptor(m_urlFilter.get()); - return QPair<QString, WebProfile *>(profileManager->id(profile), profile); + return QPair<QString, WebProfile *>(m_profileManager->id(profile), profile); } void Browser::setConfiguration(std::unique_ptr<Configuration> &config) @@ -76,27 +76,24 @@ Configuration *Browser::getConfiguration() const ProfileManager *Browser::getProfileManager() { - return ProfileManager::instance(); + return m_profileManager; } void Browser::registerPlugin(const Plugin &plugin) { Q_ASSERT(m_config); - auto *p = qobject_cast<PluginInterface *>(plugin.instance); - Q_CHECK_PTR(p); - p->setBrowserInterface(this); - - m_plugins.append(plugin); + if(p != nullptr) { + p->setBrowserInterface(this); + m_plugins.append(plugin); + } } void Browser::setup(const QString &defaultProfile) { Q_ASSERT(m_config); - ProfileManager::setInstance(new ProfileManager(m_config->section("profile"), this)); - auto stylesheet = m_config->value<QString>("browser.stylesheet"); if(stylesheet) { QFile f(stylesheet.value()); @@ -113,25 +110,15 @@ void Browser::setup(const QString &defaultProfile) // cookie request filter // load profiles - { - const auto defaults = m_config->section("profile"); - const QDir profilesDir(m_config->value<QString>("profile.path").value()); - - if(profilesDir.exists()) { - const auto entries = profilesDir.entryInfoList({ "*.profile" }, QDir::Files | QDir::Readable, QDir::Time); - - for(const QFileInfo &f : entries) { - loadProfile(f.absoluteFilePath()); - } - } - - // set default profile - if(profileManager->profile(defaultProfile) == nullptr) { - // if this profile has not been added, it doesn't have a path - loadProfile(QString()); - } - WebProfile::setDefaultProfile(profileManager->profile(defaultProfile)); + m_profileManager = new ProfileManager(m_config->section("profile"), defaultProfile, this); + // connect profiles + for(const QString &id : m_profileManager->idList()) { + auto *profile = m_profileManager->profile(id); + connect(profile, &WebProfile::downloadRequested, m_downloads.get(), &DownloadsWidget::addDownload); + profile->setRequestInterceptor(m_urlFilter.get()); } + // set default profile + WebProfile::setDefaultProfile(m_profileManager->profile(defaultProfile)); // bookmarks m_bookmarks = std::make_shared<BookmarksWidget>(QString::fromStdString(m_config->value<std::string>("bookmarks.path").value())); @@ -142,7 +129,7 @@ void Browser::setup(const QString &defaultProfile) auto *timer = new QTimer(this); connect(timer, &QTimer::timeout, m_bookmarks.get(), &BookmarksWidget::save); // 5min * 60sec * 1000ms - timer->start(5*60*1000); + timer->start(5 * 60 * 1000); } void Browser::createSession(const QJsonObject &object) @@ -158,7 +145,7 @@ void Browser::createSession(const QJsonObject &object) for(const QJsonValue &s : subwindows) { const QJsonObject subwindow = s.toObject(); const QString profileId = subwindow.value("profile").toString(); - WebProfile *profile = profileManager->profile(profileId); + WebProfile *profile = m_profileManager->profile(profileId); if(profile == nullptr) profile = WebProfile::defaultProfile(); Q_CHECK_PTR(profile); @@ -180,7 +167,7 @@ void Browser::createSession(const QJsonObject &object) for(const QJsonValue &t : subwindow.value("tabs").toArray()) { const QJsonObject tab = t.toObject(); const QUrl url = QUrl::fromUserInput(tab.value("url").toString()); - WebProfile *p = profileManager->profile(tab.value("profile").toString()); + WebProfile *p = m_profileManager->profile(tab.value("profile").toString()); window->addTab(url, p); } } @@ -190,7 +177,7 @@ void Browser::createSession(const QJsonObject &object) MainWindow *Browser::createWindow() { // the window will delete itself when it closes, so we don't need to delete it - MainWindow *window = new MainWindow(m_config); + auto *window = new MainWindow(m_config); connect(window->addressBar, &AddressBar::complete, m_bookmarks.get(), &BookmarksWidget::search); connect(window, &MainWindow::createBookmark, m_bookmarks.get(), &BookmarksWidget::addBookmark); @@ -231,7 +218,6 @@ MainWindow *Browser::createWindow() plugin->createWidget(window)->exec(); }); window->addAction(MainWindow::ToolsMenu, pluginAction); - } m_windows.append(window); diff --git a/src/browser.h b/src/browser.h index 007b0a1..bf91cc8 100644 --- a/src/browser.h +++ b/src/browser.h @@ -63,6 +63,7 @@ private: std::unique_ptr<Configuration> m_config; std::shared_ptr<BookmarksWidget> m_bookmarks; std::unique_ptr<DownloadsWidget> m_downloads; + ProfileManager *m_profileManager; std::unique_ptr<UrlRequestInterceptor> m_urlFilter; QVector<MainWindow *> m_windows; diff --git a/src/mainwindow/mainwindow.cpp b/src/mainwindow/mainwindow.cpp index e1b8fd8..8a33e23 100644 --- a/src/mainwindow/mainwindow.cpp +++ b/src/mainwindow/mainwindow.cpp @@ -390,6 +390,7 @@ void MainWindow::updatePageLoadProfileMenu() if(currentView == nullptr) return; + auto *profileManager = dynamic_cast<Browser *>(qApp)->getProfileManager(); pageLoadProfileMenu->addActions(profileManager->createProfileMenu([this](WebProfile *profile) { this->currentView->setProfile(profile); }, diff --git a/src/session.cpp b/src/session.cpp index 70e1deb..3c40a2a 100644 --- a/src/session.cpp +++ b/src/session.cpp @@ -13,7 +13,7 @@ #include <QJsonArray> #include "webengine/webview.h" #include <web/profilemanager.h> - +#include "browser.h" QJsonObject Session::session(QVector<MainWindow *> windows) { @@ -31,6 +31,7 @@ QJsonObject Session::session(QVector<MainWindow *> windows) QJsonObject Session::window(const MainWindow *window) { QJsonObject obj; + auto *profileManager = dynamic_cast<Browser *>(qApp)->getProfileManager(); QJsonArray subwindows; for(const SubWindow *subwindow : window->subWindows()) { diff --git a/src/subwindow/subwindow.cpp b/src/subwindow/subwindow.cpp index 7dc1cdf..44ac1b1 100644 --- a/src/subwindow/subwindow.cpp +++ b/src/subwindow/subwindow.cpp @@ -50,6 +50,7 @@ SubWindow::SubWindow(const std::unique_ptr<Configuration> &config, QWidget *pare Browser *browser = qobject_cast<Browser *>(qApp); Q_CHECK_PTR(browser); + auto *profileManager = dynamic_cast<Browser *>(qApp)->getProfileManager(); loadProfile_menu->addActions(profileManager->createProfileMenu([this, profileName_action](WebProfile *profile) { this->setProfile(profile); profileName_action->setText(tr("Profile: %1").arg(profile->name())); diff --git a/src/webengine/webview.cpp b/src/webengine/webview.cpp index c2c0f75..f8be48e 100644 --- a/src/webengine/webview.cpp +++ b/src/webengine/webview.cpp @@ -22,6 +22,7 @@ #include <QWidgetAction> #include <web/profilemanager.h> #include <web/webprofile.h> +#include "browser.h" inline QAction *historyAction(QWebEngineView *view, const QWebEngineHistoryItem &item) { @@ -243,6 +244,7 @@ void WebView::contextMenuEvent(QContextMenuEvent *event) createWindow(QWebEnginePage::WebBrowserTab)->load(ctxdata.linkUrl()); }); + auto *profileManager = dynamic_cast<Browser *>(qApp)->getProfileManager(); QMenu *newTabMenu = profileManager->createProfileMenu([this, ctxdata](WebProfile *profile) { auto *view = this->createWindow(QWebEnginePage::WebBrowserTab); view->setProfile(profile); |