diff options
author | Aqua-sama <aqua@iserlohn-fortress.net> | 2017-12-20 18:08:56 +0100 |
---|---|---|
committer | Aqua-sama <aqua@iserlohn-fortress.net> | 2017-12-20 18:08:56 +0100 |
commit | 2abe26db203c75798775a42eae2d7dc7ab9bf354 (patch) | |
tree | cf273c92e1fdc68fcca90409bad160b4d7fe27e6 /src | |
parent | Added SSL cert warnings (diff) | |
download | smolbote-2abe26db203c75798775a42eae2d7dc7ab9bf354.tar.xz |
Bug fixes
.config/smolbote will now be created if missing
Connected profiles to download manager
Added missing license from WebPage
Diffstat (limited to 'src')
-rw-r--r-- | src/browser.cpp | 37 | ||||
-rw-r--r-- | src/lib/downloads/downloadswidget.cpp | 6 | ||||
-rw-r--r-- | src/lib/downloads/downloadswidget.h | 2 | ||||
-rw-r--r-- | src/main.cpp | 15 | ||||
-rw-r--r-- | src/webengine/webpage.cpp | 8 | ||||
-rw-r--r-- | src/webengine/webpage.h | 8 | ||||
-rw-r--r-- | src/webengine/webview.cpp | 3 |
7 files changed, 35 insertions, 44 deletions
diff --git a/src/browser.cpp b/src/browser.cpp index f4cadb5..7a169e9 100644 --- a/src/browser.cpp +++ b/src/browser.cpp @@ -57,12 +57,14 @@ void Browser::loadProfiles() for(const QString &name : profileList) { std::shared_ptr<WebEngineProfile> profile = std::make_shared<WebEngineProfile>(name, profileDir.absoluteFilePath(name), nullptr); profile->setRequestInterceptor(m_urlRequestInterceptor.get()); + connect(profile.get(), &WebEngineProfile::downloadRequested, m_downloadManager.get(), &DownloadsWidget::addDownload); m_profiles.insert(name, profile); } // Also add the Off-the-record profile std::shared_ptr<WebEngineProfile> otr = std::make_shared<WebEngineProfile>(nullptr); otr->setRequestInterceptor(m_urlRequestInterceptor.get()); + connect(otr.get(), &WebEngineProfile::downloadRequested, m_downloadManager.get(), &DownloadsWidget::addDownload); m_profiles.insert("", otr); // set default profile @@ -73,41 +75,6 @@ void Browser::loadProfiles() #endif } -/* -std::shared_ptr<BookmarksWidget> &Browser::bookmarks() -{ - Q_ASSERT(m_bookmarksManager); - return m_bookmarksManager; -} - -std::shared_ptr<DownloadsWidget> &Browser::downloads() -{ - Q_ASSERT(m_downloadManager); - return m_downloadManager; -} - -BlockerManager *Browser::blocklists() -{ - if(!m_blocklistManager) { - m_blocklistManager = new BlockerManager(); - } - return m_blocklistManager; -} - -MainWindow *Browser::activeWindow() -{ - if(m_windows.empty()) { - return nullptr; - } - - for(auto it = m_windows.cbegin(); it != m_windows.cend(); it++) { - if(it->data()->isActiveWindow()) { - return it->data(); - } - } - return m_windows.first().data(); -}*/ - MainWindow *Browser::createWindow() { // the window will delete itself when it closes, so we don't need to delete it diff --git a/src/lib/downloads/downloadswidget.cpp b/src/lib/downloads/downloadswidget.cpp index 0022ff9..460014f 100644 --- a/src/lib/downloads/downloadswidget.cpp +++ b/src/lib/downloads/downloadswidget.cpp @@ -16,7 +16,7 @@ #include <QLabel> #include "widgets/downloaditemwidget.h" -DownloadsWidget::DownloadsWidget(const QString path, QWidget *parent) : +DownloadsWidget::DownloadsWidget(const QString &downloadPath, QWidget *parent) : QWidget(parent), ui(new Ui::DownloadDialog) { @@ -27,15 +27,13 @@ DownloadsWidget::DownloadsWidget(const QString path, QWidget *parent) : ui->setupUi(this); ui->filePath->setWordWrap(true); - m_downloadPath = path; + m_downloadPath = downloadPath; connect(ui->listWidget, SIGNAL(currentRowChanged(int)), this, SLOT(showItemDetails(int))); } DownloadsWidget::~DownloadsWidget() { - qDebug("Destroying DownloadsManager"); - delete ui; } diff --git a/src/lib/downloads/downloadswidget.h b/src/lib/downloads/downloadswidget.h index a6dcf71..a601147 100644 --- a/src/lib/downloads/downloadswidget.h +++ b/src/lib/downloads/downloadswidget.h @@ -21,7 +21,7 @@ class DownloadsWidget : public QWidget Q_OBJECT public: - explicit DownloadsWidget(const QString path, QWidget *parent = 0); + explicit DownloadsWidget(const QString &downloadPath, QWidget *parent = nullptr); ~DownloadsWidget(); public slots: diff --git a/src/main.cpp b/src/main.cpp index 8e5edb0..7433cc8 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -10,6 +10,8 @@ #include "browser.h" #include <QCommandLineParser> #include <QFile> +#include <QFileInfo> +#include <QDir> #include <QStandardPaths> #include "mainwindow.h" @@ -109,6 +111,8 @@ int main(int argc, char *argv[]) return 0; } + // TODO: check for other instances + std::shared_ptr<Configuration> config = std::make_shared<Configuration>(); config->readDefaultConfiguration(readConfig(parser.value(defaultConfigOption))); config->readUserConfiguration(parser.value(configOption).toStdString()); @@ -122,6 +126,14 @@ int main(int argc, char *argv[]) path = QStandardPaths::writableLocation(QStandardPaths::AppConfigLocation) + "/smolbote.cfg"; } + QDir configDir = QFileInfo(path).absoluteDir(); + if(!configDir.exists()) { + bool mkpathSuccess = configDir.mkpath("."); +#ifdef QT_DEBUG + qDebug("mkpath %s: %s", qUtf8Printable(configDir.absolutePath()), mkpathSuccess ? "ok" : "failed"); +#endif + } + #ifdef QT_DEBUG qDebug("Generating user config on first run to %s", qUtf8Printable(path)); #endif @@ -134,9 +146,6 @@ int main(int argc, char *argv[]) } instance.setConfiguration(config); - - // TODO: instance check - instance.loadProfiles(); MainWindow* mainWindow = instance.createWindow(); diff --git a/src/webengine/webpage.cpp b/src/webengine/webpage.cpp index 79ba809..a39c942 100644 --- a/src/webengine/webpage.cpp +++ b/src/webengine/webpage.cpp @@ -1,3 +1,11 @@ +/* + * This file is part of smolbote. It's copyrighted by the contributors recorded + * in the version control history of the file, available from its original + * location: git://neueland.iserlohn-fortress.net/smolbote.git + * + * SPDX-License-Identifier: GPL-3.0 + */ + #include "webpage.h" WebPage::WebPage(QWebEngineProfile *profile, QObject *parent) : diff --git a/src/webengine/webpage.h b/src/webengine/webpage.h index 6ae0802..ffbe34d 100644 --- a/src/webengine/webpage.h +++ b/src/webengine/webpage.h @@ -1,3 +1,11 @@ +/* + * This file is part of smolbote. It's copyrighted by the contributors recorded + * in the version control history of the file, available from its original + * location: git://neueland.iserlohn-fortress.net/smolbote.git + * + * SPDX-License-Identifier: GPL-3.0 + */ + #ifndef WEBPAGE_H #define WEBPAGE_H diff --git a/src/webengine/webview.cpp b/src/webengine/webview.cpp index 4f7b386..55efad7 100644 --- a/src/webengine/webview.cpp +++ b/src/webengine/webview.cpp @@ -130,7 +130,8 @@ QMenu *WebView::pageMenu() void WebView::setPage(WebPage *page) { Q_CHECK_PTR(page); - //this->page()->deleteLater(); + // make sure the page gets cleaned up if we replace it by taking ownership + page->setParent(this); connect(page, &WebPage::linkHovered, this, &WebView::handleLinkHovered); connect(page, &WebPage::certificateErrorMessage, this, &WebView::handleCertificateError); QWebEngineView::setPage(page); |