]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/panel.cpp
Remove dead code from Panel::Child
[libs/gltk.git] / source / panel.cpp
index 7876120b2ce2e7cea30cecb52fd42aeef2b11185..11d90e40349b04d1c49534119be5f36f100998b4 100644 (file)
@@ -39,6 +39,12 @@ void Panel::set_layout(Layout *l)
        layout = l;
 }
 
+void Panel::autosize()
+{
+       if(layout)
+               layout->autosize();
+}
+
 Panel::Child *Panel::create_child(Widget *wdg)
 {
        return new Child(*this, wdg);
@@ -67,13 +73,13 @@ Widget *Panel::get_final_input_focus() const
        return input_focus;
 }
 
-void Panel::render_special(const Part &part) const
+void Panel::render_special(const Part &part, GL::Renderer &renderer) const
 {
        if(part.get_name()=="children")
        {
                for(list<Container::Child *>::const_iterator i=children.begin(); i!=children.end(); ++i)
                        if((*i)->widget->is_visible())
-                               (*i)->widget->render();
+                               (*i)->widget->render(renderer);
        }
 }
 
@@ -160,13 +166,19 @@ void Panel::on_geometry_change()
 void Panel::on_child_added(Widget &wdg)
 {
        if(layout)
+       {
                layout->add_widget(wdg);
+               signal_autosize_changed.emit();
+       }
 }
 
 void Panel::on_child_removed(Widget &wdg)
 {
        if(layout)
+       {
                layout->remove_widget(wdg);
+               signal_autosize_changed.emit();
+       }
 }
 
 void Panel::set_pointer_focus(Widget *wdg)
@@ -263,13 +275,6 @@ void Panel::Child::visibility_changed(bool v)
        }
 }
 
-void Panel::Child::autosize_changed()
-{
-       Panel &panel = static_cast<Panel &>(container);
-       if(panel.layout)
-               panel.layout->update();
-}
-
 void Panel::Child::request_focus()
 {
        Panel &panel = static_cast<Panel &>(container);