diff options
| -rw-r--r-- | cmake/VendorConfig.cmake | 53 | ||||
| -rw-r--r-- | lib/about/aboutplugin.cpp | 87 | ||||
| -rw-r--r-- | lib/about/aboutplugin.h | 31 | ||||
| -rw-r--r-- | lib/about/aboutplugin.ui | 179 | ||||
| -rw-r--r-- | lib/about/meson.build | 6 | ||||
| -rw-r--r-- | src/browser.cpp | 39 | ||||
| -rw-r--r-- | src/mainwindow/mainwindow.ui | 8 | 
7 files changed, 333 insertions, 70 deletions
| diff --git a/cmake/VendorConfig.cmake b/cmake/VendorConfig.cmake deleted file mode 100644 index bb88eec..0000000 --- a/cmake/VendorConfig.cmake +++ /dev/null @@ -1,53 +0,0 @@ -find_package(PythonInterp 3.2 REQUIRED) - -string(TOLOWER ${CMAKE_SYSTEM_NAME} SYSTEM_NAME) - -if (NOT EXISTS "${PROJECT_SOURCE_DIR}/${SYSTEM_NAME}/.config") -    message(FATAL_ERROR "No vendor config for ${SYSTEM_NAME}: ${PROJECT_SOURCE_DIR}/${SYSTEM_NAME}/.config is missing") -endif() -# there is a .config in ${PROJECT_SOURCE_DIR}/${SYSTEM_NAME}/.config - -function(config KEY KCONFIG) -execute_process( -    COMMAND ${PYTHON_EXECUTABLE} "${PROJECT_SOURCE_DIR}/tools/config.py" "--kconfig=${PROJECT_SOURCE_DIR}/${KCONFIG}" "--dotconfig=${PROJECT_SOURCE_DIR}/${SYSTEM_NAME}/.config" ${KEY} -    WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE output OUTPUT_STRIP_TRAILING_WHITESPACE) -    set("CONFIG_${KEY}" ${output} PARENT_SCOPE) -endfunction() - -config("POI_NAME"   "src/Kconfig") -config("POI_EXE"    "src/Kconfig") - -config("INSTALL_BINDIR" "Kconfig") -config("INSTALL_LIBDIR" "Kconfig") -config("INSTALL_PLUGINDIR" "Kconfig") -config("INSTALL_APPDIR" "Kconfig") -config("INSTALL_ICONDIR" "Kconfig") - -add_custom_command(OUTPUT "${PROJECT_BINARY_DIR}/include/config.h" -    COMMAND ${CMAKE_COMMAND} -E make_directory "${PROJECT_BINARY_DIR}/include" -    COMMAND ${CMAKE_COMMAND} -E env "srctree=${PROJECT_SOURCE_DIR}" -            ${PYTHON_EXECUTABLE} "${PROJECT_SOURCE_DIR}/tools/Kconfiglib/genconfig.py" "--header-path=${PROJECT_BINARY_DIR}/include/config.h" "${PROJECT_SOURCE_DIR}/src/Kconfig" -    WORKING_DIRECTORY "${PROJECT_SOURCE_DIR}/${SYSTEM_NAME}") - -add_custom_target(config_header DEPENDS "${PROJECT_BINARY_DIR}/include/config.h") - -# QTBUG defines -execute_process( -    COMMAND ${PYTHON_EXECUTABLE} "${PROJECT_SOURCE_DIR}/tools/config.py" "--kconfig=${PROJECT_SOURCE_DIR}/src/Kconfig" "--dotconfig=${PROJECT_SOURCE_DIR}/${SYSTEM_NAME}/.config" "QTBUG" -    WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE QTBUGS OUTPUT_STRIP_TRAILING_WHITESPACE) -foreach(bug IN LISTS QTBUGS) -    set(${bug} CACHE STRING "${bug} workaround") -endforeach() - - -## Version information, used in src/version.h.in -if (EXISTS "${PROJECT_SOURCE_DIR}/.git") -    execute_process(COMMAND git rev-list --count HEAD       WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VerRevision OUTPUT_STRIP_TRAILING_WHITESPACE) -    execute_process(COMMAND git rev-parse --short HEAD      WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VerShortId  OUTPUT_STRIP_TRAILING_WHITESPACE) -    execute_process(COMMAND git rev-parse HEAD              WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VerCommit   OUTPUT_STRIP_TRAILING_WHITESPACE) -    execute_process(COMMAND git rev-parse --abbrev-ref HEAD WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VerBranch   OUTPUT_STRIP_TRAILING_WHITESPACE) -endif() - -set(poi_Version     "r${VerRevision}"               CACHE STRING "Short version string") -set(poi_Describe    "r${VerRevision}-${VerShortId}" CACHE STRING "Long version string") -set(poi_Build       "${VerBranch}-${VerCommit}"     CACHE STRING "Build string") diff --git a/lib/about/aboutplugin.cpp b/lib/about/aboutplugin.cpp new file mode 100644 index 0000000..7df75fa --- /dev/null +++ b/lib/about/aboutplugin.cpp @@ -0,0 +1,87 @@ +/* + * 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: https://neueland.iserlohn-fortress.net/gitea/aqua/smolbote + * + * SPDX-License-Identifier: GPL-3.0 + */ + +#include "aboutplugin.h" +#include "ui_aboutplugin.h" +#include <QJsonArray> +#include <QPluginLoader> + +QTreeWidgetItem *createItem(const QString &key, const QJsonValue &json, QTreeWidgetItem *parent) +{ +    auto *item = new QTreeWidgetItem(parent, { key, QLatin1Literal("---") }); + +    switch(json.type()) { +    case QJsonValue::Bool: +        item->setText(1, json.toBool() ? QLatin1Literal("true") : QLatin1Literal("false")); +        break; + +    case QJsonValue::Double: +        item->setText(1, QString::number(json.toDouble())); +        break; + +    case QJsonValue::String: +        item->setText(1, json.toString()); +        break; + +    case QJsonValue::Array: +        item->setText(1, QString()); +        for(const QJsonValue &v : json.toArray()) { +            createItem(QString(), v, item); +        } +        break; + +    case QJsonValue::Object: +        item->setText(1, QString()); +        for(const QString &k : json.toObject().keys()) { +            createItem(k, json.toObject()[k], item); +        } +        break; + +    case QJsonValue::Null: +        item->setText(1, QLatin1Literal("null")); +        break; + +    case QJsonValue::Undefined: +        item->setText(1, QLatin1Literal("undefined")); +        break; +    } + +    return item; +} + +AboutPluginDialog::AboutPluginDialog(const QPluginLoader *loader, QWidget *parent) +    : QDialog(parent) +    , ui(new Ui::AboutPluginDialog) +{ +    setAttribute(Qt::WA_DeleteOnClose, true); +    ui->setupUi(this); + +    auto metaData = loader->metaData()["MetaData"].toObject(); + +    this->setWindowTitle(metaData["name"].toString()); + +    ui->path->setText(loader->fileName()); +    ui->loaded->setChecked(loader->isLoaded()); + +    ui->name->setText(metaData[QLatin1Literal("name")].toString()); +    ui->author->setText(metaData[QLatin1Literal("author")].toString()); +    ui->license->setText(metaData[QLatin1Literal("license")].toString()); +    ui->shortcut->setText(metaData[QLatin1Literal("shortcut")].toString()); + +    for(const QString &key : loader->metaData().keys()) { +        auto *i = createItem(key, loader->metaData()[key], nullptr); + +        if(i != nullptr) +            ui->details_treeWidget->insertTopLevelItem(0, i); +    } +} + +AboutPluginDialog::~AboutPluginDialog() +{ +    delete ui; +} diff --git a/lib/about/aboutplugin.h b/lib/about/aboutplugin.h new file mode 100644 index 0000000..adab215 --- /dev/null +++ b/lib/about/aboutplugin.h @@ -0,0 +1,31 @@ +/* + * 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: https://neueland.iserlohn-fortress.net/gitea/aqua/smolbote + * + * SPDX-License-Identifier: GPL-3.0 + */ + +#ifndef SMOLBOTE_ABOUTPLUGIN_H +#define SMOLBOTE_ABOUTPLUGIN_H + +#include <QDialog> + +namespace Ui +{ +class AboutPluginDialog; +} +class QPluginLoader; +class AboutPluginDialog : public QDialog +{ +    Q_OBJECT + +public: +    explicit AboutPluginDialog(const QPluginLoader *loader, QWidget *parent = nullptr); +    ~AboutPluginDialog() override; + +private: +    Ui::AboutPluginDialog *ui; +}; + +#endif // SMOLBOTE_ABOUTPLUGIN_H diff --git a/lib/about/aboutplugin.ui b/lib/about/aboutplugin.ui new file mode 100644 index 0000000..f2d4848 --- /dev/null +++ b/lib/about/aboutplugin.ui @@ -0,0 +1,179 @@ +<?xml version="1.0" encoding="UTF-8"?> +<ui version="4.0"> + <class>AboutPluginDialog</class> + <widget class="QDialog" name="AboutPluginDialog"> +  <property name="geometry"> +   <rect> +    <x>0</x> +    <y>0</y> +    <width>474</width> +    <height>329</height> +   </rect> +  </property> +  <property name="windowTitle"> +   <string>Dialog</string> +  </property> +  <layout class="QVBoxLayout" name="verticalLayout"> +   <item> +    <widget class="QTabWidget" name="tabWidget"> +     <property name="currentIndex"> +      <number>0</number> +     </property> +     <widget class="QWidget" name="general_tab"> +      <attribute name="title"> +       <string>General</string> +      </attribute> +      <layout class="QFormLayout" name="formLayout"> +       <item row="0" column="0"> +        <widget class="QLabel" name="name_label"> +         <property name="text"> +          <string>Name</string> +         </property> +        </widget> +       </item> +       <item row="0" column="1"> +        <widget class="QLabel" name="name"> +         <property name="text"> +          <string/> +         </property> +        </widget> +       </item> +       <item row="1" column="0"> +        <widget class="QLabel" name="author_label"> +         <property name="text"> +          <string>Author</string> +         </property> +        </widget> +       </item> +       <item row="1" column="1"> +        <widget class="QLabel" name="author"> +         <property name="text"> +          <string/> +         </property> +        </widget> +       </item> +       <item row="3" column="0"> +        <widget class="QLabel" name="shortcut_label"> +         <property name="text"> +          <string>Shortcut</string> +         </property> +        </widget> +       </item> +       <item row="3" column="1"> +        <widget class="QLabel" name="shortcut"> +         <property name="text"> +          <string/> +         </property> +        </widget> +       </item> +       <item row="4" column="1"> +        <layout class="QHBoxLayout" name="controls_layout"> +         <item> +          <widget class="QPushButton" name="loaded"> +           <property name="enabled"> +            <bool>false</bool> +           </property> +           <property name="text"> +            <string>Load</string> +           </property> +           <property name="checkable"> +            <bool>true</bool> +           </property> +          </widget> +         </item> +        </layout> +       </item> +       <item row="2" column="1"> +        <widget class="QLabel" name="license"> +         <property name="text"> +          <string/> +         </property> +        </widget> +       </item> +       <item row="2" column="0"> +        <widget class="QLabel" name="license_label"> +         <property name="text"> +          <string>License</string> +         </property> +        </widget> +       </item> +      </layout> +     </widget> +     <widget class="QWidget" name="details_tab"> +      <attribute name="title"> +       <string>Details</string> +      </attribute> +      <layout class="QVBoxLayout" name="verticalLayout_2"> +       <item> +        <widget class="QLabel" name="path"> +         <property name="text"> +          <string>TextLabel</string> +         </property> +        </widget> +       </item> +       <item> +        <widget class="QTreeWidget" name="details_treeWidget"> +         <column> +          <property name="text"> +           <string>Key</string> +          </property> +         </column> +         <column> +          <property name="text"> +           <string>Value</string> +          </property> +         </column> +        </widget> +       </item> +      </layout> +     </widget> +    </widget> +   </item> +   <item> +    <widget class="QDialogButtonBox" name="buttonBox"> +     <property name="orientation"> +      <enum>Qt::Horizontal</enum> +     </property> +     <property name="standardButtons"> +      <set>QDialogButtonBox::Close</set> +     </property> +    </widget> +   </item> +  </layout> + </widget> + <resources/> + <connections> +  <connection> +   <sender>buttonBox</sender> +   <signal>accepted()</signal> +   <receiver>AboutPluginDialog</receiver> +   <slot>accept()</slot> +   <hints> +    <hint type="sourcelabel"> +     <x>248</x> +     <y>254</y> +    </hint> +    <hint type="destinationlabel"> +     <x>157</x> +     <y>274</y> +    </hint> +   </hints> +  </connection> +  <connection> +   <sender>buttonBox</sender> +   <signal>rejected()</signal> +   <receiver>AboutPluginDialog</receiver> +   <slot>reject()</slot> +   <hints> +    <hint type="sourcelabel"> +     <x>316</x> +     <y>260</y> +    </hint> +    <hint type="destinationlabel"> +     <x>286</x> +     <y>274</y> +    </hint> +   </hints> +  </connection> + </connections> +</ui> diff --git a/lib/about/meson.build b/lib/about/meson.build index 35598b3..961c7ef 100644 --- a/lib/about/meson.build +++ b/lib/about/meson.build @@ -1,11 +1,11 @@  about_moc = qt5.preprocess( -    moc_headers: ['aboutdialog.h'], -    ui_files: ['aboutdialog.ui'], +    moc_headers: ['aboutdialog.h', 'aboutplugin.h'], +    ui_files: ['aboutdialog.ui', 'aboutplugin.ui'],      dependencies: dep_qt5  )  about_inc = include_directories('.') -about_lib = static_library('about', ['aboutdialog.cpp', about_moc], +about_lib = static_library('about', ['aboutdialog.cpp', 'aboutplugin.cpp', about_moc],      dependencies: [dep_qt5, dep_genheaders]  ) diff --git a/src/browser.cpp b/src/browser.cpp index 8ff8616..0bd3d06 100644 --- a/src/browser.cpp +++ b/src/browser.cpp @@ -7,11 +7,21 @@   */  #include "browser.h" +#include "aboutdialog.h" +#include "aboutplugin.h"  #include "addressbar.h" +#include "bookmarkswidget.h" +#include "config.h" +#include "configuration.h" +#include "downloadswidget.h"  #include "mainwindow/mainwindow.h" +#include "profilemanager.h"  #include "subwindow/subwindow.h" +#include "ui_mainwindow.h"  #include "util.h" +#include "webengine/filter.h"  #include "webengine/urlinterceptor.h" +#include "webprofile.h"  #include <QAction>  #include <QDir>  #include <QFileInfo> @@ -20,18 +30,9 @@  #include <QJsonDocument>  #include <QPluginLoader>  #include <QTimer> -#include "aboutdialog.h" -#include "bookmarkswidget.h" -#include "configuration.h" -#include "downloadswidget.h" -#include <version.h> -#include "profilemanager.h" -#include "webprofile.h" -#include "webengine/filter.h" -#include <QPluginLoader> -#include <plugininterface.h> -#include "config.h"  #include <QVersionNumber> +#include <plugininterface.h> +#include <version.h>  Browser::Browser(int &argc, char *argv[], bool allowSecondary)      : SingleApplication(argc, argv, allowSecondary, SingleApplication::User | SingleApplication::SecondaryNotification | SingleApplication::ExcludeAppVersion) @@ -69,12 +70,12 @@ const QStringList Browser::configurationOptions() const      return options;  } -const QString Browser::configuration(const QString& key) const +const QString Browser::configuration(const QString &key) const  {      return m_config->value<QString>(qUtf8Printable(key)).value_or(QString());  } -void Browser::setConfiguration(const QString& key, const QString& value) +void Browser::setConfiguration(const QString &key, const QString &value)  {      m_config->setValue(qUtf8Printable(key), value);  } @@ -223,6 +224,18 @@ MainWindow *Browser::createWindow()      connect(window->addressBar, &AddressBar::complete, m_bookmarks.get(), &BookmarksWidget::search);      connect(window, &MainWindow::createBookmark, m_bookmarks.get(), &BookmarksWidget::addBookmark); +    connect(window->ui->menuTools, &QMenu::aboutToShow, this, [this, window]() { +        window->ui->menuPlugins->clear(); + +        for(const QPluginLoader *l : m_plugins) { +            auto *action = window->ui->menuPlugins->addAction(l->metaData()[QLatin1String("MetaData")].toObject()[QLatin1String("name")].toString()); +            connect(action, &QAction::triggered, this, [l, window]() { +                auto *dlg = new AboutPluginDialog(l, window); +                dlg->exec(); +            }); +        } +    }); +      auto *bookmarksAction = new QAction(tr("Bookmarks"), window);      m_config->setShortcut(bookmarksAction, "bookmarks.shortcut");      connect(bookmarksAction, &QAction::triggered, window, [this, window]() { diff --git a/src/mainwindow/mainwindow.ui b/src/mainwindow/mainwindow.ui index cb6d39e..ad213c6 100644 --- a/src/mainwindow/mainwindow.ui +++ b/src/mainwindow/mainwindow.ui @@ -20,7 +20,7 @@       <x>0</x>       <y>0</y>       <width>800</width> -     <height>23</height> +     <height>30</height>      </rect>     </property>     <widget class="QMenu" name="menusmolbote"> @@ -55,6 +55,12 @@      <property name="title">       <string>Too&ls</string>      </property> +    <widget class="QMenu" name="menuPlugins"> +     <property name="title"> +      <string>&Plugins</string> +     </property> +    </widget> +    <addaction name="menuPlugins"/>     </widget>     <widget class="QMenu" name="menuPage">      <property name="title"> | 
