X-Git-Url: http://git.tdb.fi/?p=libs%2Fgltk.git;a=blobdiff_plain;f=source%2Flist.h;fp=source%2Flist.h;h=5fa687ddbc8ec0ff9712b4fa48baa465373fc897;hp=72b5b8890668fdb0c31946c9e17632f7569a6528;hb=394e5c9969a30b604bfaf78fc05a8c2d5c98ab5b;hpb=90d5f5f2ebaeb8aaa4aa47a0c2207f96758cba8c diff --git a/source/list.h b/source/list.h index 72b5b88..5fa687d 100644 --- a/source/list.h +++ b/source/list.h @@ -1,6 +1,7 @@ #ifndef MSP_GLTK_LIST_H_ #define MSP_GLTK_LIST_H_ +#include #include #include #include @@ -117,7 +118,7 @@ private: virtual ~ItemFactory() = default; virtual void set_data(const ListData &) = 0; - virtual Item *create_item(std::size_t) const = 0; + virtual std::unique_ptr create_item(std::size_t) const = 0; }; template @@ -139,9 +140,9 @@ private: throw incompatible_data(typeid(ValueType)); } - Item *create_item(std::size_t i) const override + std::unique_ptr create_item(std::size_t i) const override { - return new I(data->get(i)); + return std::make_unique(data->get(i)); } }; @@ -158,10 +159,10 @@ public: sigc::signal signal_selection_cleared; private: + std::unique_ptr own_data; ListData *data = nullptr; - bool own_data = false; - DataObserver *observer = nullptr; - ItemFactory *item_factory = nullptr; + std::unique_ptr observer = nullptr; + std::unique_ptr item_factory = nullptr; ViewMode view_mode = LIST; std::size_t sel_index = INVALID_INDEX; std::size_t focus_index = INVALID_INDEX; @@ -176,13 +177,13 @@ private: int drag_start_y = 0; VSlider slider; - std::vector items; + std::vector> items; std::vector rows; + List(std::unique_ptr); public: List(); List(ListData &); - virtual ~List(); const char *get_class() const override { return "list"; } @@ -198,14 +199,9 @@ private: public: template - void set_item_type() - { - ItemFactory *f = new TypedItemFactory(*data); - delete item_factory; - item_factory = f; - } + void set_item_type() { item_factory = std::make_unique>(*data); } private: - Item *create_item(std::size_t); + std::unique_ptr create_item(std::size_t); public: void set_view_mode(ViewMode);