Move MarkerManager to using an ID system for markers, instead of index

This commit is contained in:
AdenKoperczak 2024-11-03 14:16:56 -05:00
parent 236d7c1e35
commit 7a070b3e7f
8 changed files with 233 additions and 74 deletions

View file

@ -12,6 +12,7 @@ namespace qt
namespace manager
{
typedef void MarkerForEachFunc(const types::MarkerInfo&);
class MarkerManager : public QObject
{
Q_OBJECT
@ -21,12 +22,15 @@ public:
~MarkerManager();
size_t marker_count();
std::optional<types::MarkerInfo> get_marker(size_t index);
void set_marker(size_t index, const types::MarkerInfo& marker);
std::optional<types::MarkerInfo> get_marker(types::MarkerId id);
std::optional<size_t> get_index(types::MarkerId id);
void set_marker(types::MarkerId id, const types::MarkerInfo& marker);
void add_marker(const types::MarkerInfo& marker);
void remove_marker(size_t index);
void remove_marker(types::MarkerId id);
void move_marker(size_t from, size_t to);
void for_each(std::function<MarkerForEachFunc> func);
// Only use for testing
void set_marker_settings_path(const std::string& path);
@ -35,9 +39,9 @@ public:
signals:
void MarkersInitialized(size_t count);
void MarkersUpdated();
void MarkerChanged(size_t index);
void MarkerAdded();
void MarkerRemoved(size_t index);
void MarkerChanged(types::MarkerId id);
void MarkerAdded(types::MarkerId id);
void MarkerRemoved(types::MarkerId id);
private:
class Impl;