mirror of
https://invent.kde.org/system/dolphin
synced 2024-10-28 03:21:56 +00:00
Dolphin Service Installer: Run uninstall scripts, rename methods
Summary: Now scripts starting with `uninstall` are being executed. Addtionally the `runInstallerScriptOnce` method has been renamed, because it is used to run the install/uninstall scripts. Same for `runInstallerScript`. Depends on D28801 Test Plan: Compile, run tests. Try to uninstall a dolphin service which has a uninstall.sh script. Reviewers: #dolphin, ngraham, nicolasfella, elvisangelaccio Reviewed By: #dolphin, elvisangelaccio Subscribers: cfeck, kfm-devel Tags: #dolphin Differential Revision: https://phabricator.kde.org/D28836
This commit is contained in:
parent
76f9d9a5f5
commit
5bbdf66fce
|
@ -126,7 +126,7 @@ QString findRecursive(const QString &dir, const QString &basename)
|
||||||
return QString();
|
return QString();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool runInstallerScriptOnce(const QString &path, const QStringList &args)
|
bool runScriptOnce(const QString &path, const QStringList &args)
|
||||||
{
|
{
|
||||||
QProcess process;
|
QProcess process;
|
||||||
process.setWorkingDirectory(QFileInfo(path).absolutePath());
|
process.setWorkingDirectory(QFileInfo(path).absolutePath());
|
||||||
|
@ -152,7 +152,7 @@ bool runInstallerScriptOnce(const QString &path, const QStringList &args)
|
||||||
|
|
||||||
// If hasArgVariants is true, run "path".
|
// If hasArgVariants is true, run "path".
|
||||||
// If hasArgVariants is false, run "path argVariants[i]" until successful.
|
// If hasArgVariants is false, run "path argVariants[i]" until successful.
|
||||||
bool runInstallerScript(const QString &path, bool hasArgVariants, const QStringList &argVariants, QString &errorText)
|
bool runScriptVariants(const QString &path, bool hasArgVariants, const QStringList &argVariants, QString &errorText)
|
||||||
{
|
{
|
||||||
QFile file(path);
|
QFile file(path);
|
||||||
if (!file.setPermissions(QFile::ReadOwner | QFile::WriteOwner | QFile::ExeOwner)) {
|
if (!file.setPermissions(QFile::ReadOwner | QFile::WriteOwner | QFile::ExeOwner)) {
|
||||||
|
@ -163,11 +163,11 @@ bool runInstallerScript(const QString &path, bool hasArgVariants, const QStringL
|
||||||
qInfo() << "[servicemenuinstaller]: Trying to run installer/uninstaller" << path;
|
qInfo() << "[servicemenuinstaller]: Trying to run installer/uninstaller" << path;
|
||||||
if (hasArgVariants) {
|
if (hasArgVariants) {
|
||||||
for (const auto &arg : argVariants) {
|
for (const auto &arg : argVariants) {
|
||||||
if (runInstallerScriptOnce(path, {arg})) {
|
if (runScriptOnce(path, {arg})) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (runInstallerScriptOnce(path, {})) {
|
} else if (runScriptOnce(path, {})) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -232,7 +232,7 @@ bool cmdInstall(const QString &archive, QString &errorText)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!installItPath.isEmpty()) {
|
if (!installItPath.isEmpty()) {
|
||||||
return runInstallerScript(installItPath, false, QStringList{}, errorText);
|
return runScriptVariants(installItPath, false, QStringList{}, errorText);
|
||||||
}
|
}
|
||||||
|
|
||||||
// If "install-it" is missing, try "install"
|
// If "install-it" is missing, try "install"
|
||||||
|
@ -247,7 +247,7 @@ bool cmdInstall(const QString &archive, QString &errorText)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!installerPath.isEmpty()) {
|
if (!installerPath.isEmpty()) {
|
||||||
return runInstallerScript(installerPath, true, {"--local", "--local-install", "--install"}, errorText);
|
return runScriptVariants(installerPath, true, {"--local", "--local-install", "--install"}, errorText);
|
||||||
}
|
}
|
||||||
|
|
||||||
fail(i18n("Failed to find an installation script in %1", dir));
|
fail(i18n("Failed to find an installation script in %1", dir));
|
||||||
|
@ -272,7 +272,7 @@ bool cmdUninstall(const QString &archive, QString &errorText)
|
||||||
|
|
||||||
// Try "deinstall" first
|
// Try "deinstall" first
|
||||||
QString deinstallPath;
|
QString deinstallPath;
|
||||||
const QStringList basenames1 = {"deinstall.sh", "deinstall"};
|
const QStringList basenames1 = {"uninstall.sh", "uninstal", "deinstall.sh", "deinstall"};
|
||||||
for (const auto &basename : basenames1) {
|
for (const auto &basename : basenames1) {
|
||||||
const auto path = findRecursive(dir, basename);
|
const auto path = findRecursive(dir, basename);
|
||||||
if (!path.isEmpty()) {
|
if (!path.isEmpty()) {
|
||||||
|
@ -282,7 +282,7 @@ bool cmdUninstall(const QString &archive, QString &errorText)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!deinstallPath.isEmpty()) {
|
if (!deinstallPath.isEmpty()) {
|
||||||
const bool ok = runInstallerScript(deinstallPath, false, {}, errorText);
|
const bool ok = runScriptVariants(deinstallPath, false, {}, errorText);
|
||||||
if (!ok) {
|
if (!ok) {
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
@ -300,7 +300,7 @@ bool cmdUninstall(const QString &archive, QString &errorText)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!installerPath.isEmpty()) {
|
if (!installerPath.isEmpty()) {
|
||||||
const bool ok = runInstallerScript(installerPath, true,
|
const bool ok = runScriptVariants(installerPath, true,
|
||||||
{"--remove", "--delete", "--uninstall", "--deinstall"}, errorText);
|
{"--remove", "--delete", "--uninstall", "--deinstall"}, errorText);
|
||||||
if (!ok) {
|
if (!ok) {
|
||||||
return ok;
|
return ok;
|
||||||
|
|
Loading…
Reference in a new issue