From fa6304204ed1c1b2193310c04bd15730e550b3d4 Mon Sep 17 00:00:00 2001 From: nephros Date: Fri, 26 May 2023 09:23:28 +0200 Subject: [PATCH 01/13] if auto applying succeded, save a known good state --- .../patchmanager-daemon/patchmanagerobject.cpp | 15 +++++++++++++++ src/bin/patchmanager-daemon/patchmanagerobject.h | 3 +++ 2 files changed, 18 insertions(+) diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index 67eb2218f..0e58481eb 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -359,6 +359,17 @@ void PatchManagerObject::setAppliedPatches(const QSet &patches) putSettings(QStringLiteral("applied"), QStringList(patches.toList())); } + +QSet PatchManagerObject::getLastGoodPatches() const +{ + return getSettings(QStringLiteral("lastknowngood"), QStringList()).toStringList().toSet(); +} + +void PatchManagerObject::setLastGoodPatches(const QSet &patches) +{ + putSettings(QStringLiteral("lastknowngood"), QStringList(patches.toList())); +} + QStringList PatchManagerObject::getMangleCandidates() { if (m_mangleCandidates.empty()) { @@ -592,6 +603,10 @@ void PatchManagerObject::doPrepareCacheRoot() emit m_adaptor->autoApplyingFinished(success); } + if (success) { + setLastGoodPatches(m_appliedPatches); + } + if (!success) { setAppliedPatches(m_appliedPatches); refreshPatchList(); diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.h b/src/bin/patchmanager-daemon/patchmanagerobject.h index 7f262f4d9..f086aaed1 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.h +++ b/src/bin/patchmanager-daemon/patchmanagerobject.h @@ -216,6 +216,9 @@ private slots: QSet getAppliedPatches() const; void setAppliedPatches(const QSet &patches); + QSet getLastGoodPatches() const; + void setLastGoodPatches(const QSet &patches); + void getVersion(); void lateInitialize(); From eca3be2330e96c28482b74044cc1a89e02b9a20d Mon Sep 17 00:00:00 2001 From: nephros Date: Fri, 26 May 2023 09:40:44 +0200 Subject: [PATCH 02/13] Add option to load last-know-good patch list Contributes-To: #277 --- .../dbus/org.SfietKonstantin.patchmanager.xml | 3 +++ src/bin/patchmanager-daemon/patchmanagerobject.cpp | 6 ++++++ src/bin/patchmanager-daemon/patchmanagerobject.h | 1 + src/qml/PatchManagerPage.qml | 6 ++++++ src/qml/patchmanager.cpp | 7 +++++++ src/qml/patchmanager.h | 1 + 6 files changed, 24 insertions(+) diff --git a/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml b/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml index ae7e5b198..faa50d9c5 100644 --- a/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml +++ b/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml @@ -107,6 +107,9 @@ + + + diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index 0e58481eb..f7665a473 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -1586,6 +1586,12 @@ bool PatchManagerObject::getLoaded() const return m_serverThread->isRunning(); } +void PatchManagerObject::revertToLastGood() +{ + m_appliedPatches = getLastGoodPatches(); + setAppliedPatches(m_appliedPatches); +} + /*! Reset internal failure state and re-initialize. diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.h b/src/bin/patchmanager-daemon/patchmanagerobject.h index f086aaed1..61a5e024d 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.h +++ b/src/bin/patchmanager-daemon/patchmanagerobject.h @@ -129,6 +129,7 @@ public slots: bool getFailure() const; bool getLoaded() const; void resolveFailure(); + void revertToLastGood(); void loadRequest(bool apply); void lipstickChanged(const QString &state); diff --git a/src/qml/PatchManagerPage.qml b/src/qml/PatchManagerPage.qml index 4bae477ef..b126fd31f 100644 --- a/src/qml/PatchManagerPage.qml +++ b/src/qml/PatchManagerPage.qml @@ -239,6 +239,12 @@ Page { onClicked: pageStack.push(Qt.resolvedUrl("RestartServicesDialog.qml")) } + MenuItem { + text: qsTranslate("", "Load Pre-Failure List") + visible: PatchManager.failure + onClicked: menuRemorse.execute( text, function() { PatchManager.call(PatchManager.revertToLastGood()) } ) + } + MenuItem { text: qsTranslate("", "Resolve failure") visible: PatchManager.failure diff --git a/src/qml/patchmanager.cpp b/src/qml/patchmanager.cpp index 17a780c58..54d4aeda4 100644 --- a/src/qml/patchmanager.cpp +++ b/src/qml/patchmanager.cpp @@ -817,6 +817,13 @@ void PatchManager::onLoadedChanged(bool loaded) emit loadedChanged(m_loaded); } +void PatchManager::revertToLastGood() +{ + qDebug() << Q_FUNC_INFO; + + m_interface->revertToLastGood(); +} + /*! Calls the \e resolveFailure method on D-Bus */ void PatchManager::resolveFailure() { diff --git a/src/qml/patchmanager.h b/src/qml/patchmanager.h index 5f1e72bfa..dd6e4ae4b 100644 --- a/src/qml/patchmanager.h +++ b/src/qml/patchmanager.h @@ -182,6 +182,7 @@ public slots: void onFailureChanged(bool failed); void onLoadedChanged(bool loaded); + void revertToLastGood(); void resolveFailure(); signals: From 60e374c6fc4f650cf9424230864385e9e4b1c8d4 Mon Sep 17 00:00:00 2001 From: nephros Date: Fri, 26 May 2023 10:19:18 +0200 Subject: [PATCH 03/13] Add call to save current set as KnownGood --- .../dbus/org.SfietKonstantin.patchmanager.xml | 3 +++ src/bin/patchmanager-daemon/patchmanagerobject.cpp | 5 +++++ src/bin/patchmanager-daemon/patchmanagerobject.h | 1 + src/qml/patchmanager.cpp | 7 +++++++ src/qml/patchmanager.h | 1 + 5 files changed, 17 insertions(+) diff --git a/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml b/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml index faa50d9c5..a220ac7e7 100644 --- a/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml +++ b/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml @@ -110,6 +110,9 @@ + + + diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index f7665a473..8ff3348ad 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -370,6 +370,11 @@ void PatchManagerObject::setLastGoodPatches(const QSet &patches) putSettings(QStringLiteral("lastknowngood"), QStringList(patches.toList())); } +void PatchManagerObject::setKnownGood() +{ + setLastGoodPatches(getAppliedPatches()); +} + QStringList PatchManagerObject::getMangleCandidates() { if (m_mangleCandidates.empty()) { diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.h b/src/bin/patchmanager-daemon/patchmanagerobject.h index 61a5e024d..71ccaa1d2 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.h +++ b/src/bin/patchmanager-daemon/patchmanagerobject.h @@ -219,6 +219,7 @@ private slots: QSet getLastGoodPatches() const; void setLastGoodPatches(const QSet &patches); + void setKnownGood(); void getVersion(); diff --git a/src/qml/patchmanager.cpp b/src/qml/patchmanager.cpp index 54d4aeda4..c917fcf41 100644 --- a/src/qml/patchmanager.cpp +++ b/src/qml/patchmanager.cpp @@ -824,6 +824,13 @@ void PatchManager::revertToLastGood() m_interface->revertToLastGood(); } +void PatchManager::setKnownGood() +{ + qDebug() << Q_FUNC_INFO; + + m_interface->setKnownGood(); +} + /*! Calls the \e resolveFailure method on D-Bus */ void PatchManager::resolveFailure() { diff --git a/src/qml/patchmanager.h b/src/qml/patchmanager.h index dd6e4ae4b..d69623a4c 100644 --- a/src/qml/patchmanager.h +++ b/src/qml/patchmanager.h @@ -182,6 +182,7 @@ public slots: void onFailureChanged(bool failed); void onLoadedChanged(bool loaded); + void setKnownGood(); void revertToLastGood(); void resolveFailure(); From 3c5e4b45f3d05a4b8cf85dc1df89fd555a98ff53 Mon Sep 17 00:00:00 2001 From: nephros Date: Fri, 26 May 2023 10:27:46 +0200 Subject: [PATCH 04/13] Add "save as good" to command line options --- src/bin/patchmanager-daemon/main.cpp | 1 + src/bin/patchmanager-daemon/patchmanagerobject.cpp | 2 ++ src/tools/patchmanager-tool | 6 ++++++ 3 files changed, 9 insertions(+) diff --git a/src/bin/patchmanager-daemon/main.cpp b/src/bin/patchmanager-daemon/main.cpp index 8176d7689..094c25872 100644 --- a/src/bin/patchmanager-daemon/main.cpp +++ b/src/bin/patchmanager-daemon/main.cpp @@ -61,6 +61,7 @@ void help() std::cout << " patchmanager -a : Enable and activate a Patch" << std::endl; std::cout << " patchmanager -u : Deactivate and disable (unapply) a Patch" << std::endl; std::cout << " patchmanager --unapply-all : Deactivate and disable (unapply) all Patches" << std::endl; + std::cout << " patchmanager --save-as-good : Save list of enabled Patches as 'known good'" << std::endl; std::cout << " patchmanager --daemon : Start Patchmanager as daemon" << std::endl; } diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index 8ff3348ad..eab029cba 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -1133,6 +1133,8 @@ void PatchManagerObject::process() } } else if (args[1] == QStringLiteral("--unapply-all")) { method = QStringLiteral("unapplyAllPatches"); + } else if (args[1] == QStringLiteral("--save-as-good")) { + method = QStringLiteral("setKnownGood"); } else { return; } diff --git a/src/tools/patchmanager-tool b/src/tools/patchmanager-tool index d79931614..4a47f761e 100644 --- a/src/tools/patchmanager-tool +++ b/src/tools/patchmanager-tool @@ -23,6 +23,7 @@ function usage() { printf "\t-A | --activate-all\t\tActivate / apply all Patches formerly marked as active.\n" printf "\t-d | --deactivate\t\tDeactivate / unapply Patches from list or file (via -f).\n" printf "\t-D | --deactivate-all\t\tDeactivate / unapply all Patches.\n" + printf "\t-S | --save-as-good\t\tSave list of enabled Patches as 'known good'\n" printf "\t-f | --file \t\tUse for the list of Patches.\n" printf "\t-e | --export\t\t\tExport list of Patches marked as active either to STDout or (via -f) to a file.\n" printf "\t-? | --help\t\t\tPrint this help.\n" @@ -93,6 +94,11 @@ case "$1" in shift surplus "$*" ;; + -S|--save-as-good) + operation="--save-as-good" + shift + surplus "$*" + ;; --reset-system) operation="--reset-system" shift From 40455217901f2ead0831b102e53549dd724d5254 Mon Sep 17 00:00:00 2001 From: nephros Date: Fri, 26 May 2023 12:14:20 +0200 Subject: [PATCH 05/13] Add "load known-good" to command line options --- src/bin/patchmanager-daemon/main.cpp | 1 + src/bin/patchmanager-daemon/patchmanagerobject.cpp | 2 ++ src/tools/patchmanager-tool | 6 ++++++ 3 files changed, 9 insertions(+) diff --git a/src/bin/patchmanager-daemon/main.cpp b/src/bin/patchmanager-daemon/main.cpp index 094c25872..9dbd90706 100644 --- a/src/bin/patchmanager-daemon/main.cpp +++ b/src/bin/patchmanager-daemon/main.cpp @@ -62,6 +62,7 @@ void help() std::cout << " patchmanager -u : Deactivate and disable (unapply) a Patch" << std::endl; std::cout << " patchmanager --unapply-all : Deactivate and disable (unapply) all Patches" << std::endl; std::cout << " patchmanager --save-as-good : Save list of enabled Patches as 'known good'" << std::endl; + std::cout << " patchmanager --load-known-good : Enable 'known good' Patches" << std::endl; std::cout << " patchmanager --daemon : Start Patchmanager as daemon" << std::endl; } diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index eab029cba..15e55d1e9 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -1135,6 +1135,8 @@ void PatchManagerObject::process() method = QStringLiteral("unapplyAllPatches"); } else if (args[1] == QStringLiteral("--save-as-good")) { method = QStringLiteral("setKnownGood"); + } else if (args[1] == QStringLiteral("--load-known-good")) { + method = QStringLiteral("revertToLastGood"); } else { return; } diff --git a/src/tools/patchmanager-tool b/src/tools/patchmanager-tool index 4a47f761e..97e5eb9eb 100644 --- a/src/tools/patchmanager-tool +++ b/src/tools/patchmanager-tool @@ -24,6 +24,7 @@ function usage() { printf "\t-d | --deactivate\t\tDeactivate / unapply Patches from list or file (via -f).\n" printf "\t-D | --deactivate-all\t\tDeactivate / unapply all Patches.\n" printf "\t-S | --save-as-good\t\tSave list of enabled Patches as 'known good'\n" + printf "\t-G | --load-known-good\t\tEnable 'known good' Patches\n" printf "\t-f | --file \t\tUse for the list of Patches.\n" printf "\t-e | --export\t\t\tExport list of Patches marked as active either to STDout or (via -f) to a file.\n" printf "\t-? | --help\t\t\tPrint this help.\n" @@ -99,6 +100,11 @@ case "$1" in shift surplus "$*" ;; + -G|) + operation="--load-known-good" + shift + surplus "$*" + ;; --reset-system) operation="--reset-system" shift From 8bfb85a7e28c887edcbe576c45a9a813c527d065 Mon Sep 17 00:00:00 2001 From: nephros Date: Fri, 26 May 2023 12:14:47 +0200 Subject: [PATCH 06/13] [trivial] whitespace-align help output --- src/bin/patchmanager-daemon/main.cpp | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/bin/patchmanager-daemon/main.cpp b/src/bin/patchmanager-daemon/main.cpp index 9dbd90706..73a954af4 100644 --- a/src/bin/patchmanager-daemon/main.cpp +++ b/src/bin/patchmanager-daemon/main.cpp @@ -57,13 +57,13 @@ void help() { std::cout << "Patchmanager " << BUILD_VERSION << std::endl; std::cout << "Usage:" << std::endl; - std::cout << " patchmanager [--help] : Print this help text" << std::endl; - std::cout << " patchmanager -a : Enable and activate a Patch" << std::endl; - std::cout << " patchmanager -u : Deactivate and disable (unapply) a Patch" << std::endl; - std::cout << " patchmanager --unapply-all : Deactivate and disable (unapply) all Patches" << std::endl; - std::cout << " patchmanager --save-as-good : Save list of enabled Patches as 'known good'" << std::endl; + std::cout << " patchmanager [--help] : Print this help text" << std::endl; + std::cout << " patchmanager -a : Enable and activate a Patch" << std::endl; + std::cout << " patchmanager -u : Deactivate and disable (unapply) a Patch" << std::endl; + std::cout << " patchmanager --unapply-all : Deactivate and disable (unapply) all Patches" << std::endl; + std::cout << " patchmanager --save-as-good : Save list of enabled Patches as 'known good'" << std::endl; std::cout << " patchmanager --load-known-good : Enable 'known good' Patches" << std::endl; - std::cout << " patchmanager --daemon : Start Patchmanager as daemon" << std::endl; + std::cout << " patchmanager --daemon : Start Patchmanager as daemon" << std::endl; } int main(int argc, char **argv) From 6d66b6c3eecc886d60920431ccbc42a87f252ce5 Mon Sep 17 00:00:00 2001 From: nephros Date: Fri, 26 May 2023 12:24:11 +0200 Subject: [PATCH 07/13] only set good patches if we have any --- src/bin/patchmanager-daemon/patchmanagerobject.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index 15e55d1e9..a49f44e6a 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -359,7 +359,6 @@ void PatchManagerObject::setAppliedPatches(const QSet &patches) putSettings(QStringLiteral("applied"), QStringList(patches.toList())); } - QSet PatchManagerObject::getLastGoodPatches() const { return getSettings(QStringLiteral("lastknowngood"), QStringList()).toStringList().toSet(); @@ -1597,8 +1596,11 @@ bool PatchManagerObject::getLoaded() const void PatchManagerObject::revertToLastGood() { - m_appliedPatches = getLastGoodPatches(); - setAppliedPatches(m_appliedPatches); + QSet patches = getLastGoodPatches(); + if (!patches.empty()) { + m_appliedPatches = patches; + setAppliedPatches(patches); + } } /*! From 3bce11414cbff5b59ffb5e80299a828105d5c50a Mon Sep 17 00:00:00 2001 From: nephros Date: Fri, 26 May 2023 12:24:40 +0200 Subject: [PATCH 08/13] refresh after setting good list --- src/bin/patchmanager-daemon/patchmanagerobject.cpp | 1 + 1 file changed, 1 insertion(+) diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index a49f44e6a..2cabc6b0e 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -1600,6 +1600,7 @@ void PatchManagerObject::revertToLastGood() if (!patches.empty()) { m_appliedPatches = patches; setAppliedPatches(patches); + refreshPatchList(); } } From 46d8031cb2ba126ca04777c689bf65f011cc3aea Mon Sep 17 00:00:00 2001 From: nephros Date: Thu, 1 Jun 2023 08:29:02 +0200 Subject: [PATCH 09/13] [tool]: fix syntax --- src/tools/patchmanager-tool | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/tools/patchmanager-tool b/src/tools/patchmanager-tool index 97e5eb9eb..188e46934 100644 --- a/src/tools/patchmanager-tool +++ b/src/tools/patchmanager-tool @@ -100,7 +100,7 @@ case "$1" in shift surplus "$*" ;; - -G|) + -G|--load-known-good) operation="--load-known-good" shift surplus "$*" From 4e7ed8b7b4dfae7384cd89265e15a09df8c8ae63 Mon Sep 17 00:00:00 2001 From: nephros Date: Sun, 23 Jul 2023 18:14:58 +0200 Subject: [PATCH 10/13] [Doc] document the new functions --- .../patchmanager-daemon/patchmanagerobject.cpp | 17 +++++++++++++++-- src/qml/patchmanager.cpp | 2 ++ 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index 2cabc6b0e..296c6ccbf 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -343,7 +343,7 @@ void PatchManagerObject::notify(const QString &patch, NotifyAction action) /*! Returns the list of applied patches via getSettings(). - \sa getSettings(), getSettings(), setAppliedPatches() + \sa putSettings(), setAppliedPatches() */ QSet PatchManagerObject::getAppliedPatches() const { @@ -352,23 +352,35 @@ QSet PatchManagerObject::getAppliedPatches() const /*! Saves the list of applied \a patches via \c putSettings(). - \sa getSettings(), getSettings(), getAppliedPatches() + \sa getSettings(), getAppliedPatches() */ void PatchManagerObject::setAppliedPatches(const QSet &patches) { putSettings(QStringLiteral("applied"), QStringList(patches.toList())); } +/*! + Returns the list of successfully automatically applied \a patches via \c getSettings(). + \sa putSettings(), setLastKnownGood() +*/ QSet PatchManagerObject::getLastGoodPatches() const { return getSettings(QStringLiteral("lastknowngood"), QStringList()).toStringList().toSet(); } +/*! + Saves the list of successfully automatically applied \a patches via \c putSettings(). + \sa getSettings(), getSettings(), getLastKnownGood() +*/ void PatchManagerObject::setLastGoodPatches(const QSet &patches) { putSettings(QStringLiteral("lastknowngood"), QStringList(patches.toList())); } +/*! + Saves the list of currently applied \a patches as "Last Known Good" via \c getLastKnownGood(). + \sa getSettings(), getSettings(), getLastKnownGood() +*/ void PatchManagerObject::setKnownGood() { setLastGoodPatches(getAppliedPatches()); @@ -1594,6 +1606,7 @@ bool PatchManagerObject::getLoaded() const return m_serverThread->isRunning(); } +/*! Loads the list of "Last Known Good" patches if available, and applies them. */ void PatchManagerObject::revertToLastGood() { QSet patches = getLastGoodPatches(); diff --git a/src/qml/patchmanager.cpp b/src/qml/patchmanager.cpp index c917fcf41..52d091777 100644 --- a/src/qml/patchmanager.cpp +++ b/src/qml/patchmanager.cpp @@ -817,6 +817,7 @@ void PatchManager::onLoadedChanged(bool loaded) emit loadedChanged(m_loaded); } +/*! Calls the \e revertToLastGood method on D-Bus */ void PatchManager::revertToLastGood() { qDebug() << Q_FUNC_INFO; @@ -824,6 +825,7 @@ void PatchManager::revertToLastGood() m_interface->revertToLastGood(); } +/*! Calls the \e setKnownGood method on D-Bus */ void PatchManager::setKnownGood() { qDebug() << Q_FUNC_INFO; From 1ff36b2e535ba129c74d9fc21b2ddb7e072ee8af Mon Sep 17 00:00:00 2001 From: nephros Date: Sun, 23 Jul 2023 18:25:36 +0200 Subject: [PATCH 11/13] [Doc] document the new settings key --- src/index.qdoc | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/index.qdoc b/src/index.qdoc index 65d1d60ad..2edfd5664 100644 --- a/src/index.qdoc +++ b/src/index.qdoc @@ -304,6 +304,11 @@ \li empty \li stores the list of "activated" patches \row + \li lastknowngood + \li list of strings, comma-separated + \li empty + \li stores the list of patches, which represent a last-known-good configuration. This is automatically copied from \c applied after a run of autoapply succeeds. + \row \li applyOnBoot \li Boolean \li \c false From b2da29164ad24552b9dd37b8759e38ef186f3d14 Mon Sep 17 00:00:00 2001 From: nephros Date: Mon, 24 Jul 2023 11:50:25 +0200 Subject: [PATCH 12/13] [Doc] document the preparecache functions a bit better I guess they won't show up in the docs because qdoc doesn't care about non-public things, but still, now it's in there. --- .../patchmanagerobject.cpp | 25 +++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index 296c6ccbf..7705a5a35 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -571,6 +571,24 @@ void PatchManagerObject::doRegisterDBus() m_dbusRegistered = true; } +/*! + \fn void PatchManagerObject::prepareCacheRoot() + + Despite its name does not actually prepare the cache root. + Instead, this is tha main "auto apply" function. + + \list + \li first, apply all enabled patches which are listend in the \l{order}{inifile} settings key. + \li second, apply all enabled patches which remain (if any). + \li if applying any patch fails, the local \c success variable will be set to \c false, but the applying will continue. + \li at the end of the process, if \c success is \c true, calls setLastGoodPatches() + \li at the end of the process, if \c success is \c false, calls refreshPatchList() + \endlist +() + Emits signals \c autoApplyingStarted(), \c autoApplyingPatch(), \c autoApplyingFailed(), autoApplyingFinished(), depending on state. + + \sa PatchManagerObject::doPrepareCache(), {Patchmanager Configuration Files}, inifile, refreshPatchList(), setLastGoodPatches() +*/ void PatchManagerObject::doPrepareCacheRoot() { qDebug() << Q_FUNC_INFO; @@ -631,10 +649,13 @@ void PatchManagerObject::doPrepareCacheRoot() /*! \fn void PatchManagerObject::doPrepareCache(const QString &patchName, bool apply = true) - \fn void PatchManagerObject::prepareCacheRoot() Creates the cache directory where patched files will be stored - and read from when passed to the preload library + and read from when passed to the preload library. + + \c It will create the cache for the Patch \a patchName, and optionally \a apply it. + + \sa PatchManagerObject::prepareCacheRoot() */ void PatchManagerObject::doPrepareCache(const QString &patchName, bool apply) { From 578fd806ea0129b68354fb092200474a79358e92 Mon Sep 17 00:00:00 2001 From: olf Date: Mon, 14 Aug 2023 12:36:02 +0200 Subject: [PATCH 13/13] Rename both new methods to `backupWorkingPatchList` and `restorePatchList` (#6) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * [org.SfietKonstantin.patchmanager.xml] Rename both new methods … to `backupWorkingPatchList` and `restorePatchList` Reference: https://github.com/sailfishos-patches/patchmanager/pull/437#issuecomment-1650825008 * [patchmanagerobject.cpp] First round of name changes * [patchmanagerobject.h] Carry out all name changes * [patchmanager.cpp] Carry out all name changes * [patchmanager.h] Carry out all name changes * [org.SfietKonstantin.patchmanager.xml] Fix accidentally swapped names * [PatchManagerPage.qml] Carry out all name changes * [patchmanager-tool] Carry out all name changes * [main.cpp] Carry out all name changes ¿Is the masking of the **"** with **\** correct in C++? * [PatchManagerPage.qml] Enhance wording of menu entry Better, but still not really good, IMO. Issue is, it must be terse enough to fit in a single line in portrait orientation on a Jolla 1 (i.e., 540 pixels width)! * [index.qdoc] Overhaul Sorry, I became carried away: Originally I only adjusted the original lines 307 & 310, then started fixing a few typos, enhanced a few phrases etc. etc. and ended up in going over the whole file. Open points: - Line 110: "\uicontrol" Is this correct markup? Does the sentence make sense this way? - Line 161: "\badcode" Is this correct markup? - Line 225: "In this state, all enabled services are disabled, and PM must be reactivated via the GUI." "Patches" instead of "services"? - Line 289: "\warning" Not "Warning"? I.e., is it a markup term? * [patchmanagerobject.cpp] Complete name changes Questions: - Was capitalising "\c Patches" in line 372 O.K.? - Is the "\sa" in line 373 correct? * [patchmanagerobject.cpp] Try to rectify comments lines 344 - 387 Please review thoroughly! It became obvious, that some copy&paste flaws existed, but I am not sure, if I rectified them correctly. I simply assumed that the code is correct, but maybe (unlikely) the documentation mismatch was the other way around. * [patchmanagerobject.cpp] Complete name changes & overhaul Notes / questions: - Line 587: "()"? Function name missing? - Line 1103: "on the bus" -> "on D-Bus"? - Line 1198: Ambiguous, especially the second "all". - Line 1705: Not better "/sa" instead of "See also"? - Line 2121: Is that an accidentally deleted comment: Check `git blame` * [patchmanagerobject.cpp] Revert over-eagerly applied capitalisation * [index.qdoc] Two minor rectifications of yesterday's work * [index.qdoc] Fix ambiguosity and missing "that" in line 120 * [index.qdoc] Enhance lines 124 and 135 a little bit * [index.qdoc] More minor fixes * [index.qdoc] Even moere small fixes * [index.qdoc] More nitpicks * [index.qdoc] Rectify broken sentence, detected and forgotten multiple times --- .../dbus/org.SfietKonstantin.patchmanager.xml | 4 +- src/bin/patchmanager-daemon/main.cpp | 4 +- .../patchmanagerobject.cpp | 195 +++++++++--------- .../patchmanager-daemon/patchmanagerobject.h | 8 +- src/index.qdoc | 158 ++++++-------- src/qml/PatchManagerPage.qml | 4 +- src/qml/patchmanager.cpp | 12 +- src/qml/patchmanager.h | 4 +- src/tools/patchmanager-tool | 12 +- 9 files changed, 183 insertions(+), 218 deletions(-) diff --git a/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml b/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml index a220ac7e7..b024cc97c 100644 --- a/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml +++ b/src/bin/patchmanager-daemon/dbus/org.SfietKonstantin.patchmanager.xml @@ -107,10 +107,10 @@ - + - + diff --git a/src/bin/patchmanager-daemon/main.cpp b/src/bin/patchmanager-daemon/main.cpp index 73a954af4..86ccadd45 100644 --- a/src/bin/patchmanager-daemon/main.cpp +++ b/src/bin/patchmanager-daemon/main.cpp @@ -61,8 +61,8 @@ void help() std::cout << " patchmanager -a : Enable and activate a Patch" << std::endl; std::cout << " patchmanager -u : Deactivate and disable (unapply) a Patch" << std::endl; std::cout << " patchmanager --unapply-all : Deactivate and disable (unapply) all Patches" << std::endl; - std::cout << " patchmanager --save-as-good : Save list of enabled Patches as 'known good'" << std::endl; - std::cout << " patchmanager --load-known-good : Enable 'known good' Patches" << std::endl; + std::cout << " patchmanager --backup-working : Save list of enabled Patches as \"working\"" << std::endl; + std::cout << " patchmanager --restore-working : Enable backup list of \"working\" Patches" << std::endl; std::cout << " patchmanager --daemon : Start Patchmanager as daemon" << std::endl; } diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.cpp b/src/bin/patchmanager-daemon/patchmanagerobject.cpp index 7705a5a35..ac641110b 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.cpp +++ b/src/bin/patchmanager-daemon/patchmanagerobject.cpp @@ -151,14 +151,14 @@ static const QString KEYBOARD_CODE = QStringLiteral("keyboard"); \class PatchManagerObject \inmodule PatchManagerDaemon - \brief The Patchmanager Daemon. + \brief The Patchmanager daemon. A D-Bus activated background service which manages patch un/installation, listing, de/actvation, and communication with the preload library. - PatchManager is usually launched by its DBus service. + Patchmanager is usually launched by its D-Bus service. The binary can also serve as a simple command-line client to a running - daemon. See the output of \c{patchmanager --help} for more information. + daemon. See the output of \c{patchmanager --help} for more information. */ @@ -178,7 +178,7 @@ static const QString KEYBOARD_CODE = QStringLiteral("keyboard"); \value NotifyActionFailedUnapply unapplying was not successful \value NotifyActionUpdateAvailable - one of the patches has an update + one of the Patches has an update */ QString getLang() @@ -259,7 +259,7 @@ bool PatchManagerObject::makePatch(const QDir &root, const QString &patchPath, Q } /*! - Sends a notification to the user. \a patch is the patch name, \a action one of: + Sends a notification to the user. \a patch is the Patch name, \a action one of: \sa PatchManagerObject::NotifyAction */ void PatchManagerObject::notify(const QString &patch, NotifyAction action) @@ -342,7 +342,7 @@ void PatchManagerObject::notify(const QString &patch, NotifyAction action) } /*! - Returns the list of applied patches via getSettings(). + Returns the list of applied \a patches via \c getSettings(). \sa putSettings(), setAppliedPatches() */ QSet PatchManagerObject::getAppliedPatches() const @@ -351,7 +351,7 @@ QSet PatchManagerObject::getAppliedPatches() const } /*! - Saves the list of applied \a patches via \c putSettings(). + Stores a list of applied \a patches via \c putSettings(). \sa getSettings(), getAppliedPatches() */ void PatchManagerObject::setAppliedPatches(const QSet &patches) @@ -360,30 +360,30 @@ void PatchManagerObject::setAppliedPatches(const QSet &patches) } /*! - Returns the list of successfully automatically applied \a patches via \c getSettings(). - \sa putSettings(), setLastKnownGood() + Returns the list of successfully auto-applied \a patches via \c getSettings(). + \sa putSettings(), setWorkingPatches() */ -QSet PatchManagerObject::getLastGoodPatches() const +QSet PatchManagerObject::getWorkingPatches() const { - return getSettings(QStringLiteral("lastknowngood"), QStringList()).toStringList().toSet(); + return getSettings(QStringLiteral("workingPatches"), QStringList()).toStringList().toSet(); } /*! - Saves the list of successfully automatically applied \a patches via \c putSettings(). - \sa getSettings(), getSettings(), getLastKnownGood() + Stores a list of successfully auto-applied \a patches via \c putSettings(). + \sa getSettings(), getWorkingPatches() */ -void PatchManagerObject::setLastGoodPatches(const QSet &patches) +void PatchManagerObject::setWorkingPatches(const QSet &patches) { - putSettings(QStringLiteral("lastknowngood"), QStringList(patches.toList())); + putSettings(QStringLiteral("workingPatches"), QStringList(patches.toList())); } /*! - Saves the list of currently applied \a patches as "Last Known Good" via \c getLastKnownGood(). - \sa getSettings(), getSettings(), getLastKnownGood() + Stores a list of currently applied \a patches as "last-known-good" / working via \c setWorkingPatches(). + \sa getSettings(), getWorkingPatches() */ -void PatchManagerObject::setKnownGood() +void PatchManagerObject::setWorking() { - setLastGoodPatches(getAppliedPatches()); + setWorkingPatches(getAppliedPatches()); } QStringList PatchManagerObject::getMangleCandidates() @@ -478,7 +478,7 @@ void PatchManagerObject::lateInitialize() // connect(additionalWatcher, &INotifyWatcher::contentChanged, [this](const QString &path, bool created) { // qDebug() << Q_FUNC_INFO << "Content in" << path << "changed; is newly created (bool):" << created; // refreshPatchList(); - // }); +// }); registerDBus(); checkForUpdates(); @@ -574,20 +574,20 @@ void PatchManagerObject::doRegisterDBus() /*! \fn void PatchManagerObject::prepareCacheRoot() - Despite its name does not actually prepare the cache root. - Instead, this is tha main "auto apply" function. + Despite its name, it does not actually prepare the cache root! + Instead, this is the main "auto-apply" function. \list - \li first, apply all enabled patches which are listend in the \l{order}{inifile} settings key. - \li second, apply all enabled patches which remain (if any). - \li if applying any patch fails, the local \c success variable will be set to \c false, but the applying will continue. - \li at the end of the process, if \c success is \c true, calls setLastGoodPatches() - \li at the end of the process, if \c success is \c false, calls refreshPatchList() + \li First, apply all enabled Patches which are listend in the \l{order}{inifile} settings key. + \li Second, apply all enabled Patches which remain (if any). + \li If applying any Patch fails, the local \c success variable will be set to \c false, but the applying run will continue. + \li At the end of the process, if \c success is \c true, calls setWorkingPatches() + \li At the end of the process, if \c success is \c false, calls refreshPatchList() \endlist () Emits signals \c autoApplyingStarted(), \c autoApplyingPatch(), \c autoApplyingFailed(), autoApplyingFinished(), depending on state. - \sa PatchManagerObject::doPrepareCache(), {Patchmanager Configuration Files}, inifile, refreshPatchList(), setLastGoodPatches() + \sa PatchManagerObject::doPrepareCache(), {Patchmanager Configuration Files}, inifile, refreshPatchList(), setWorkingPatches() */ void PatchManagerObject::doPrepareCacheRoot() { @@ -638,7 +638,7 @@ void PatchManagerObject::doPrepareCacheRoot() } if (success) { - setLastGoodPatches(m_appliedPatches); + setWorkingPatches(m_appliedPatches); } if (!success) { @@ -742,7 +742,7 @@ void PatchManagerObject::doPrepareCache(const QString &patchName, bool apply) \fn void PatchManagerObject::doStartLocalServer() \fn void PatchManagerObject::startLocalServer() - Starts the internal Server thread if not already started. + Starts the internal server thread if not already started. Emits \c loadedChanged if successful. */ void PatchManagerObject::doStartLocalServer() @@ -761,13 +761,13 @@ void PatchManagerObject::doStartLocalServer() \fn void PatchManagerObject::initialize() \fn void PatchManagerObject::lateInitialize() - Initialize the engines. + Initialise the engines. - The initialization sequence consists of: + The initialisation sequence comprises: - setting up the patch translator - checking configuration constants and environment - - setting up DBus connections to Lipstick and the Store client + - setting up D-Bus connections to Lipstick and the Store client */ void PatchManagerObject::initialize() @@ -872,7 +872,7 @@ void PatchManagerObject::initialize() m_originalWatcher = new QFileSystemWatcher(this); connect(m_originalWatcher, &QFileSystemWatcher::fileChanged, this, &PatchManagerObject::onOriginalFileChanged); - m_localServer = new QLocalServer(nullptr); // controlled by separate thread + m_localServer = new QLocalServer(nullptr); // controlled by a separate thread m_localServer->setSocketOptions(QLocalServer::WorldAccessOption); m_localServer->setMaxPendingConnections(2147483647); @@ -968,7 +968,7 @@ void PatchManagerObject::doRestartKeyboard() For regular processes, \c killall will be performed on them. - For SystemD services, they will be restarted via D-Bus call, or if that fails, via \c systemctl-user. + Systemd services will be restarted via D-Bus call, or if that fails, via \c systemctl-user. */ void PatchManagerObject::restartService(const QString &serviceName) @@ -1087,7 +1087,7 @@ void PatchManagerObject::clearFakeroot() } /*! - retrieve the RPM name from a full package string + Retrieve the RPM name from a full package string. */ QString PatchManagerObject::getRpmName(const QString &rpm) const { @@ -1097,11 +1097,10 @@ QString PatchManagerObject::getRpmName(const QString &rpm) const } /*! - - handle command line arguments, and maybe daemonize. + Handle command line arguments, and may daemonise. If called with any other argument other than \c --daemon, call a method - coreesponding to the command line option on the bus and exit. + corresponding to the command line option on the bus and exit. Currently supported command line options are: @@ -1113,15 +1112,15 @@ QString PatchManagerObject::getRpmName(const QString &rpm) const \row \li \c -a \li a patch internal name - \li calls the "apply" action for the patch + \li Calls the "apply" action for a Patch. \row \li \c -u \li a patch internal name - \li calls the "unapply" action for the patch + \li Calls the "unapply" action for a Patch. \row \li \c --unapply-all \li \e none - \li calls the "unapply" action for all patches + \li Calls the "unapply" action for all Patches. \endtable */ @@ -1165,10 +1164,10 @@ void PatchManagerObject::process() } } else if (args[1] == QStringLiteral("--unapply-all")) { method = QStringLiteral("unapplyAllPatches"); - } else if (args[1] == QStringLiteral("--save-as-good")) { - method = QStringLiteral("setKnownGood"); - } else if (args[1] == QStringLiteral("--load-known-good")) { - method = QStringLiteral("revertToLastGood"); + } else if (args[1] == QStringLiteral("--backup-working")) { + method = QStringLiteral("backupWorkingPatchList"); + } else if (args[1] == QStringLiteral("--restore-working")) { + method = QStringLiteral("restorePatchList"); } else { return; } @@ -1185,7 +1184,7 @@ void PatchManagerObject::process() } -/*! Retrieves a list of patches via D-Bus. */ +/*! Retrieves a list of Patches via D-Bus. */ QVariantList PatchManagerObject::listPatches() { DBUS_GUARD(QVariantList()) @@ -1195,7 +1194,7 @@ QVariantList PatchManagerObject::listPatches() return QVariantList(); } -/*! Returns all versions contained in all patch metadata. */ +/*! Returns all versions contained in all Patch metadata. */ QVariantMap PatchManagerObject::listVersions() { qDebug() << Q_FUNC_INFO; @@ -1207,7 +1206,7 @@ QVariantMap PatchManagerObject::listVersions() return versionsList; } -/*! Returns whether \a patch is in the list of currently applied patches. */ +/*! Returns whether \a patch is in the list of currently active (applied) Patches. */ bool PatchManagerObject::isPatchApplied(const QString &patch) { qDebug() << Q_FUNC_INFO; @@ -1215,7 +1214,8 @@ bool PatchManagerObject::isPatchApplied(const QString &patch) } /*! - Calls the corresponding method over D-Bus to apply \a patch + Calls the corresponding method over D-Bus to activate (apply) \a patch + \warning This function always returns an empty(!) \c QVariantMap */ QVariantMap PatchManagerObject::applyPatch(const QString &patch) @@ -1235,10 +1235,9 @@ QVariantMap PatchManagerObject::applyPatch(const QString &patch) } /*! - call the corresponding method over D-Bus to unapply \a patch + Call the corresponding method over D-Bus to deactivate (unapply) \a patch Returns a \c QVariantMap with the call results. - */ QVariantMap PatchManagerObject::unapplyPatch(const QString &patch) { @@ -1262,7 +1261,8 @@ QVariantMap PatchManagerObject::unapplyPatch(const QString &patch) } /*! - Calls the corresponding method over D-Bus to unapply all active patches. + Calls the corresponding method over D-Bus to deactivate (unapply) all active Patches. + Returns \c true if successful. */ bool PatchManagerObject::unapplyAllPatches() @@ -1303,9 +1303,9 @@ bool PatchManagerObject::installPatch(const QString &patch, const QString &versi } /*! - Calls the corresponding method over D-Bus to uninstall (delete) \a patch from system. + Calls the corresponding method over D-Bus to remove (uninstall / delete) \a patch. - Returns \c true if uninstallation was successful. + Returns \c true if removal (deinstallation) was successful. */ bool PatchManagerObject::uninstallPatch(const QString &patch) { @@ -1326,7 +1326,7 @@ bool PatchManagerObject::uninstallPatch(const QString &patch) /*! Calls the corresponding method over D-Bus to reset applied state of \a patch - Returns \c true if successful + Returns \c true if successful. \sa doResetPatchState */ @@ -1347,7 +1347,7 @@ bool PatchManagerObject::resetPatchState(const QString &patch) } /*! - Calls the corresponding method over D-Bus to retrieve a vote for patch \a patch + Calls the corresponding method over D-Bus to retrieve a vote for Patch \a patch \link doCheckVote \endlink */ @@ -1363,7 +1363,7 @@ int PatchManagerObject::checkVote(const QString &patch) } /*! - Calls the corresponding method over D-Bus to send a vote of type \a action for patch \a patch. + Calls the corresponding method over D-Bus to send a vote of type \a action for Patch \a patch. \sa sendVote */ @@ -1375,7 +1375,7 @@ void PatchManagerObject::votePatch(const QString &patch, int action) Q_ARG(int, action)); } -/*! an \internal thing, let's not spoil the eggs! */ +/*! An \internal thing, let's not spoil the eggs! */ QString PatchManagerObject::checkEaster() { DBUS_GUARD(QString()) @@ -1385,7 +1385,10 @@ QString PatchManagerObject::checkEaster() return QString(); } -/*! Calls the corresponding method over D-Bus to update the \l {Patchmanager Web Catalog}{Web Catalog} Metadata. \a params stores the connection properties. */ +/*! + Calls the corresponding method over D-Bus to update the \l {Patchmanager Web Catalog}{Web Catalog} + metadata. \a params stores the connection properties. +*/ QVariantList PatchManagerObject::downloadCatalog(const QVariantMap ¶ms) { DBUS_GUARD(QVariantList()) @@ -1398,7 +1401,7 @@ QVariantList PatchManagerObject::downloadCatalog(const QVariantMap ¶ms) } /*! - Calls the corresponding method over D-Bus to download metadata for the patch with the name \a name + Calls the corresponding method over D-Bus to download metadata for a Patch with the name \a name \sa requestDownloadPatchInfo */ @@ -1414,10 +1417,10 @@ QVariantMap PatchManagerObject::downloadPatchInfo(const QString &name) } /*! - Calls the corresponding method over D-Bus to check whether the \l {Patchmanager Web Catalog}{Web Catalog} contains updated patch entries. + Calls the corresponding method over D-Bus to check whether the + \l {Patchmanager Web Catalog}{Web Catalog} contains updated patch entries. \sa requestCheckForUpdates - */ void PatchManagerObject::checkForUpdates() { @@ -1431,10 +1434,11 @@ QVariantMap PatchManagerObject::getUpdates() const return m_updates; } -/*! \fn bool PatchManagerObject::putSettings(const QString &name, const QDBusVariant &value) - \fn bool PatchManagerObject::putSettings(const QString &name, const QVariant &value) +/*! + \fn bool PatchManagerObject::putSettings(const QString &name, const QDBusVariant &value) + \fn bool PatchManagerObject::putSettings(const QString &name, const QVariant &value) - Store setting called \a name to the persistent config, \c s_newConfigLocation, and give it value \a value + Store setting called \a name to the persistent config, \c s_newConfigLocation, and give it value \a value. Returns \c true if successful. */ @@ -1459,10 +1463,11 @@ bool PatchManagerObject::putSettings(const QString &name, const QVariant &value) return false; } -/*! \fn QDBusVariant PatchManagerObject::getSettings(const QString &name, const QDBusVariant &def) - \fn QVariant PatchManagerObject::getSettings(const QString &name, const QVariant &def) const +/*! + \fn QDBusVariant PatchManagerObject::getSettings(const QString &name, const QDBusVariant &def) + \fn QVariant PatchManagerObject::getSettings(const QString &name, const QVariant &def) const - Retrieve a setting called \a name from the persistent config, \c s_newConfigLocation. + Retrieve a setting called \a name from the persistent config, \c s_newConfigLocation Use \a def as the default value if not present. Returns a \c QDBusVariant or \c QVariant if successful. @@ -1482,7 +1487,7 @@ QVariant PatchManagerObject::getSettings(const QString &name, const QVariant &de /*! Compares two dot-separated version strings \a version1 and \a version2, and - returns the semanticly higher one. + returns the semantically higher one. */ QString PatchManagerObject::maxVersion(const QString &version1, const QString &version2) { @@ -1519,13 +1524,12 @@ QString PatchManagerObject::maxVersion(const QString &version1, const QString &v } /*! - Stops, Restarts, or kills running processes belonging to a category which + Stops, restarts, or kills running processes belonging to a category which has been marked as to-be-restarted. For regular processes, \c killall will be performed on them. - For SystemD services, they will be restarted via D-Bus call, or if that fails, via \c systemctl-user. - + Systemd services will be restarted via D-Bus call, or if that fails, via \c systemctl-user. */ void PatchManagerObject::restartServices() { @@ -1576,7 +1580,7 @@ void PatchManagerObject::restartServices() /*! Checks the category of \a patch for membership in a category. - If found appends its service toggles to the service toggle list. + If found, append its service toggles to the service toggle list. */ void PatchManagerObject::patchToggleService(const QString &patch) { @@ -1608,8 +1612,7 @@ QStringList PatchManagerObject::getToggleServicesList() const return m_toggleServices.keys(); } -/*! Returns \c true if whether there are services that should be restarted, \c false otherwise. -*/ +/*! Returns \c true if there are services that should be restarted, \c false otherwise. */ bool PatchManagerObject::getToggleServices() const { return !m_toggleServices.isEmpty(); @@ -1621,16 +1624,16 @@ bool PatchManagerObject::getFailure() const return m_failed; } -/*! Returns the internal state whether the server thread is running. */ +/*! Returns the internal state whether the server thread is running. */ bool PatchManagerObject::getLoaded() const { return m_serverThread->isRunning(); } -/*! Loads the list of "Last Known Good" patches if available, and applies them. */ -void PatchManagerObject::revertToLastGood() +/*! Retrieves the list of "last-known-good" / working Patches if available, and applies them. */ +void PatchManagerObject::restorePatchList() { - QSet patches = getLastGoodPatches(); + QSet patches = getWorkingPatches(); if (!patches.empty()) { m_appliedPatches = patches; setAppliedPatches(patches); @@ -1662,9 +1665,8 @@ void PatchManagerObject::resolveFailure() } /*! - If \a apply is \c true, prepare all internals, start the server, apply all patches and restart Lipstick. - If \a apply is \c false, start the server, unapply all patches. - + If \a apply is \c true, prepare all internals, start the server, activate all enabled Patches and restart Lipstick. + If \a apply is \c false, start the server, deactivate all Patches. */ void PatchManagerObject::loadRequest(bool apply) { @@ -1688,9 +1690,9 @@ void PatchManagerObject::loadRequest(bool apply) } } /*! - D-Bus Method handler. + D-Bus method handler - Called on Lipstick (Re-)Start. Launched the Patchmanager Dialog app (if enabled). + Called on Lipstick (re-)start. Launches the Patchmanager Dialog app (if enabled). \a state passed the Lipstick state: \list @@ -1766,7 +1768,7 @@ QString PatchManagerObject::getOsVersion() const // refreshPatchList(); //} -/*! Return the result of calling \c QObject::eventFilter() on \a watched, \a event */ +/*! Return the result of calling \c QObject::eventFilter() on \a watched, \a event */ bool PatchManagerObject::eventFilter(QObject *watched, QEvent *event) { if (qEnvironmentVariableIsSet("PM_DEBUG_EVENTFILTER")) { @@ -1776,7 +1778,7 @@ bool PatchManagerObject::eventFilter(QObject *watched, QEvent *event) } /*! - Detect a Lipstick crash, assume it was us, clean up and set ourselves into filed state. + Detect a Lipstick crash, assume it was our fault, clean up and set ourselves into failed state. \sa PatchManagerObject::onFailureOccured() \sa PatchManagerObject::FailureOccured() @@ -1949,7 +1951,7 @@ void PatchManagerObject::doRefreshPatchList() { qDebug() << Q_FUNC_INFO; - // Create mangling replacement tokens. + // create mangling replacement tokens QStringList toManglePaths{}, mangledPaths{}; if(getSettings(QStringLiteral("bitnessMangle"), false).toBool()) { toManglePaths = getMangleCandidates(); @@ -2053,7 +2055,7 @@ void PatchManagerObject::doRefreshPatchList() QList patches = listPatchesFromDir(PATCHES_DIR, existingPatches); patches.append(listPatchesFromDir(PATCHES_ADDITIONAL_DIR, existingPatches, false)); qDebug() << Q_FUNC_INFO << "patches:" << patches.count(); -// std::sort(patches.begin(), patches.end(), patchSort); +// std::sort(patches.begin(), patches.end(), patchSort); // fill patch conflicts and rpm names @@ -2154,7 +2156,6 @@ void PatchManagerObject::doListPatches(const QDBusMessage &message) } // for (const QVariantMap &patch : m_metadata) { - // result.append(patch); // } sendMessageReply(message, result); @@ -2230,7 +2231,7 @@ void PatchManagerObject::doPatch(const QVariantMap ¶ms, const QDBusMessage & } } - // is this parameter used anywhere?? + // Is this parameter used anywhere?? if (!params.value(QStringLiteral("dont_notify"), false).toBool()) { if (ok) { bool donotify = getSettings(QStringLiteral("notifyOnSuccess"), true).toBool(); @@ -2252,7 +2253,7 @@ void PatchManagerObject::doPatch(const QVariantMap ¶ms, const QDBusMessage & } /*! - Removes \a patch from list of applied patches. Returns the result in \a message. + Removes \a patch from the list of applied Patches. Returns the result in \a message. \target doResetPatchState */ @@ -2477,7 +2478,7 @@ int PatchManagerObject::getVote(const QString &patch) /*! \target doCheckVote - Send a reply \a message regarding the result or \e getVote() for patch \a patch + Send a reply \a message regarding the result or \e getVote() for Patch \a patch \sa getVote() */ @@ -2490,7 +2491,7 @@ void PatchManagerObject::doCheckVote(const QString &patch, const QDBusMessage &m /*! Submit a vote for patch \a patch. - \a action can be an integet representing an "upvote" or "downvote" (1) + \a action can be an integer representing an "upvote" or "downvote" (1) \target sendVote */ @@ -2668,7 +2669,7 @@ void PatchManagerObject::requestDownloadCatalog(const QVariantMap ¶ms, const } /*! - Retrieve patch metadata from the \l {Patchmanager Web Catalog}{Web Catalog} got patch \a name, reply with message \a message + Retrieve Patch metadata from the \l {Patchmanager Web Catalog}{Web Catalog}, use Patch \a name, reply with message \a message \target requestDownloadPatchInfo */ @@ -2713,9 +2714,9 @@ void PatchManagerObject::requestDownloadPatchInfo(const QString &name, const QDB Connects to the \l {Patchmanager Web Catalog}{Web Catalog} to check for Patch updates. Updates internal state with any results. - Emits updatesAvailable() if yes. + Emits updatesAvailable() if true. - \target requestCheckForUpdates + \target requestCheckForUpdates */ void PatchManagerObject::requestCheckForUpdates() { diff --git a/src/bin/patchmanager-daemon/patchmanagerobject.h b/src/bin/patchmanager-daemon/patchmanagerobject.h index 71ccaa1d2..70a4612f0 100644 --- a/src/bin/patchmanager-daemon/patchmanagerobject.h +++ b/src/bin/patchmanager-daemon/patchmanagerobject.h @@ -129,7 +129,7 @@ public slots: bool getFailure() const; bool getLoaded() const; void resolveFailure(); - void revertToLastGood(); + void restorePatchList(); void loadRequest(bool apply); void lipstickChanged(const QString &state); @@ -217,9 +217,9 @@ private slots: QSet getAppliedPatches() const; void setAppliedPatches(const QSet &patches); - QSet getLastGoodPatches() const; - void setLastGoodPatches(const QSet &patches); - void setKnownGood(); + QSet getWorkingPatches() const; + void setWorkingPatches(const QSet &patches); + void setWorking(); void getVersion(); diff --git a/src/index.qdoc b/src/index.qdoc index 2edfd5664..3b86f03e0 100644 --- a/src/index.qdoc +++ b/src/index.qdoc @@ -10,7 +10,7 @@ \section1 Internals - For information on how PM operates internally, see: + For information on how Patchmanager operates internally, see: \list \li \l {Patchmanager Overview} @@ -20,13 +20,13 @@ \section1 Applications - The Patchmanager project includes the following applications: + The Patchmanager project includes these applications: \section2 GUI Applications \list - \li \l {Patchmanager Documentation: Settings Plugin}{Patchmanager Settings Plugin}, a plugin for the Jolla Settings to launch the application - \li \l {Patchmanager Documentation: QML Plugin}{Patchmanager QML Plugin}, the main UI Application - \li \l {Patchmanager Documentation: Startup Dialog}{Patchmanager Startup Dialog}, a UI shown at Lipstick startup. + \li \l {Patchmanager Documentation: Settings Plugin}{Patchmanager Settings Plugin}, a plugin for the Jolla Settings app to launch the Patchmanager application + \li \l {Patchmanager Documentation: QML Plugin}{Patchmanager QML Plugin}, the main GUI Application + \li \l {Patchmanager Documentation: Startup Dialog}{Patchmanager Startup Dialog}, a GUI shown at Lipstick startup \endlist \section2 Infrastructure Applications @@ -40,58 +40,46 @@ /****** Overview page *******/ /*! - \title Patchmanager Overview + \title Overview of Patchmanager (PM) \page pmoverview.html overview \indexpage Patchmanager Documentation \nextpage {Patchmanager Services} - So the current mode of operation of Patchmanager is something like this: + The workflow of operations Patchmanager performs: \section1 Operation Flow \section2 1. A Patch is "activated" - When a user activates a patch via the App, a signal is sent to the daemon. + When a user activates a Patch via the GUI, a signal is sent to the Patchmanager daemon. The daemon will then: - For each file the patch manipulates, a copy of the original file is put into - a cache dir in \c /tmp, and the changes are applied there instead of on the - original file. + For each file a Patch alters, copy the original file into a cache directory in \c /tmp and apply the changes to this copy instead of the original. + + If paths or files are referenced by a Patch which do not yet exist on the filesystem, these will be created in the cache directory, and symlinks pointing to them are placed in the original filesystem. - If there are paths or files involved in the patch which do not exist yet - in the filesystem, they will be created in the cache dir, and a symlink - pointing to them is placed in the original filesystem. \section2 2. A patched application is launched. - Through library preloading, the \c libpreloadpatchmanager.so library is - injected into the launching binary. + Through library preloading, the \c libpreloadpatchmanager.so library is injected into the launching binary. \section2 3. The Preload Library: \list \li Intercepts calls to \l {https://www.man7.org/linux/man-pages/man2/open.2.html}{\c{open()} (or \c{open64()})}, - \li analyzes which files the call was meant to open - \li asks the Patchmanager daemon (via socket) whether it knows of a patched version. + \li analyses which files the call was meant to open + \li asks the Patchmanager daemon (via socket) if it is aware of a patched version of any of these files. \endlist - If yes, the daemon will return a path to its cachedir, and the library - redirects the call to that file instead of the original. Otherwise, the - \c{open()} is executed on the original file. + If so, the daemon will return a path to its cache directory, and the library redirects the call to that file instead of the original. Otherwise, the \c{open()} call is executed on the original file. - Certain paths are blacklisted for these operations to reduce the risk of - critical services, or PM itself, choking on these redirections. + Certain paths are blacklisted for these operations to reduce the risk of critical services, or the Patchmanager binaries proper, stumbling over these redirections. - \note After activating a Patch , the daemon may also inform the UI that some - apps or services need restart. The UI client is expected to issue the command - to restart these soon. - As long as the corresponding preocesses are not restarted, the effect of the - applied patch will not show, or may only show partially, depending on the "patch - history" of the respective process. + \note After activating a Patch, the Patchmanager daemon may inform the Patchmanager GUI that some apps or services need to be restarted. As long as the corresponding processes are not restarted, the applied Patch will be not at all or only partially in effect, depending on the "patch history" of the respective process. \section1 Patch Installation - There are three ways a Patch can end up on the system: + There are four ways a Patch can be deployed: \list \li Web Catalog @@ -102,52 +90,38 @@ \section2 Patch folder structure - All Patches managed by PM are installed under \c /usr/share/patchmanager/patches/NAME, - where NAME is a directory having a unique name. + All Patches managed by PM are installed under \c /usr/share/patchmanager/patches/NAME with NAME being a uniquely named directory. - That directory must contain at least two files: a \c JSON file called - \c patch.json containing metadata, and a \c diff file called \c{unified_diff.patch}. + This directory must contain at least two files: a \c JSON file called \c patch.json containing metadata, and a \c diff file called \c{unified_diff.patch}. It may optionally also contain: \list \li Qt translation (.qm) files \li icon files in PNG format \li a QML file called \c main.qml (whose root element is a Sailfish Silica \c{Page}). - \li other QML-compatible files which are referenced/loaded from \c main.qml + \li other QML-compatible files which are referenced / loaded from \c main.qml \endlist - \note the directory NAME is usually and by convention the same as the patch - metadata field \c name, but that is not a requirement. NAME should be - reasonably unique though, to avoid name clashes with Patches from others. + \note The directory NAME is usually and by convention the same as the Patch metadata field \c name, but this is not a strict requirement. NAME should be reasonably unique though, in order to avoid naming conflicts with other Patches. \section2 Web Catalog - Installation via the Patchmanager Web Catalog is the most common and recomended way of installing a patch. - This is done through the Patchmanager UI, by selecting \uicontrol install on the \l {WebPatchPage}{Patch Page}. + Installation via Patchmanager's Web Catalog is the most common and recommended way of deploying Patches. + This is carried out in the Patchmanager GUI by selecting \uicontrol install on the \l {WebPatchPage}{Patch Page}. - PM will download metadata and a tarball from the Web Catalog, extract the - tarball into the patch storage location, and generate the necessary JSON file - from the metadata. + PM will download metadata and a tar archive from the Web Catalog, extract the archive into the Patch storage location, and generate the necessary JSON file from the metadata. \section2 RPM package - Patches may be distributed as RPM files, which assure the placement of files - according to the structure explained above. RPM also provides advanced - features like dependencies and scriptlets which may be necessary for correct - operation or installation of a Patch. + Patches may be distributed as RPM files, which assure the placement of files according to the structure explained above. RPM files also provide advanced features as specifying dependencies and scriptlets which may be necessary for the correct operation or installation of a Patch. \section2 TAR package - Patch developers may sometimes distribute Patches in \c tar format. Usually - they also contain the necessary files, but the contents of the tarball may - differ, and recipients of them must assure the layout given above is set up - correctly. + Patch developers may offer a Patch as a "naked" \c tar archive. Although it should contain all necessary files, all checks to assure that the layout and content of the files in the archive are correct must be carried out by the user, in contrast to tar archives uploaded to the Web Catalog. - \section2 manual installation + \section2 Manual installation - Patch developers or users may want to quickly place a Patch under PM's - supervision without going through the hassle of packaging and installing. - This can be done easily, as long as the formats given above are followed. + Patch developers or users may want to quickly place a Patch under PM's supervision without the effort of packaging and installing this Patch properly. This can be easily done, as long the aforementioned requirements are obeyed. \e{to be continued...} @@ -158,8 +132,7 @@ \page pmwc.html - The Web Catalog is currently not maintained by the Patchmanager project, and - is documented here briefly for sake of completeness. + The Web Catalog is currently not maintained by the Patchmanager project proper and hence is only tersely documented here. \e{to be continued...} @@ -183,7 +156,7 @@ \quotefile dbus/org.SfietKonstantin.patchmanager.xml - Calls can be issued e.g. like this: + Calls can be issued this way, for example: \badcode dbus-send --print-reply --system --dest=org.SfietKonstantin.patchmanager /org/SfietKonstantin/patchmanager org.SfietKonstantin.patchmanager.checkforUpdates @@ -201,27 +174,27 @@ \li \c UNITDIR/checkForUpdates-org.SfietKonstantin.patchmanager.service \li service \li - - \li calls the \c checkForUpdates() method via D-Bus + \li Calls the \c checkForUpdates() method via D-Bus. \row \li \c UNITDIR/checkForUpdates-org.SfietKonstantin.patchmanager.timer \li timer \li - - \li runs the service above, every two hours + \li Runs the service above, every two hours. \row \li \c UNITDIR/dbus-org.SfietKonstantin.patchmanager.service \li dbus-activated service \li \l {Patchmanager Documentation: Daemon}{Daemon} - \li starts/activates the D-Bus service + \li Starts / activates the D-Bus service. \row \li \c /var/lib/environment/patchmanager/10-dbus.conf \li environment file \li \l {Patchmanager Documentation: Daemon}{Daemon} - \li Configures the environment the Systemd service is started in. + \li Configures the environment in which the Systemd service is started. \row \li \c /etc/dbus-1/system.d/org.SfietKonstantin.patchmanager.conf \li policy file \li \l {Patchmanager Documentation: Daemon}{Daemon} - \li Configures access policy for the D-Bus service + \li Configures the access policy for the D-Bus service. \endtable \section2 Systemd User Units @@ -235,45 +208,35 @@ \row \li \c $USERUNITDIR/dbus-org.SfietKonstantin.patchmanager.service \li dbus-activated service - \li {Patchmanager Documentation: Startup Dialog}{Dialog} - \li starts the Startup Dialog if necessary + \li \l {Patchmanager Documentation: Startup Dialog}{Dialog} + \li Starts the Startup Dialog, if necessary. \row \li \c $USERUNITDIR/lipstick-patchmanager.service \li service - \li {Patchmanager Documentation: Startup Dialog}{Dialog} - \li calls the \c lipstickChanged() method via D-Bus + \li \l {Patchmanager Documentation: Startup Dialog}{Dialog} + \li Calls the \c lipstickChanged() method via D-Bus. \row \li \c /var/lib/environment/patchmanager-dialog/*.conf \li environment file - \li {Patchmanager Documentation: Startup Dialog}{Dialog} - \li Configures the environment the dialog service is started in. + \li \l {Patchmanager Documentation: Startup Dialog}{Dialog} + \li Configures the environment in which the dialog service is started. \endtable - \c lipstick-patchmanager.service watches the state of the Lipstick service. - If Lipstick crashes, Patchmanager Daemon assumes it was caused by a patch - and goes into \c failed state. In this state, all enabled services are - disabled, and PM must be reactivated via the GUI. + \c lipstick-patchmanager.service watches the state of the Lipstick service. If Lipstick crashes, the Patchmanager daemon assumes it was caused by a Patch and goes into \c failed state. In this state, all enabled services are disabled, and PM must be reactivated via the GUI. \section1 Manual Invocation - Apart from using the appropriate tools manipulating tools like \c systemctl, - \c busctl, or \c dbus-send, the patchmanager binary can serve as a CLI as - well if called from command line. - See the output of \c{patchmanager --help} and PatchManagerObject::process() - for more information. + Aside of using appropriate tools as \c systemctl, \c busctl, or \c dbus-send to invoke Patchmanager's functions, the patchmanager binary can also serve as CLI, if called from command line. See the output of \c{patchmanager --help} and PatchManagerObject::process() for more information. - There is also a shell script called \c patchmanager-tool, wrapping the capabilities of \c patchmanager to generate more useful functions. + Additionally a shell script called \c patchmanager-tool exists, which builds upon the capabilities of \c patchmanager to provide more sophisticated and generic functions. - \note At the time this was written, \c patchmanager-tool is not yet distributed with the default packages. You can find it in the source repository though, under \c src/tools/. + \note At the time of compiling this documentation, \c patchmanager-tool is not yet distributed as part of the regular RPM packages. It can be obtained from the directory \c src/tools/ in Patchmanager's source code repository. \section1 Logging and Debugging - Debug logging of the daemon can be configured using the environment file - located in \c /var/lib/environment/patchmanager/10-dbus.conf setting the \c - QT_LOGGING_RULES variable to e.g. \c{"*.debug=true"} + Debug logging by the Patchmananger daemon can be configured by setting the \c QT_LOGGING_RULES variable to, e.g., \c{"*.debug=true"} in the environment file \c /var/lib/environment/patchmanager/10-dbus.conf - After changing this, the system service must be restarted so it can pick up - the new values. + After changing this, Patchmanager's system service must be restarted for evaluating the new values. */ /****** Services Documentation page *******/ @@ -287,9 +250,10 @@ \target inifile - INI-style configuration file and state storage. + An INI-style configuration file and state storage. + + It consists of two sections: \c settings and \c votes - It currently consists of two sections: \c settings, and \c votes \section3 \c settings \table @@ -302,47 +266,47 @@ \li applied \li list of strings, comma-separated \li empty - \li stores the list of "activated" patches + \li Stores the list of "activated" Patches. \row - \li lastknowngood + \li workingPatches \li list of strings, comma-separated \li empty - \li stores the list of patches, which represent a last-known-good configuration. This is automatically copied from \c applied after a run of autoapply succeeds. + \li Stores a list of Patches, which represent a "last-known-good" / working set of enabled Patches. This list is automatically copied from \c applied after each successful run of auto-apply. \row \li applyOnBoot \li Boolean \li \c false - \li Whether to activate Patches at boot, or show the {Patchmanager Documentation: Startup Dialog}{Startup Dialog} + \li Whether to activate all enabled Patches during OS startup or to show the {Patchmanager Documentation: Startup Dialog}{Startup Dialog}. \row \li bitnessMangle \li Boolean \li \c false - \li Convert patch contents so they can apply on the local architecture (e.g. \c lib vs. \c lib64 path segments) + \li Convert Patch contents so they are applicable to the local architecture (e.g., \c lib versus \c lib64 path elements). \row \li developerMode \li Boolean \li \c false - \li \warning \b deprecated. Pre-Patchmanager v3.2.7, this was used to store the settings for "Developer Mode". This has now been split into \c patchDevelMode and \c sfosVersionCheck + \li \warning \b deprecated. Before Patchmanager 3.2.7, this was used to store the settings for the "Developer Mode". This mode has been split into \c patchDevelMode and \c sfosVersionCheck \row \li notifyOnSuccess \li Boolean \li \c true - \li Whether to show success messages in the UI + \li Whether to show notifications about successful actions on the GUI. \row \li order \li list of strings, comma-separated \li empty - \li The order of the list of patches, bith in the UI as well as the order they will be applied/activated. + \li The order of Patches, both in the list on the GUI, and the sequence in which they will be activated and hence their patch files applied. \row \li patchDevelMode - \li Boolesn + \li Boolean \li \c false \li \row \li sfosVersionCheck \li Integer (Enum) \li 0 (strict) - \li Whether to relax the version checking in the PM GUI. The default will only allow Patches to be downloaded, or activated, whose compatibility field matches the currently running OS version exactly. + \li Whether to relax the version checking in the Patchmanager GUI. The default setting will only allow Patches to be downloaded or activated, of which an entry in their compatibility field exactly matches the currently installed OS version. \endtable \section3 \c [votes] diff --git a/src/qml/PatchManagerPage.qml b/src/qml/PatchManagerPage.qml index b126fd31f..1d12c74f4 100644 --- a/src/qml/PatchManagerPage.qml +++ b/src/qml/PatchManagerPage.qml @@ -240,9 +240,9 @@ Page { } MenuItem { - text: qsTranslate("", "Load Pre-Failure List") + text: qsTranslate("", "Restore prior enabled list") visible: PatchManager.failure - onClicked: menuRemorse.execute( text, function() { PatchManager.call(PatchManager.revertToLastGood()) } ) + onClicked: menuRemorse.execute( text, function() { PatchManager.call(PatchManager.restorePatchList()) } ) } MenuItem { diff --git a/src/qml/patchmanager.cpp b/src/qml/patchmanager.cpp index 52d091777..49d1f2b00 100644 --- a/src/qml/patchmanager.cpp +++ b/src/qml/patchmanager.cpp @@ -817,20 +817,20 @@ void PatchManager::onLoadedChanged(bool loaded) emit loadedChanged(m_loaded); } -/*! Calls the \e revertToLastGood method on D-Bus */ -void PatchManager::revertToLastGood() +/*! Calls the \e restorePatchList method on D-Bus */ +void PatchManager::restorePatchList() { qDebug() << Q_FUNC_INFO; - m_interface->revertToLastGood(); + m_interface->restorePatchList(); } -/*! Calls the \e setKnownGood method on D-Bus */ -void PatchManager::setKnownGood() +/*! Calls the \e backupWorkingPatchList method on D-Bus */ +void PatchManager::backupWorkingPatchList() { qDebug() << Q_FUNC_INFO; - m_interface->setKnownGood(); + m_interface->backupWorkingPatchList(); } /*! Calls the \e resolveFailure method on D-Bus */ diff --git a/src/qml/patchmanager.h b/src/qml/patchmanager.h index d69623a4c..3527df74e 100644 --- a/src/qml/patchmanager.h +++ b/src/qml/patchmanager.h @@ -182,8 +182,8 @@ public slots: void onFailureChanged(bool failed); void onLoadedChanged(bool loaded); - void setKnownGood(); - void revertToLastGood(); + void backupWorkingPatchList(); + void restorePatchList(); void resolveFailure(); signals: diff --git a/src/tools/patchmanager-tool b/src/tools/patchmanager-tool index 188e46934..b4d217c9f 100644 --- a/src/tools/patchmanager-tool +++ b/src/tools/patchmanager-tool @@ -23,8 +23,8 @@ function usage() { printf "\t-A | --activate-all\t\tActivate / apply all Patches formerly marked as active.\n" printf "\t-d | --deactivate\t\tDeactivate / unapply Patches from list or file (via -f).\n" printf "\t-D | --deactivate-all\t\tDeactivate / unapply all Patches.\n" - printf "\t-S | --save-as-good\t\tSave list of enabled Patches as 'known good'\n" - printf "\t-G | --load-known-good\t\tEnable 'known good' Patches\n" + printf "\t-B | --backup-working\t\tSave list of enabled Patches as \"working\"\n" + printf "\t-R | --restore-working\t\tEnable backup list of \"working\" Patches\n" printf "\t-f | --file \t\tUse for the list of Patches.\n" printf "\t-e | --export\t\t\tExport list of Patches marked as active either to STDout or (via -f) to a file.\n" printf "\t-? | --help\t\t\tPrint this help.\n" @@ -95,13 +95,13 @@ case "$1" in shift surplus "$*" ;; - -S|--save-as-good) - operation="--save-as-good" + -B|--backup-working) + operation="--backup-working" shift surplus "$*" ;; - -G|--load-known-good) - operation="--load-known-good" + -R|--restore-working) + operation="--restore-working" shift surplus "$*" ;;