X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpanel.h;h=3061032789574f168c2bb2933f787d4f439c1284;hb=HEAD;hp=e9744fd107a273c12365a86d11cec545228109d6;hpb=aa9b8db38efb9e97460c76e27cecc4d1591b23e5;p=libs%2Fgltk.git diff --git a/source/panel.h b/source/panel.h index e9744fd..3061032 100644 --- a/source/panel.h +++ b/source/panel.h @@ -1,6 +1,7 @@ #ifndef MSP_GLTK_PANEL_H_ #define MSP_GLTK_PANEL_H_ +#include #include #include "container.h" #include "layout.h" @@ -36,7 +37,6 @@ public: Loader(Panel &, WidgetMap &); private: - Layout &get_layout(); Widget &get_last_widget(); template void arrangement(); @@ -67,24 +67,20 @@ private: protected: std::vector nav_order; - Layout *layout = nullptr; + std::unique_ptr layout; static TypeRegistry widget_registry; static bool widget_registry_init_done; - Panel(const Panel &); - Panel &operator=(const Panel &); public: Panel(); - virtual ~Panel(); template static void register_child_type(const std::string &); const char *get_class() const override { return "panel"; } - void set_layout(Layout *); - Layout *get_layout() { return layout; } + Layout &get_or_create_layout(); protected: void autosize_special(const Part &, Geometry &) const override; @@ -119,10 +115,11 @@ void Panel::Loader::child(const std::string &n) template void Panel::Loader::unnamed_child() { - RefPtr chl = new T(); + std::unique_ptr chl = std::make_unique(); load_sub(*chl); - obj.add(*chl.get()); - last_widget = chl.release(); + Widget *wdg = chl.get(); + obj.add(move(chl)); + last_widget = wdg; }