diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2020-10-25 07:53:40 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-10-25 13:59:04 -0700 |
commit | faebb539091ca5550bb6b60280d692c50d547bc0 (patch) | |
tree | 785284eedbc783bfd0f02318c05cabf48712e8ed | |
parent | 572e2678a0c5e1a9c2a947e4a9a86f35cec125eb (diff) | |
download | subsurface-faebb539091ca5550bb6b60280d692c50d547bc0.tar.gz |
undo: add device related undo commands
Add commands for deleting devices and editing device nicknames
to include the device-handling in the undo system.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r-- | commands/CMakeLists.txt | 2 | ||||
-rw-r--r-- | commands/command.cpp | 11 | ||||
-rw-r--r-- | commands/command.h | 7 | ||||
-rw-r--r-- | commands/command_device.cpp | 66 | ||||
-rw-r--r-- | commands/command_device.h | 44 | ||||
-rw-r--r-- | core/device.cpp | 7 | ||||
-rw-r--r-- | core/device.h | 1 | ||||
-rw-r--r-- | core/subsurface-qt/divelistnotifier.h | 1 | ||||
-rw-r--r-- | packaging/ios/Subsurface-mobile.pro | 2 |
9 files changed, 140 insertions, 1 deletions
diff --git a/commands/CMakeLists.txt b/commands/CMakeLists.txt index bcd76bba9..f03842048 100644 --- a/commands/CMakeLists.txt +++ b/commands/CMakeLists.txt @@ -6,6 +6,8 @@ set(SUBSURFACE_GENERIC_COMMANDS_SRCS command_base.h command.cpp command.h + command_device.cpp + command_device.h command_divelist.cpp command_divelist.h command_divesite.cpp diff --git a/commands/command.cpp b/commands/command.cpp index 6ce7f18bd..4125d994b 100644 --- a/commands/command.cpp +++ b/commands/command.cpp @@ -1,6 +1,7 @@ // SPDX-License-Identifier: GPL-2.0 #include "command.h" +#include "command_device.h" #include "command_divelist.h" #include "command_divesite.h" #include "command_edit.h" @@ -380,6 +381,16 @@ void addPictures(const std::vector<PictureListForAddition> &pictures) execute(new AddPictures(pictures)); } +void removeDevice(int idx) +{ + execute(new RemoveDevice(idx)); +} + +void editDeviceNickname(int idx, const QString &nickname) +{ + execute(new EditDeviceNickname(idx, nickname)); +} + void createFilterPreset(const QString &name, const FilterData &data) { execute(new CreateFilterPreset(name, data)); diff --git a/commands/command.h b/commands/command.h index 26340357e..a18fc5dd6 100644 --- a/commands/command.h +++ b/commands/command.h @@ -138,7 +138,12 @@ void setPictureOffset(dive *d, const QString &filename, offset_t offset); void removePictures(const std::vector<PictureListForDeletion> &pictures); void addPictures(const std::vector<PictureListForAddition> &pictures); -// 8) Filter commands +// 8) Device commands + +void removeDevice(int idx); +void editDeviceNickname(int idx, const QString &nickname); + +// 9) Filter commands void createFilterPreset(const QString &name, const FilterData &data); void removeFilterPreset(int index); diff --git a/commands/command_device.cpp b/commands/command_device.cpp new file mode 100644 index 000000000..afd368b55 --- /dev/null +++ b/commands/command_device.cpp @@ -0,0 +1,66 @@ +// SPDX-License-Identifier: GPL-2.0 + +#include "command_device.h" +#include "core/subsurface-qt/divelistnotifier.h" + +namespace Command { + +RemoveDevice::RemoveDevice(int indexIn) : index(indexIn) +{ + const device *dev = get_device(&device_table, index); + if (!dev) + return; + + setText(Command::Base::tr("Delete device %1 (0x%2)").arg(QString::fromStdString(dev->model), + QString::number(dev->deviceId))); +} + +bool RemoveDevice::workToBeDone() +{ + return get_device(&device_table, index) != nullptr; +} + +void RemoveDevice::redo() +{ + dev = *get_device(&device_table, index); + remove_from_device_table(&device_table, index); + emit diveListNotifier.deviceDeleted(index); +} + +void RemoveDevice::undo() +{ + index = add_to_device_table(&device_table, &dev); + emit diveListNotifier.deviceAdded(index); +} + +EditDeviceNickname::EditDeviceNickname(int indexIn, const QString &nicknameIn) : + index(indexIn), nickname(nicknameIn.toStdString()) +{ + const device *dev = get_device(&device_table, index); + if (!dev) + return; + + setText(Command::Base::tr("Set nickname of device %1 (0x%2) to %3").arg(QString::fromStdString(dev->model), + QString::number(dev->deviceId,1 ,16), nicknameIn)); +} + +bool EditDeviceNickname::workToBeDone() +{ + return get_device(&device_table, index) != nullptr; +} + +void EditDeviceNickname::redo() +{ + device *dev = get_device_mutable(&device_table, index); + if (!dev) + return; + std::swap(dev->nickName, nickname); + emit diveListNotifier.deviceEdited(index); +} + +void EditDeviceNickname::undo() +{ + redo(); // undo() and redo() do the same thing +} + +} // namespace Command diff --git a/commands/command_device.h b/commands/command_device.h new file mode 100644 index 000000000..c1cf1a240 --- /dev/null +++ b/commands/command_device.h @@ -0,0 +1,44 @@ +// SPDX-License-Identifier: GPL-2.0 +// Note: this header file is used by the undo-machinery and should not be included elsewhere. + +#ifndef COMMAND_DEVICE_H +#define COMMAND_DEVICE_H + +#include "command_base.h" +#include "core/device.h" + +struct device; + +// We put everything in a namespace, so that we can shorten names without polluting the global namespace +namespace Command { + +class RemoveDevice final : public Base { +public: + RemoveDevice(int index); +private: + // for undo + device dev; + + // for redo + int index; + + void undo() override; + void redo() override; + bool workToBeDone() override; +}; + +class EditDeviceNickname final : public Base { +public: + EditDeviceNickname(int index, const QString &nickname); +private: + // for redo and undo + int index; + std::string nickname; + + void undo() override; + void redo() override; + bool workToBeDone() override; +}; + +} // namespace Command +#endif diff --git a/core/device.cpp b/core/device.cpp index bd1d75416..47ce72b17 100644 --- a/core/device.cpp +++ b/core/device.cpp @@ -392,6 +392,13 @@ extern "C" const struct device *get_device(const struct device_table *table, int return &table->devices[i]; } +extern "C" struct device *get_device_mutable(struct device_table *table, int i) +{ + if (i < 0 || i > nr_devices(table)) + return NULL; + return &table->devices[i]; +} + extern "C" const char *device_get_model(const struct device *dev) { return dev ? dev->model.c_str() : NULL; diff --git a/core/device.h b/core/device.h index 0de299060..0ef0d4c92 100644 --- a/core/device.h +++ b/core/device.h @@ -23,6 +23,7 @@ extern void add_devices_of_dive(const struct dive *dive, struct device_table *ta extern void create_device_node(struct device_table *table, const char *model, uint32_t deviceid, const char *serial, const char *firmware, const char *nickname); extern int nr_devices(const struct device_table *table); extern const struct device *get_device(const struct device_table *table, int i); +extern struct device *get_device_mutable(struct device_table *table, int i); extern void clear_device_table(struct device_table *table); const char *get_dc_nickname(const struct divecomputer *dc); extern bool device_used_by_selected_dive(const struct device *dev); diff --git a/core/subsurface-qt/divelistnotifier.h b/core/subsurface-qt/divelistnotifier.h index 7f7162dac..07750de90 100644 --- a/core/subsurface-qt/divelistnotifier.h +++ b/core/subsurface-qt/divelistnotifier.h @@ -130,6 +130,7 @@ signals: // Devices related signals void deviceAdded(int index); void deviceDeleted(int index); + void deviceEdited(int index); // Filter related signals void filterPresetAdded(int index); diff --git a/packaging/ios/Subsurface-mobile.pro b/packaging/ios/Subsurface-mobile.pro index e9c81dfb2..bcd60efcc 100644 --- a/packaging/ios/Subsurface-mobile.pro +++ b/packaging/ios/Subsurface-mobile.pro @@ -17,6 +17,7 @@ SOURCES += ../../subsurface-mobile-main.cpp \ ../../map-widget/qmlmapwidgethelper.cpp \ ../../commands/command_base.cpp \ ../../commands/command.cpp \ + ../../commands/command_device.cpp \ ../../commands/command_divelist.cpp \ ../../commands/command_divesite.cpp \ ../../commands/command_edit.cpp \ @@ -190,6 +191,7 @@ INCLUDEPATH += ../../../install-root/ios/include/ \ HEADERS += \ ../../commands/command_base.h \ ../../commands/command.h \ + ../../commands/command_device.h \ ../../commands/command_divelist.h \ ../../commands/command_divesite.h \ ../../commands/command_edit.h \ |