Replace hardcoded system plugin directories with list from Qt. (#1814)

This commit is contained in:
karliss 2019-12-12 09:35:25 +02:00 committed by Florian Märkl
parent c255fd1cfd
commit 55017f6ba0
5 changed files with 72 additions and 55 deletions

View File

@ -17,6 +17,7 @@ option(CUTTER_ENABLE_CRASH_REPORTS "Enable crash report system. Unused if CUTTER
tri_option(CUTTER_ENABLE_KSYNTAXHIGHLIGHTING "Use KSyntaxHighlighting" AUTO)
tri_option(CUTTER_ENABLE_GRAPHVIZ "Enable use of graphviz for graph layout" AUTO)
option (option SHIBOKEN_EXTRA_OPTIONS "Extra options for shiboken generator")
set(CUTTER_EXTRA_PLUGIN_DIRS "" CACHE STRING "List of addition plugin locations")
if(NOT CUTTER_ENABLE_PYTHON)
set(CUTTER_ENABLE_PYTHON_BINDINGS OFF)

View File

@ -8,4 +8,6 @@
#define CUTTER_VERSION_FULL \"$${CUTTER_VERSION_MAJOR}.$${CUTTER_VERSION_MINOR}.$${CUTTER_VERSION_PATCH}\"
#define CUTTER_EXTRA_PLUGIN_DIRS \"$${CUTTER_EXTRA_PLUGIN_DIRS}\"
#endif

View File

@ -23,7 +23,7 @@ PluginsOptionsWidget::PluginsOptionsWidget(PreferencesDialog *dialog)
auto dirLabel = new QLabel(this);
dirLabel->setTextInteractionFlags(Qt::TextSelectableByMouse);
layout->addWidget(dirLabel);
dirLabel->setText(tr("Plugins are loaded from <b>%1</b>").arg(Plugins()->getPluginsDirectory()));
dirLabel->setText(tr("Plugins are loaded from <b>%1</b>").arg(Plugins()->getUserPluginsDirectory()));
auto treeWidget = new QTreeWidget(this);
layout->addWidget(treeWidget);

View File

@ -9,6 +9,7 @@
#include "PluginManager.h"
#include "CutterPlugin.h"
#include "CutterConfig.h"
#include <QDir>
#include <QCoreApplication>
@ -30,77 +31,44 @@ PluginManager::~PluginManager()
{
}
QString PluginManager::getPluginsDirectory() const
{
QStringList locations = QStandardPaths::standardLocations(QStandardPaths::AppDataLocation);
if (locations.isEmpty()) {
return QString();
}
QDir pluginsDir(locations.first());
pluginsDir.mkpath("plugins");
if (!pluginsDir.cd("plugins")) {
return QString();
}
return pluginsDir.absolutePath();
}
void PluginManager::loadPlugins()
{
assert(plugins.isEmpty());
QString pluginsDirStr = getPluginsDirectory();
if (pluginsDirStr.isEmpty()) {
qCritical() << "Failed to get a path to load plugins from.";
return;
QString userPluginDir = getUserPluginsDirectory();
if (!userPluginDir.isEmpty()) {
loadPluginsFromDir(QDir(userPluginDir), true);
}
loadPluginsFromDir(QDir(pluginsDirStr));
#ifdef Q_OS_WIN
{
QDir appDir;
appDir.mkdir("plugins");
if (appDir.cd("plugins")) {
loadPluginsFromDir(appDir);
const auto pluginDirs = getPluginDirectories();
for (auto &dir : pluginDirs) {
if (dir.absolutePath() == userPluginDir) {
continue;
}
loadPluginsFromDir(dir);
}
#endif
#ifdef APPIMAGE
{
auto plugdir = QDir(QCoreApplication::applicationDirPath()); // appdir/bin
plugdir.cdUp(); // appdir
if (plugdir.cd("share/RadareOrg/Cutter/plugins")) { // appdir/share/RadareOrg/Cutter/plugins
loadPluginsFromDir(plugdir);
}
}
#endif
#ifdef Q_OS_MACOS
{
auto plugdir = QDir(QCoreApplication::applicationDirPath()); // Contents/MacOS
plugdir.cdUp(); // Contents
if (plugdir.cd("Resources/plugins")) { // Contents/Resources/plugins
loadPluginsFromDir(plugdir);
}
}
#endif
}
void PluginManager::loadPluginsFromDir(const QDir &pluginsDir)
void PluginManager::loadPluginsFromDir(const QDir &pluginsDir, bool writable)
{
qInfo() << "Plugins are loaded from" << pluginsDir.absolutePath();
int loadedPlugins = plugins.length();
if (!pluginsDir.exists()) {
return;
}
QDir nativePluginsDir = pluginsDir;
nativePluginsDir.mkdir("native");
if (writable) {
nativePluginsDir.mkdir("native");
}
if (nativePluginsDir.cd("native")) {
loadNativePlugins(nativePluginsDir);
}
#ifdef CUTTER_ENABLE_PYTHON_BINDINGS
QDir pythonPluginsDir = pluginsDir;
pythonPluginsDir.mkdir("python");
if (writable) {
pythonPluginsDir.mkdir("python");
}
if (pythonPluginsDir.cd("python")) {
loadPythonPlugins(pythonPluginsDir.absolutePath());
}
@ -110,7 +78,6 @@ void PluginManager::loadPluginsFromDir(const QDir &pluginsDir)
qInfo() << "Loaded" << loadedPlugins << "plugin(s).";
}
void PluginManager::destroyPlugins()
{
for (CutterPlugin *plugin : plugins) {
@ -119,6 +86,52 @@ void PluginManager::destroyPlugins()
}
}
QVector<QDir> PluginManager::getPluginDirectories() const
{
QVector<QDir> result;
QStringList locations = QStandardPaths::standardLocations(QStandardPaths::AppDataLocation);
for (auto &location : locations) {
result.push_back(QDir(location).filePath("plugins"));
}
#ifdef APPIMAGE
{
auto plugdir = QDir(QCoreApplication::applicationDirPath()); // appdir/bin
plugdir.cdUp(); // appdir
if (plugdir.cd("share/RadareOrg/Cutter/plugins")) { // appdir/share/RadareOrg/Cutter/plugins
result.push_back(plugdir);
}
}
#endif
#if QT_VERSION < QT_VERSION_CHECK(5, 6, 0) && defined(Q_OS_UNIX)
QChar listSeparator = ':';
#else
QChar listSeparator = QDir::listSeparator();
#endif
QString extra_plugin_dirs = CUTTER_EXTRA_PLUGIN_DIRS;
for (auto& path : extra_plugin_dirs.split(listSeparator, QString::SplitBehavior::SkipEmptyParts)) {
result.push_back(QDir(path));
}
return result;
}
QString PluginManager::getUserPluginsDirectory() const
{
QString location = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation);
if (location.isEmpty()) {
return QString();
}
QDir pluginsDir(location);
pluginsDir.mkpath("plugins");
if (!pluginsDir.cd("plugins")) {
return QString();
}
return pluginsDir.absolutePath();
}
void PluginManager::loadNativePlugins(const QDir &directory)
{
for (const QString &fileName : directory.entryList(QDir::Files)) {

View File

@ -29,13 +29,14 @@ public:
const QList<CutterPlugin *> &getPlugins() { return plugins; }
QString getPluginsDirectory() const;
QVector<QDir> getPluginDirectories() const;
QString getUserPluginsDirectory() const;
private:
QList<CutterPlugin *> plugins;
void loadNativePlugins(const QDir &directory);
void loadPluginsFromDir(const QDir &pluginsDir);
void loadPluginsFromDir(const QDir &pluginsDir, bool writable = false);
#ifdef CUTTER_ENABLE_PYTHON_BINDINGS
void loadPythonPlugins(const QDir &directory);