Fix flatpak properly

This commit is contained in:
dada513 2022-03-27 12:43:49 +02:00
parent 81b50c0387
commit 3672dbc5af
No known key found for this signature in database
GPG Key ID: 403448C14FA4B33E
4 changed files with 62 additions and 6 deletions

View File

@ -582,6 +582,8 @@ SET(LAUNCHER_SOURCES
ApplicationMessage.cpp ApplicationMessage.cpp
# GUI - general utilities # GUI - general utilities
Flatpak.h
Flatpak.cpp
DesktopServices.h DesktopServices.h
DesktopServices.cpp DesktopServices.cpp
VersionProxyModel.h VersionProxyModel.h

View File

@ -3,6 +3,7 @@
#include <QDesktopServices> #include <QDesktopServices>
#include <QProcess> #include <QProcess>
#include <QDebug> #include <QDebug>
#include "Flatpak.h"
/** /**
* This shouldn't exist, but until QTBUG-9328 and other unreported bugs are fixed, it needs to be a thing. * This shouldn't exist, but until QTBUG-9328 and other unreported bugs are fixed, it needs to be a thing.
@ -84,7 +85,14 @@ bool openDirectory(const QString &path, bool ensureExists)
return QDesktopServices::openUrl(QUrl::fromLocalFile(dir.absolutePath())); return QDesktopServices::openUrl(QUrl::fromLocalFile(dir.absolutePath()));
}; };
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD) #if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
if(!Flatpak::IsFlatpak())
{
return IndirectOpen(f); return IndirectOpen(f);
}
else
{
return f();
}
#else #else
return f(); return f();
#endif #endif
@ -98,7 +106,14 @@ bool openFile(const QString &path)
return QDesktopServices::openUrl(QUrl::fromLocalFile(path)); return QDesktopServices::openUrl(QUrl::fromLocalFile(path));
}; };
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD) #if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
if(!Flatpak::IsFlatpak())
{
return IndirectOpen(f); return IndirectOpen(f);
}
else
{
return f();
}
#else #else
return f(); return f();
#endif #endif
@ -109,10 +124,17 @@ bool openFile(const QString &application, const QString &path, const QString &wo
qDebug() << "Opening file" << path << "using" << application; qDebug() << "Opening file" << path << "using" << application;
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD) #if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
// FIXME: the pid here is fake. So if something depends on it, it will likely misbehave // FIXME: the pid here is fake. So if something depends on it, it will likely misbehave
if(!Flatpak::IsFlatpak())
{
return IndirectOpen([&]() return IndirectOpen([&]()
{ {
return QProcess::startDetached(application, QStringList() << path, workingDirectory); return QProcess::startDetached(application, QStringList() << path, workingDirectory);
}, pid); }, pid);
}
else
{
return QProcess::startDetached(application, QStringList() << path, workingDirectory, pid);
}
#else #else
return QProcess::startDetached(application, QStringList() << path, workingDirectory, pid); return QProcess::startDetached(application, QStringList() << path, workingDirectory, pid);
#endif #endif
@ -122,11 +144,18 @@ bool run(const QString &application, const QStringList &args, const QString &wor
{ {
qDebug() << "Running" << application << "with args" << args.join(' '); qDebug() << "Running" << application << "with args" << args.join(' ');
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD) #if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
if(!Flatpak::IsFlatpak())
{
// FIXME: the pid here is fake. So if something depends on it, it will likely misbehave // FIXME: the pid here is fake. So if something depends on it, it will likely misbehave
return IndirectOpen([&]() return IndirectOpen([&]()
{ {
return QProcess::startDetached(application, args, workingDirectory); return QProcess::startDetached(application, args, workingDirectory);
}, pid); }, pid);
}
else
{
return QProcess::startDetached(application, args, workingDirectory, pid);
}
#else #else
return QProcess::startDetached(application, args, workingDirectory, pid); return QProcess::startDetached(application, args, workingDirectory, pid);
#endif #endif
@ -140,7 +169,14 @@ bool openUrl(const QUrl &url)
return QDesktopServices::openUrl(url); return QDesktopServices::openUrl(url);
}; };
#if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD) #if defined(Q_OS_LINUX) || defined(Q_OS_FREEBSD)
if(!Flatpak::IsFlatpak())
{
return IndirectOpen(f); return IndirectOpen(f);
}
else
{
return f();
}
#else #else
return f(); return f();
#endif #endif

14
launcher/Flatpak.cpp Normal file
View File

@ -0,0 +1,14 @@
#include <QFileInfo>
namespace Flatpak
{
bool IsFlatpak()
{
#ifdef Q_OS_LINUX
QFileInfo check_file("/.flatpak-info");
return check_file.exists();
#else
return false;
#endif
}
}

4
launcher/Flatpak.h Normal file
View File

@ -0,0 +1,4 @@
namespace Flatpak
{
bool IsFlatpak();
}