]> de.git.xonotic.org Git - xonotic/netradiant.git/blobdiff - libs/uilib/uilib.cpp
Wrap GtkListStore
[xonotic/netradiant.git] / libs / uilib / uilib.cpp
index eb49165a8969a7834150db2929ef0eb3c6de289e..dc0b93f29e9bfa9e81fdb9fe0a77f82c9690c699 100644 (file)
@@ -22,11 +22,21 @@ namespace ui {
         gtk_main();
     }
 
-    Widget root;
+    Widget root{nullptr};
 
-    alert_response Widget::alert(std::string text, std::string title, alert_type type, alert_icon icon)
+#define this (*static_cast<self>(this))
+
+    void IEditable::editable(bool value)
+    {
+        gtk_editable_set_editable(GTK_EDITABLE(this), value);
+    }
+
+    Widget::Widget() : Widget(nullptr)
+    {}
+
+    alert_response IWidget::alert(std::string text, std::string title, alert_type type, alert_icon icon)
     {
-        auto ret = gtk_MessageBox(*this, text.c_str(),
+        auto ret = gtk_MessageBox(this, text.c_str(),
                                   title.c_str(),
                                   type == alert_type::OK ? eMB_OK :
                                   type == alert_type::OKCANCEL ? eMB_OKCANCEL :
@@ -49,36 +59,39 @@ namespace ui {
                 alert_response::OK;
     }
 
-    const char *Widget::file_dialog(bool open, const char *title, const char *path,
-                                    const char *pattern, bool want_load, bool want_import,
-                                    bool want_save)
+    const char *
+    IWidget::file_dialog(bool open, const char *title, const char *path, const char *pattern, bool want_load,
+                         bool want_import, bool want_save)
     {
-        return ::file_dialog(*this, open, title, path, pattern, want_load, want_import, want_save);
+        return ::file_dialog(this, open, title, path, pattern, want_load, want_import, want_save);
     }
 
-    Window::Window(window_type type)
-            : Window(GTK_WINDOW(gtk_window_new(
+    Window::Window() : Window(nullptr)
+    {}
+
+    Window::Window(window_type type) : Window(GTK_WINDOW(gtk_window_new(
             type == window_type::TOP ? GTK_WINDOW_TOPLEVEL :
             type == window_type::POPUP ? GTK_WINDOW_POPUP :
-            GTK_WINDOW_TOPLEVEL)))
-    { };
+            GTK_WINDOW_TOPLEVEL
+    )))
+    {}
 
-    Window Window::create_dialog_window(const char *title, void func(), void *data, int default_w, int default_h)
+    Window IWindow::create_dialog_window(const char *title, void func(), void *data, int default_w, int default_h)
     {
-        return Window(::create_dialog_window(*this, title, func, data, default_w, default_h));
+        return Window(::create_dialog_window(this, title, func, data, default_w, default_h));
     }
 
-    Window Window::create_modal_dialog_window(const char *title, ui_modal &dialog, int default_w, int default_h)
+    Window IWindow::create_modal_dialog_window(const char *title, ModalDialog &dialog, int default_w, int default_h)
     {
-        return Window(::create_modal_dialog_window(*this, title, dialog, default_w, default_h));
+        return Window(::create_modal_dialog_window(this, title, dialog, default_w, default_h));
     }
 
-    Window Window::create_floating_window(const char *title)
+    Window IWindow::create_floating_window(const char *title)
     {
-        return Window(::create_floating_window(title, *this));
+        return Window(::create_floating_window(title, this));
     }
 
-    std::uint64_t Window::on_key_press(bool (*f)(Widget widget, ui_evkey *event, void *extra), void *extra)
+    std::uint64_t IWindow::on_key_press(bool (*f)(Widget widget, _GdkEventKey *event, void *extra), void *extra)
     {
         using f_t = decltype(f);
         struct user_data {
@@ -88,118 +101,139 @@ namespace ui {
         auto dtor = [](user_data *data, GClosure *) {
             delete data;
         };
-        auto func = [](ui_widget *widget, GdkEventKey *event, user_data *args) -> bool {
+        auto func = [](_GtkWidget *widget, GdkEventKey *event, user_data *args) -> bool {
             return args->f(Widget(widget), event, args->extra);
         };
         auto clos = g_cclosure_new(G_CALLBACK(+func), pass, reinterpret_cast<GClosureNotify>(+dtor));
-        return g_signal_connect_closure(G_OBJECT(*this), "key-press-event", clos, false);
+        return g_signal_connect_closure(G_OBJECT(this), "key-press-event", clos, false);
     }
 
-    AccelGroup::AccelGroup() : AccelGroup(GTK_ACCEL_GROUP(gtk_accel_group_new()))
-    { }
-
-    Adjustment::Adjustment(double value,
-                           double lower, double upper,
-                           double step_increment, double page_increment,
-                           double page_size)
-            : Adjustment(
-            GTK_ADJUSTMENT(gtk_adjustment_new(value, lower, upper, step_increment, page_increment, page_size)))
-    { }
+    void IWindow::add_accel_group(AccelGroup group)
+    {
+        gtk_window_add_accel_group(this, group);
+    }
 
     Alignment::Alignment(float xalign, float yalign, float xscale, float yscale)
             : Alignment(GTK_ALIGNMENT(gtk_alignment_new(xalign, yalign, xscale, yscale)))
-    { }
+    {}
+
+    Frame::Frame(const char *label) : Frame(GTK_FRAME(gtk_frame_new(label)))
+    {}
 
     Button::Button() : Button(GTK_BUTTON(gtk_button_new()))
-    { }
+    {}
 
     Button::Button(const char *label) : Button(GTK_BUTTON(gtk_button_new_with_label(label)))
-    { }
-
-    CellRendererText::CellRendererText() : CellRendererText(GTK_CELL_RENDERER_TEXT(gtk_cell_renderer_text_new()))
-    { }
-
-    ComboBoxText::ComboBoxText() : ComboBoxText(GTK_COMBO_BOX_TEXT(gtk_combo_box_text_new()))
-    { }
+    {}
 
-    CheckButton::CheckButton(const char *label) : CheckButton(GTK_CHECK_BUTTON(gtk_check_button_new_with_label(label)))
-    { }
-
-    Entry::Entry() : Entry(GTK_ENTRY(gtk_entry_new()))
-    { }
-
-    Entry::Entry(std::size_t max_length) : Entry()
+    bool IToggleButton::active()
     {
-        gtk_entry_set_max_length(*this, static_cast<gint>(max_length));
+        return gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(this)) != 0;
     }
 
-    Frame::Frame(const char *label) : Frame(GTK_FRAME(gtk_frame_new(label)))
-    { }
+    CheckButton::CheckButton(const char *label) : CheckButton(GTK_CHECK_BUTTON(gtk_check_button_new_with_label(label)))
+    {}
 
-    HBox::HBox(bool homogenous, int spacing) : HBox(GTK_HBOX(gtk_hbox_new(homogenous, spacing)))
-    { }
+    MenuItem::MenuItem() : MenuItem(GTK_MENU_ITEM(gtk_menu_item_new()))
+    {}
 
-    HScale::HScale(Adjustment adjustment) : HScale(GTK_HSCALE(gtk_hscale_new(adjustment)))
-    { }
+    MenuItem::MenuItem(const char *label, bool mnemonic) : MenuItem(
+            GTK_MENU_ITEM((mnemonic ? gtk_menu_item_new_with_mnemonic : gtk_menu_item_new_with_label)(label)))
+    {}
 
-    HScale::HScale(double min, double max, double step) : HScale(GTK_HSCALE(gtk_hscale_new_with_range(min, max, step)))
-    { }
+    TearoffMenuItem::TearoffMenuItem() : TearoffMenuItem(GTK_TEAROFF_MENU_ITEM(gtk_tearoff_menu_item_new()))
+    {}
 
-    Image::Image() : Image(GTK_IMAGE(gtk_image_new()))
-    { }
+    ComboBoxText::ComboBoxText() : ComboBoxText(GTK_COMBO_BOX_TEXT(gtk_combo_box_text_new()))
+    {}
 
-    Label::Label(const char *label) : Label(GTK_LABEL(gtk_label_new(label)))
-    { }
+    ScrolledWindow::ScrolledWindow() : ScrolledWindow(GTK_SCROLLED_WINDOW(gtk_scrolled_window_new(nullptr, nullptr)))
+    {}
 
-    Menu::Menu() : Menu(GTK_MENU(gtk_menu_new()))
-    { }
+    VBox::VBox(bool homogenous, int spacing) : VBox(GTK_VBOX(gtk_vbox_new(homogenous, spacing)))
+    {}
 
-    MenuItem::MenuItem(const char *label, bool mnemonic) : MenuItem(
-            GTK_MENU_ITEM((mnemonic ? gtk_menu_item_new_with_mnemonic : gtk_menu_item_new_with_label)(label)))
-    { }
+    HBox::HBox(bool homogenous, int spacing) : HBox(GTK_HBOX(gtk_hbox_new(homogenous, spacing)))
+    {}
 
     HPaned::HPaned() : HPaned(GTK_HPANED(gtk_hpaned_new()))
-    { }
+    {}
 
     VPaned::VPaned() : VPaned(GTK_VPANED(gtk_vpaned_new()))
-    { }
+    {}
 
-    ScrolledWindow::ScrolledWindow() : ScrolledWindow(GTK_SCROLLED_WINDOW(gtk_scrolled_window_new(nullptr, nullptr)))
-    { }
-
-    SpinButton::SpinButton(Adjustment adjustment, double climb_rate, std::size_t digits) : SpinButton(
-            GTK_SPIN_BUTTON(gtk_spin_button_new(adjustment, climb_rate, digits)))
-    { }
+    Menu::Menu() : Menu(GTK_MENU(gtk_menu_new()))
+    {}
 
     Table::Table(std::size_t rows, std::size_t columns, bool homogenous) : Table(
-            GTK_TABLE(gtk_table_new(rows, columns, homogenous)))
-    { }
+            GTK_TABLE(gtk_table_new(rows, columns, homogenous))
+    )
+    {}
 
     TextView::TextView() : TextView(GTK_TEXT_VIEW(gtk_text_view_new()))
-    { }
-
-    TreePath::TreePath() : TreePath(gtk_tree_path_new())
-    { }
-
-    TreePath::TreePath(const char *path) : TreePath(gtk_tree_path_new_from_string(path))
-    { }
+    {}
 
     TreeView::TreeView() : TreeView(GTK_TREE_VIEW(gtk_tree_view_new()))
-    { }
+    {}
 
     TreeView::TreeView(TreeModel model) : TreeView(GTK_TREE_VIEW(gtk_tree_view_new_with_model(model)))
-    { }
+    {}
+
+    Label::Label(const char *label) : Label(GTK_LABEL(gtk_label_new(label)))
+    {}
+
+    Image::Image() : Image(GTK_IMAGE(gtk_image_new()))
+    {}
+
+    Entry::Entry() : Entry(GTK_ENTRY(gtk_entry_new()))
+    {}
+
+    Entry::Entry(std::size_t max_length) : Entry()
+    {
+        gtk_entry_set_max_length(this, static_cast<gint>(max_length));
+    }
+
+    SpinButton::SpinButton(Adjustment adjustment, double climb_rate, std::size_t digits) : SpinButton(
+            GTK_SPIN_BUTTON(gtk_spin_button_new(adjustment, climb_rate, digits)))
+    {}
+
+    HScale::HScale(Adjustment adjustment) : HScale(GTK_HSCALE(gtk_hscale_new(adjustment)))
+    {}
+
+    HScale::HScale(double min, double max, double step) : HScale(GTK_HSCALE(gtk_hscale_new_with_range(min, max, step)))
+    {}
+
+    Adjustment::Adjustment(double value,
+                           double lower, double upper,
+                           double step_increment, double page_increment,
+                           double page_size)
+            : Adjustment(
+            GTK_ADJUSTMENT(gtk_adjustment_new(value, lower, upper, step_increment, page_increment, page_size)))
+    {}
+
+    CellRendererText::CellRendererText() : CellRendererText(GTK_CELL_RENDERER_TEXT(gtk_cell_renderer_text_new()))
+    {}
 
     TreeViewColumn::TreeViewColumn(const char *title, CellRenderer renderer,
                                    std::initializer_list<TreeViewColumnAttribute> attributes)
             : TreeViewColumn(gtk_tree_view_column_new_with_attributes(title, renderer, nullptr))
     {
         for (auto &it : attributes) {
-            gtk_tree_view_column_add_attribute(*this, renderer, it.attribute, it.column);
+            gtk_tree_view_column_add_attribute(this, renderer, it.attribute, it.column);
         }
     };
 
-    VBox::VBox(bool homogenous, int spacing) : VBox(GTK_VBOX(gtk_vbox_new(homogenous, spacing)))
-    { }
+    AccelGroup::AccelGroup() : AccelGroup(GTK_ACCEL_GROUP(gtk_accel_group_new()))
+    {}
+
+    void IListStore::clear() {
+        gtk_list_store_clear(this);
+    }
+
+    TreePath::TreePath() : TreePath(gtk_tree_path_new())
+    {}
+
+    TreePath::TreePath(const char *path) : TreePath(gtk_tree_path_new_from_string(path))
+    {}
 
 }