summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Berthold Stoeger <bstoeger@mail.tuwien.ac.at>2020-04-26 19:09:28 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-04-26 13:54:59 -0700
commitf43b3f56b252c2403b072298d4dbd613f03c479f (patch)
tree6c9f5b6bcb453b715495ec0bdcc0c749ba49ce8b
parent2ad3696230e5bbd4f5a339121812d27e857c1789 (diff)
downloadsubsurface-f43b3f56b252c2403b072298d4dbd613f03c479f.tar.gz
cleanup: remove Command::inCommand()
This was used by the divelist to check wether a selection change is programmatical or user-initiated. However, since there is only one entry point for programmatical selection changes, this is not needed anymore. Remove it - this removes an inter-module dependency. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r--commands/command_divelist.cpp2
-rw-r--r--core/subsurface-qt/divelistnotifier.h56
2 files changed, 0 insertions, 58 deletions
diff --git a/commands/command_divelist.cpp b/commands/command_divelist.cpp
index fe59ecb6c..50e410c16 100644
--- a/commands/command_divelist.cpp
+++ b/commands/command_divelist.cpp
@@ -381,7 +381,6 @@ void DiveListBase::finishWork()
void DiveListBase::undo()
{
- auto marker = diveListNotifier.enterCommand();
initWork();
undoit();
finishWork();
@@ -389,7 +388,6 @@ void DiveListBase::undo()
void DiveListBase::redo()
{
- auto marker = diveListNotifier.enterCommand();
initWork();
redoit();
finishWork();
diff --git a/core/subsurface-qt/divelistnotifier.h b/core/subsurface-qt/divelistnotifier.h
index 63355fbcc..b5f8106d5 100644
--- a/core/subsurface-qt/divelistnotifier.h
+++ b/core/subsurface-qt/divelistnotifier.h
@@ -121,68 +121,12 @@ signals:
// This is necessary, so that the user can't click on the "undo" button and undo
// an unrelated command.
void commandExecuted();
-public:
- // Desktop uses the QTreeView class to present the list of dives. The layout
- // of this class gives us a very fundamental problem, as we can not easily
- // distinguish between user-initiated changes of the selection and changes
- // that are due to actions of the Command-classes. To solve this problem,
- // the frontend can use this function to query whether a dive list-modifying
- // command is currently executed. If this function returns true, the
- // frontend is supposed to not modify the selection.
- bool inCommand() const;
-
- // The following class and function are used by divelist-modifying commands
- // to signal that they are in-flight. If the returned object goes out of scope,
- // the command-in-flight status is reset to its previous value. Thus, the
- // function can be called recursively.
- class InCommandMarker {
- DiveListNotifier &notifier;
- bool oldValue;
- InCommandMarker(DiveListNotifier &);
- friend DiveListNotifier;
- public:
- ~InCommandMarker();
- };
-
- // Usage:
- // void doWork()
- // {
- // auto marker = diveListNotifier.enterCommand();
- // ... do work ...
- // }
- InCommandMarker enterCommand();
-private:
- friend InCommandMarker;
- bool commandExecuting;
};
// The DiveListNotifier class has only trivial state.
// We can simply define it as a global object.
extern DiveListNotifier diveListNotifier;
-// InCommandMarker is so trivial that the functions can be inlined.
-// TODO: perhaps move this into own header-file.
-inline DiveListNotifier::InCommandMarker::InCommandMarker(DiveListNotifier &notifierIn) : notifier(notifierIn),
- oldValue(notifier.commandExecuting)
-{
- notifier.commandExecuting = true;
-}
-
-inline DiveListNotifier::InCommandMarker::~InCommandMarker()
-{
- notifier.commandExecuting = oldValue;
-}
-
-inline bool DiveListNotifier::inCommand() const
-{
- return commandExecuting;
-}
-
-inline DiveListNotifier::InCommandMarker DiveListNotifier::enterCommand()
-{
- return InCommandMarker(*this);
-}
-
inline DiveField::DiveField(int flags) :
nr((flags & NR) != 0),
datetime((flags & DATETIME) != 0),