]> git.saurik.com Git - wxWidgets.git/blob - src/gtk/treeentry_gtk.c
remove symbol exports, this code is private to the library
[wxWidgets.git] / src / gtk / treeentry_gtk.c
1 /* ///////////////////////////////////////////////////////////////////////////
2 // Name: src/gtk/treeentry_gtk.c
3 // Purpose: GtkTreeEntry implementation
4 // Author: Ryan Norton
5 // Id: $Id$
6 // Copyright: (c) 2006 Ryan Norton
7 // Licence: wxWindows licence
8 /////////////////////////////////////////////////////////////////////////// */
9
10 #ifdef __VMS
11 #include <types.h>
12 typedef pid_t GPid;
13 #define G_GNUC_INTERNAL
14 #define GSEAL(x) x
15 #endif
16
17 #include "wx/gtk/private/treeentry_gtk.h"
18
19 /*
20 GtkTreeEntry
21
22 The main reason for this class is to have a holder for both a string
23 and userdata for us to use in wxListXXX classes.
24
25 This is transformable to a string for the Gtk implementations,
26 and the string passed in is duplicated and freed upon destruction.
27
28 As mentioned the real magic here is the transforming it to a string
29 which lets us use it as a entry in a GtkTreeView/GtkListStore
30 and still display it. Otherwise we would need to implement our
31 own model etc..
32 */
33
34 /* forwards */
35 static void gtk_tree_entry_class_init(void* g_class, void* class_data);
36 static void gtk_tree_entry_string_transform_func(const GValue *src_value,
37 GValue *dest_value);
38 static void gtk_tree_entry_dispose(GObject* obj);
39
40 static GObjectClass* parent_class;
41
42 /* public */
43 GtkTreeEntry*
44 gtk_tree_entry_new()
45 {
46 return GTK_TREE_ENTRY(g_object_new(GTK_TYPE_TREE_ENTRY, NULL));
47 }
48
49 GType
50 gtk_tree_entry_get_type ()
51 {
52 static GType tree_entry_type = 0;
53
54 if (!tree_entry_type)
55 {
56 const GTypeInfo tree_entry_info =
57 {
58 sizeof(GObjectClass),
59 NULL, /* base_init */
60 NULL, /* base_finalize */
61 gtk_tree_entry_class_init,
62 NULL, /* class_finalize */
63 NULL, /* class_data */
64 sizeof (GtkTreeEntry),
65 16, /* n_preallocs */
66 NULL, /* instance_init */
67 NULL /* value_table */
68 };
69 tree_entry_type = g_type_register_static (G_TYPE_OBJECT, "GtkTreeEntry",
70 &tree_entry_info,
71 (GTypeFlags)0);
72 g_value_register_transform_func(tree_entry_type, G_TYPE_STRING,
73 gtk_tree_entry_string_transform_func);
74 }
75
76 return tree_entry_type;
77 }
78
79 gchar* gtk_tree_entry_get_collate_key (GtkTreeEntry* entry)
80 {
81 if (entry->collate_key == NULL)
82 {
83 char* temp = g_utf8_casefold(entry->label, -1);
84 entry->collate_key = g_utf8_collate_key(temp, -1);
85 g_free(temp);
86 }
87 return entry->collate_key;
88 }
89
90 gchar* gtk_tree_entry_get_label (GtkTreeEntry* entry)
91 {
92 g_assert(GTK_IS_TREE_ENTRY(entry));
93 return entry->label;
94 }
95
96 gpointer gtk_tree_entry_get_userdata (GtkTreeEntry* entry)
97 {
98 g_assert(GTK_IS_TREE_ENTRY(entry));
99 return entry->userdata;
100 }
101
102 void gtk_tree_entry_set_label (GtkTreeEntry* entry, const gchar* label)
103 {
104 g_assert(GTK_IS_TREE_ENTRY(entry));
105
106 /* free previous if it exists */
107 if(entry->label)
108 {
109 g_free(entry->label);
110 g_free(entry->collate_key);
111 }
112
113 entry->label = g_strdup(label);
114 entry->collate_key = NULL;
115 }
116
117 void gtk_tree_entry_set_userdata (GtkTreeEntry* entry, gpointer userdata)
118 {
119 g_assert(GTK_IS_TREE_ENTRY(entry));
120 entry->userdata = userdata;
121 }
122
123 void gtk_tree_entry_set_destroy_func (GtkTreeEntry* entry,
124 GtkTreeEntryDestroy destroy_func,
125 gpointer destroy_func_data)
126 {
127 g_assert(GTK_IS_TREE_ENTRY(entry));
128 entry->destroy_func = destroy_func;
129 entry->destroy_func_data = destroy_func_data;
130 }
131
132 /* private */
133 static void gtk_tree_entry_class_init(void* g_class, void* class_data)
134 {
135 GObjectClass* gobject_class = G_OBJECT_CLASS(g_class);
136 gobject_class->dispose = gtk_tree_entry_dispose;
137 parent_class = G_OBJECT_CLASS(g_type_class_peek_parent(g_class));
138 }
139
140 static void gtk_tree_entry_string_transform_func(const GValue *src_value,
141 GValue *dest_value)
142 {
143 GtkTreeEntry *entry;
144 void* src_ptr = g_value_peek_pointer(src_value);
145
146 /* Make sure src is a treeentry and dest can hold a string */
147 g_assert(GTK_IS_TREE_ENTRY(src_ptr));
148 g_assert(G_VALUE_HOLDS(dest_value, G_TYPE_STRING));
149
150 entry = GTK_TREE_ENTRY(src_ptr);
151 g_value_set_string(dest_value, entry->label);
152 }
153
154 static void gtk_tree_entry_dispose(GObject* obj)
155 {
156 GtkTreeEntry *entry;
157
158 g_assert(GTK_IS_TREE_ENTRY(obj));
159
160 entry = GTK_TREE_ENTRY(obj);
161
162 /* free label if it exists */
163 if(entry->label)
164 {
165 g_free(entry->label);
166 g_free(entry->collate_key);
167 entry->label = NULL;
168 entry->collate_key = NULL;
169 }
170
171 /* call destroy callback if it exists */
172 if(entry->destroy_func)
173 {
174 (*entry->destroy_func) (entry, entry->destroy_func_data);
175 entry->destroy_func = NULL;
176 entry->destroy_func_data = NULL;
177 }
178
179 /* clear userdata */
180 entry->userdata = NULL;
181
182 parent_class->dispose(obj);
183 }