1 /* ///////////////////////////////////////////////////////////////////////////
2 // Name: src/gtk/treeentry_gtk.c
3 // Purpose: GtkTreeEntry implementation
6 // Copyright: (c) 2006 Ryan Norton
7 // Licence: wxWindows licence
8 /////////////////////////////////////////////////////////////////////////// */
14 #include "wx/gtk/treeentry_gtk.h"
19 The main reason for this class is to have a holder for both a string
20 and userdata for us to use in wxListXXX classes.
22 This is transformable to a string for the Gtk implementations,
23 and the string passed in is duplicated and freed upon destruction.
25 As mentioned the real magic here is the transforming it to a string
26 which lets us use it as a entry in a GtkTreeView/GtkListStore
27 and still display it. Otherwise we would need to implement our
32 static void gtk_tree_entry_class_init(GtkTreeEntryClass
* klass
);
33 static void gtk_tree_entry_init (GTypeInstance
* instance
, gpointer g_class
);
34 static void gtk_tree_entry_string_transform_func(const GValue
*src_value
,
36 static void gtk_tree_entry_dispose(GObject
* obj
);
43 return GTK_TREE_ENTRY(g_object_new(GTK_TYPE_TREE_ENTRY
, NULL
));
47 gtk_tree_entry_get_type ()
49 static GType tree_entry_type
= 0;
53 const GTypeInfo tree_entry_info
=
55 sizeof (GtkTreeEntryClass
),
57 NULL
, /* base_finalize */
58 (GClassInitFunc
) gtk_tree_entry_class_init
, /* class_init */
59 NULL
, /* class_finalize */
60 NULL
, /* class_data */
61 sizeof (GtkTreeEntry
),
63 (GInstanceInitFunc
) gtk_tree_entry_init
, /*instance_init*/
64 NULL
/* value_table */
66 tree_entry_type
= g_type_register_static (G_TYPE_OBJECT
, "GtkTreeEntry",
69 g_value_register_transform_func(tree_entry_type
, G_TYPE_STRING
,
70 gtk_tree_entry_string_transform_func
);
73 return tree_entry_type
;
76 gchar
* gtk_tree_entry_get_collate_key (GtkTreeEntry
* entry
)
78 return entry
->collate_key
;
81 gchar
* gtk_tree_entry_get_label (GtkTreeEntry
* entry
)
83 g_assert(GTK_IS_TREE_ENTRY(entry
));
87 gpointer
gtk_tree_entry_get_userdata (GtkTreeEntry
* entry
)
89 g_assert(GTK_IS_TREE_ENTRY(entry
));
90 return entry
->userdata
;
93 void gtk_tree_entry_set_label (GtkTreeEntry
* entry
, const gchar
* label
)
95 g_assert(GTK_IS_TREE_ENTRY(entry
));
98 /* free previous if it exists */
101 g_free(entry
->label
);
102 g_free(entry
->collate_key
);
105 entry
->label
= g_strdup(label
);
106 temp
= g_utf8_casefold(label
, -1); /* -1 == null terminated */
107 entry
->collate_key
= g_utf8_collate_key(temp
, -1); /* -1 == null terminated */
111 void gtk_tree_entry_set_userdata (GtkTreeEntry
* entry
, gpointer userdata
)
113 g_assert(GTK_IS_TREE_ENTRY(entry
));
114 entry
->userdata
= userdata
;
117 void gtk_tree_entry_set_destroy_func (GtkTreeEntry
* entry
,
118 GtkTreeEntryDestroy destroy_func
,
119 gpointer destroy_func_data
)
121 g_assert(GTK_IS_TREE_ENTRY(entry
));
122 entry
->destroy_func
= destroy_func
;
123 entry
->destroy_func_data
= destroy_func_data
;
127 static void gtk_tree_entry_class_init(GtkTreeEntryClass
* klass
)
129 GObjectClass
* gobject_class
= G_OBJECT_CLASS(klass
);
130 gobject_class
->dispose
= gtk_tree_entry_dispose
;
133 static void gtk_tree_entry_init (GTypeInstance
* instance
, gpointer g_class
)
135 GtkTreeEntry
* entry
= (GtkTreeEntry
*) instance
;
139 entry
->collate_key
= NULL
;
140 entry
->userdata
= NULL
;
141 entry
->destroy_func_data
= NULL
;
142 entry
->destroy_func
= NULL
;
145 static void gtk_tree_entry_string_transform_func(const GValue
*src_value
,
150 /* Make sure src is a treeentry and dest can hold a string */
151 g_assert(GTK_IS_TREE_ENTRY(src_value
->data
[0].v_pointer
));
152 g_assert(G_VALUE_HOLDS(dest_value
, G_TYPE_STRING
));
154 /* TODO: Use strdup here or just pass it? */
155 entry
= GTK_TREE_ENTRY(src_value
->data
[0].v_pointer
);
157 g_value_set_string(dest_value
, entry
->label
);
160 static void gtk_tree_entry_dispose(GObject
* obj
)
164 g_assert(GTK_IS_TREE_ENTRY(obj
));
166 entry
= GTK_TREE_ENTRY(obj
);
168 /* free label if it exists */
171 g_free(entry
->label
);
172 g_free(entry
->collate_key
);
174 entry
->collate_key
= NULL
;
177 /* call destroy callback if it exists */
178 if(entry
->destroy_func
)
180 (*entry
->destroy_func
) (entry
, entry
->destroy_func_data
);
181 entry
->destroy_func
= NULL
;
182 entry
->destroy_func_data
= NULL
;
186 entry
->userdata
= NULL
;