]> de.git.xonotic.org Git - xonotic/netradiant.git/blobdiff - contrib/brushexport/support.cpp
Merge branch 'fix-fast' into 'master'
[xonotic/netradiant.git] / contrib / brushexport / support.cpp
index 79c5e145b6939eb4ef6aa1f0a32b1fecc11e5679..d227b5baa2c0fdd89e6ed62215bdca1a8e2edddc 100644 (file)
@@ -1,33 +1,32 @@
 #include <gtk/gtk.h>
+#include <uilib/uilib.h>
 
 #include "support.h"
 
-GtkWidget*
-lookup_widget( GtkWidget       *widget,
-                          const gchar     *widget_name ){
-       GtkWidget *parent, *found_widget;
+ui::Widget
+lookup_widget(ui::Widget widget,
+              const gchar *widget_name)
+{
+    ui::Widget parent{ui::null};
 
-       for (;; )
-       {
-               if ( GTK_IS_MENU( widget ) ) {
-                       parent = gtk_menu_get_attach_widget( GTK_MENU( widget ) );
-               }
-               else{
-                       parent = widget->parent;
-               }
-               if ( !parent ) {
-                       parent = (GtkWidget*) g_object_get_data( G_OBJECT( widget ), "GladeParentKey" );
-               }
-               if ( parent == NULL ) {
-                       break;
-               }
-               widget = parent;
-       }
+    for (;;) {
+        if (GTK_IS_MENU(widget)) {
+            parent = ui::Widget::from(gtk_menu_get_attach_widget(GTK_MENU(widget)));
+        } else {
+            parent = ui::Widget::from(gtk_widget_get_parent(widget));
+        }
+        if (!parent) {
+            parent = ui::Widget::from(g_object_get_data(G_OBJECT(widget), "GladeParentKey"));
+        }
+        if (parent == NULL) {
+            break;
+        }
+        widget = parent;
+    }
 
-       found_widget = (GtkWidget*) g_object_get_data( G_OBJECT( widget ),
-                                                                                                  widget_name );
-       if ( !found_widget ) {
-               g_warning( "Widget not found: %s", widget_name );
-       }
-       return found_widget;
+    auto found_widget = ui::Widget::from(g_object_get_data(G_OBJECT(widget), widget_name));
+    if (!found_widget) {
+        g_warning("Widget not found: %s", widget_name);
+    }
+    return found_widget;
 }