+ if(v==visible)
+ return;
+
+ visible = v;
+
+ signal_visibility_changed.emit(visible);
+}
+
+void Widget::set_focusable(bool f)
+{
+ input_type = (f ? INPUT_TEXT : INPUT_NONE);
+}
+
+void Widget::set_focus()
+{
+ if(!parent)
+ throw hierarchy_error("no parent");
+ if(!visible)
+ throw logic_error("!visible");
+
+ signal_request_focus.emit();
+}
+
+void Widget::set_enabled(bool e)
+{
+ set_state(DISABLED, (e ? NORMAL : DISABLED));
+}
+
+void Widget::set_state(State mask, State bits)
+{
+ State old_state = state;
+ state = (state&~mask)|bits;
+ if(style && style->compare_states(old_state, state))
+ rebuild();
+}
+
+void Widget::rebuild()
+{
+ if(!style)
+ return;
+
+ part_cache.begin_rebuild();
+ const Style::PartSeq &parts = style->get_parts();
+ for(Style::PartSeq::const_iterator i=parts.begin(); i!=parts.end(); ++i)