X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpanel.h;h=b5755d0cbb1d4f39d7c0975d45cb19656eac8cf0;hb=81c4024fb6acf37df702a803dc4efdf82a81525a;hp=8881f8cb700adac60dfbff20b4336ae2dfe5df76;hpb=405ac4d6193635ae6ee7dacb6ecd6b098fe84c42;p=libs%2Fgltk.git diff --git a/source/panel.h b/source/panel.h index 8881f8c..b5755d0 100644 --- a/source/panel.h +++ b/source/panel.h @@ -1,9 +1,10 @@ #ifndef MSP_GLTK_PANEL_H_ #define MSP_GLTK_PANEL_H_ -#include +#include #include "container.h" #include "layout.h" +#include "mspgltk_api.h" namespace Msp { namespace GLtk { @@ -13,7 +14,7 @@ Panels are containers for other widgets. Panel styles should have a special part "children" to render the child widgets. All properties of this part are ignored. */ -class Panel: public Container +class MSPGLTK_API Panel: public Container { public: class Loader: public DataFile::DerivedObjectLoader @@ -25,7 +26,7 @@ public: template struct AddChildType { - static void add(Loader &, const std::string &); + void operator()(const std::string &, Loader &) const; }; WidgetMap &wdg_map; @@ -66,9 +67,9 @@ private: protected: std::vector nav_order; - Layout *layout; + Layout *layout = nullptr; - static DataFile::LoadableTypeRegistry widget_registry; + static TypeRegistry widget_registry; static bool widget_registry_init_done; Panel(const Panel &); @@ -95,7 +96,7 @@ protected: Widget *find_next_child(int, int, int, int, int) const; static int compute_delta(int, int, int, int, int); - virtual void on_geometry_change(); + virtual void on_size_change(); virtual void on_child_added(Widget &); virtual void on_child_removed(Widget &); }; @@ -126,7 +127,7 @@ void Panel::Loader::unnamed_child() template -void Panel::Loader::AddChildType::add(Loader &ldr, const std::string &kwd) +void Panel::Loader::AddChildType::operator()(const std::string &kwd, Loader &ldr) const { ldr.add(kwd, &Loader::child); ldr.add(kwd, &Loader::unnamed_child);