#include <string.h>
-static gboolean roster_row_activated(GtkTreeView *tree_view, GtkTreePath *path,
+static void roster_row_activated(GtkTreeView *tree_view, GtkTreePath *path,
GtkTreeViewColumn *column, gpointer data)
{
JubGtkRosterUI *roster = data;
gtk_tree_model_get(tree_model, &row_iter, 1, &jid_s, -1);
// This was a group row
- if (!jid_s) return TRUE;
+ if (!jid_s) return;
pool = [OFAutoreleasePool new];
jid = [XMPPJID JIDWithString: [OFString stringWithUTF8String: jid_s]];
withObject: jid
waitUntilDone: NO];
[pool release];
-
- return TRUE;
}
static void presence_changed(GtkComboBox *combo_box, gpointer data)
}
@implementation JubGtkRosterUI
-- initWithBuilder: (GtkBuilder*)builder_
- connection: (XMPPConnection*)connection_
+- initWithConnection: (XMPPConnection*)connection_
{
self = [super init];
@try {
GtkTreeView *roster_view;
GtkComboBox *presence_combo;
+ GtkBuilder *builder;
groupMap = [[OFMapTable alloc]
initWithKeyFunctions: keyFunctions
presences = [[OFCountedSet alloc] init];
connection = [connection_ retain];
- builder = g_object_ref(builder_);
+ builder = gtk_builder_new();
+ gtk_builder_add_from_file(builder, "data/gtk/roster.ui", NULL);
+ gtk_builder_connect_signals(builder, NULL);
+
+ roster_window =
+ GTK_WIDGET(gtk_builder_get_object(builder, "RosterWindow"));
+
+ gtk_widget_show(roster_window);
roster_model = GTK_TREE_STORE(gtk_builder_get_object(builder,
"RosterTreeStore"));
g_signal_connect(presence_combo, "changed",
G_CALLBACK(presence_changed), connection);
+
+ g_object_unref(G_OBJECT(builder));
} @catch (id e) {
[self release];
@throw e;
{
[groupMap release];
[contactMap release];
+ [chatMap release];
[presences release];
[connection release];
- if (roster_model)
- g_object_unref(roster_model);
-
- if (roster_filter)
- g_object_unref(roster_filter);
-
- g_object_unref(builder);
+ gtk_widget_destroy(roster_window);
[super dealloc];
}