diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2020-04-17 16:49:15 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-05-06 13:58:09 -0700 |
commit | fe82cb32b93e906b9bf53010538651b9c84df9db (patch) | |
tree | 91d944915294c37136221074e31e8077cefc52ad | |
parent | 6f8cc5aafecdbbd824be8872c6c4d837d725ef40 (diff) | |
download | subsurface-fe82cb32b93e906b9bf53010538651b9c84df9db.tar.gz |
media: add small C++ helper describing a picture struct
By using a std::string instead of a C-string, memory management
becomes so much simpler! This class will be used for keeping track
of deleted/added pictures in the undo system.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r-- | core/CMakeLists.txt | 2 | ||||
-rw-r--r-- | core/pictureobj.cpp | 27 | ||||
-rw-r--r-- | core/pictureobj.h | 25 | ||||
-rw-r--r-- | packaging/ios/Subsurface-mobile.pro | 2 |
4 files changed, 56 insertions, 0 deletions
diff --git a/core/CMakeLists.txt b/core/CMakeLists.txt index 7699877bc..4a498cde8 100644 --- a/core/CMakeLists.txt +++ b/core/CMakeLists.txt @@ -127,6 +127,8 @@ set(SUBSURFACE_CORE_LIB_SRCS parse.h picture.c picture.h + pictureobj.cpp + pictureobj.h planner.c planner.h plannernotes.c diff --git a/core/pictureobj.cpp b/core/pictureobj.cpp new file mode 100644 index 000000000..cb6b32675 --- /dev/null +++ b/core/pictureobj.cpp @@ -0,0 +1,27 @@ +// SPDX-License-Identifier: GPL-2.0 +#include "pictureobj.h" +#include "qthelper.h" + +PictureObj::PictureObj() : offset({ 0 }), location({ 0 }) +{ +} + +PictureObj::PictureObj(const picture &pic) : filename(pic.filename), offset(pic.offset), location(pic.location) +{ +} + +picture PictureObj::toCore() const +{ + return picture { + strdup(filename.c_str()), + offset, + location + }; +} + +bool PictureObj::operator<(const PictureObj &p2) const +{ + if (offset.seconds != p2.offset.seconds) + return offset.seconds < p2.offset.seconds; + return strcmp(filename.c_str(), p2.filename.c_str()) < 0; +} diff --git a/core/pictureobj.h b/core/pictureobj.h new file mode 100644 index 000000000..6ea20259b --- /dev/null +++ b/core/pictureobj.h @@ -0,0 +1,25 @@ +// SPDX-License-Identifier: GPL-2.0 + +#ifndef PICTUREOBJ_H +#define PICTUREOBJ_H + +// A tiny helper class that represents a struct picture of the core +// It does, however, keep the filename as a std::string so that C++ code +// doesn't have do its own memory-management. + +#include "core/units.h" +#include "core/picture.h" +#include <string> + +struct PictureObj { + std::string filename; + offset_t offset; + location_t location; + + PictureObj(); // Initialize to empty picture. + PictureObj(const picture &pic); // Create from core struct picture. + picture toCore() const; // Turn into core structure. Caller responsible for freeing. + bool operator<(const PictureObj &p2) const; +}; + +#endif // PICTUREOBJ_H diff --git a/packaging/ios/Subsurface-mobile.pro b/packaging/ios/Subsurface-mobile.pro index a036ccae8..36da3e3af 100644 --- a/packaging/ios/Subsurface-mobile.pro +++ b/packaging/ios/Subsurface-mobile.pro @@ -64,6 +64,7 @@ SOURCES += ../../subsurface-mobile-main.cpp \ ../../core/parse-xml.c \ ../../core/parse.c \ ../../core/picture.c \ + ../../core/pictureobj.cpp \ ../../core/import-suunto.c \ ../../core/import-shearwater.c \ ../../core/import-cobalt.c \ @@ -205,6 +206,7 @@ HEADERS += \ ../../core/units.h \ ../../core/version.h \ ../../core/picture.h \ + ../../core/pictureobj.h \ ../../core/planner.h \ ../../core/divesite.h \ ../../core/checkcloudconnection.h \ |