Mercurial > pidgin
annotate src/gtkconv.h @ 10865:c28766b87f64
[gaim-migrate @ 12549]
Check all characters in the unescaped value of a HTML entity when matching smileys. Also make sure that the returned value of the smiley length is correct when dealing with escaped text. This resolves an inconsistency between how smileys are detected and how they are looked up for display.
committer: Tailor Script <tailor@pidgin.im>
author | Daniel Atallah <daniel.atallah@gmail.com> |
---|---|
date | Sun, 24 Apr 2005 21:28:39 +0000 |
parents | 53e7884c549a |
children | 339b61819edc |
rev | line source |
---|---|
4359 | 1 /** |
2 * @file gtkconv.h GTK+ Conversation API | |
5034
4691c5936c01
[gaim-migrate @ 5377]
Christian Hammond <chipx86@chipx86.com>
parents:
4736
diff
changeset
|
3 * @ingroup gtkui |
4359 | 4 * |
5 * gaim | |
6 * | |
8046 | 7 * Gaim is the legal property of its developers, whose names are too numerous |
8 * to list here. Please refer to the COPYRIGHT file distributed with this | |
9 * source distribution. | |
7326
00a9ab26d607
[gaim-migrate @ 7912]
Christian Hammond <chipx86@chipx86.com>
parents:
7295
diff
changeset
|
10 * |
4359 | 11 * This program is free software; you can redistribute it and/or modify |
12 * it under the terms of the GNU General Public License as published by | |
13 * the Free Software Foundation; either version 2 of the License, or | |
14 * (at your option) any later version. | |
15 * | |
16 * This program is distributed in the hope that it will be useful, | |
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 * GNU General Public License for more details. | |
20 * | |
21 * You should have received a copy of the GNU General Public License | |
22 * along with this program; if not, write to the Free Software | |
23 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
24 */ | |
9713 | 25 #ifndef _GAIM_GTKCONVERSATION_H_ |
26 #define _GAIM_GTKCONVERSATION_H_ | |
4359 | 27 |
10008 | 28 typedef struct _GaimGtkWindow GaimGtkWindow; |
29 typedef struct _GaimGtkImPane GaimGtkImPane; | |
30 typedef struct _GaimGtkChatPane GaimGtkChatPane; | |
31 typedef struct _GaimGtkConversation GaimGtkConversation; | |
9709 | 32 |
9498 | 33 enum { |
34 CHAT_USERS_ICON_COLUMN, | |
35 CHAT_USERS_NAME_COLUMN, | |
9554 | 36 CHAT_USERS_FLAGS_COLUMN, |
9498 | 37 CHAT_USERS_COLUMNS |
38 }; | |
39 | |
10008 | 40 #define GAIM_GTK_WINDOW(win) \ |
41 ((GaimGtkWindow *)(win)->ui_data) | |
42 | |
43 #define GAIM_GTK_CONVERSATION(conv) \ | |
44 ((GaimGtkConversation *)(conv)->ui_data) | |
45 | |
46 #define GAIM_IS_GTK_WINDOW(win) \ | |
47 (gaim_conv_window_get_ui_ops(win) == gaim_gtk_conversations_get_win_ui_ops()) | |
48 | |
49 #define GAIM_IS_GTK_CONVERSATION(conv) \ | |
50 (gaim_conversation_get_ui_ops(conv) == \ | |
51 gaim_gtk_conversations_get_conv_ui_ops()) | |
52 | |
53 #include "gtkgaim.h" | |
54 #include "conversation.h" | |
55 | |
4359 | 56 /************************************************************************** |
57 * @name Structures | |
58 **************************************************************************/ | |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
59 /*@{*/ |
4359 | 60 |
61 /** | |
62 * A GTK+ representation of a graphical window containing one or more | |
63 * conversations. | |
64 */ | |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
65 struct _GaimGtkWindow |
4359 | 66 { |
67 GtkWidget *window; /**< The window. */ | |
68 GtkWidget *notebook; /**< The notebook of conversations. */ | |
69 | |
70 struct | |
71 { | |
10359 | 72 GtkWidget *menubox; |
4359 | 73 GtkWidget *menubar; |
74 | |
5167 | 75 GtkWidget *view_log; |
5908
ed8a9a3bf7e2
[gaim-migrate @ 6340]
Christian Hammond <chipx86@chipx86.com>
parents:
5872
diff
changeset
|
76 |
9468 | 77 GtkWidget *send_file; |
5908
ed8a9a3bf7e2
[gaim-migrate @ 6340]
Christian Hammond <chipx86@chipx86.com>
parents:
5872
diff
changeset
|
78 GtkWidget *add_pounce; |
7887 | 79 GtkWidget *get_info; |
80 GtkWidget *warn; | |
81 GtkWidget *invite; | |
82 | |
5908
ed8a9a3bf7e2
[gaim-migrate @ 6340]
Christian Hammond <chipx86@chipx86.com>
parents:
5872
diff
changeset
|
83 GtkWidget *alias; |
7887 | 84 GtkWidget *block; |
85 GtkWidget *add; | |
86 GtkWidget *remove; | |
5908
ed8a9a3bf7e2
[gaim-migrate @ 6340]
Christian Hammond <chipx86@chipx86.com>
parents:
5872
diff
changeset
|
87 |
7859 | 88 GtkWidget *insert_link; |
89 GtkWidget *insert_image; | |
90 | |
4359 | 91 GtkWidget *logging; |
92 GtkWidget *sounds; | |
7326
00a9ab26d607
[gaim-migrate @ 7912]
Christian Hammond <chipx86@chipx86.com>
parents:
7295
diff
changeset
|
93 GtkWidget *show_formatting_toolbar; |
9188 | 94 GtkWidget *show_timestamps; |
10456 | 95 GtkWidget *show_icon; |
5908
ed8a9a3bf7e2
[gaim-migrate @ 6340]
Christian Hammond <chipx86@chipx86.com>
parents:
5872
diff
changeset
|
96 |
4359 | 97 GtkWidget *send_as; |
5908
ed8a9a3bf7e2
[gaim-migrate @ 6340]
Christian Hammond <chipx86@chipx86.com>
parents:
5872
diff
changeset
|
98 |
4736 | 99 GtkWidget *typing_icon; |
4359 | 100 |
4630 | 101 GtkItemFactory *item_factory; |
102 | |
4359 | 103 } menu; |
104 | |
105 /* Tab dragging stuff. */ | |
106 gboolean in_drag; | |
107 gboolean in_predrag; | |
108 | |
109 gint drag_min_x, drag_max_x, drag_min_y, drag_max_y; | |
110 | |
111 gint drag_motion_signal; | |
112 gint drag_leave_signal; | |
113 }; | |
114 | |
115 /** | |
7820 | 116 * A GTK+ Instant Message pane. |
4359 | 117 */ |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
118 struct _GaimGtkImPane |
4359 | 119 { |
120 GtkWidget *block; | |
9468 | 121 GtkWidget *send_file; |
4359 | 122 GtkWidget *sep1; |
123 GtkWidget *sep2; | |
124 GtkWidget *check; | |
125 GtkWidget *progress; | |
126 | |
127 gboolean a_virgin; | |
128 | |
129 /* Buddy icon stuff */ | |
9885 | 130 GtkWidget *icon_container; |
4359 | 131 GtkWidget *icon; |
9687 | 132 gboolean show_icon; |
8189 | 133 gboolean animate; |
4359 | 134 GdkPixbufAnimation *anim; |
135 GdkPixbufAnimationIter *iter; | |
136 guint32 icon_timer; | |
137 }; | |
138 | |
139 /** | |
140 * GTK+ Chat panes. | |
141 */ | |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
142 struct _GaimGtkChatPane |
4359 | 143 { |
144 GtkWidget *count; | |
145 GtkWidget *list; | |
146 GtkWidget *topic_text; | |
10500 | 147 GtkWidget *userlist_im; |
148 GtkWidget *userlist_ignore; | |
149 GtkWidget *userlist_info; | |
4359 | 150 }; |
151 | |
152 /** | |
153 * A GTK+ conversation pane. | |
154 */ | |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
155 struct _GaimGtkConversation |
4359 | 156 { |
10810 | 157 GaimConversation *active_conv; |
158 GList *convs; | |
159 | |
4359 | 160 gboolean make_sound; |
7326
00a9ab26d607
[gaim-migrate @ 7912]
Christian Hammond <chipx86@chipx86.com>
parents:
7295
diff
changeset
|
161 gboolean show_formatting_toolbar; |
9188 | 162 gboolean show_timestamps; |
4359 | 163 |
164 GtkTooltips *tooltips; | |
165 | |
166 GtkWidget *tab_cont; | |
167 GtkWidget *tabby; | |
6771
8eebba08b44b
[gaim-migrate @ 7308]
Christian Hammond <chipx86@chipx86.com>
parents:
6392
diff
changeset
|
168 GtkWidget *menu_tabby; |
4359 | 169 |
170 GtkWidget *imhtml; | |
171 GtkTextBuffer *entry_buffer; | |
172 GtkWidget *entry; | |
173 | |
7930 | 174 GtkWidget *close; /* "x" on the tab */ |
6392
e9974608b319
[gaim-migrate @ 6897]
Christian Hammond <chipx86@chipx86.com>
parents:
5908
diff
changeset
|
175 GtkWidget *icon; |
4359 | 176 GtkWidget *tab_label; |
6771
8eebba08b44b
[gaim-migrate @ 7308]
Christian Hammond <chipx86@chipx86.com>
parents:
6392
diff
changeset
|
177 GtkWidget *menu_icon; |
8eebba08b44b
[gaim-migrate @ 7308]
Christian Hammond <chipx86@chipx86.com>
parents:
6392
diff
changeset
|
178 GtkWidget *menu_label; |
4359 | 179 GtkSizeGroup *sg; |
180 | |
9332 | 181 GtkWidget *lower_hbox; |
4359 | 182 |
8317 | 183 GtkWidget *toolbar; |
4359 | 184 |
185 struct | |
186 { | |
5106 | 187 GtkWidget *image; |
7295 | 188 GtkWidget *search; |
4359 | 189 |
190 } dialogs; | |
191 | |
192 union | |
193 { | |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
194 GaimGtkImPane *im; |
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
195 GaimGtkChatPane *chat; |
4359 | 196 |
197 } u; | |
198 }; | |
199 | |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
200 /*@}*/ |
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
201 |
4359 | 202 /************************************************************************** |
203 * @name GTK+ Conversation API | |
204 **************************************************************************/ | |
5673
62f57ec16f29
[gaim-migrate @ 6091]
Christian Hammond <chipx86@chipx86.com>
parents:
5167
diff
changeset
|
205 /*@{*/ |
62f57ec16f29
[gaim-migrate @ 6091]
Christian Hammond <chipx86@chipx86.com>
parents:
5167
diff
changeset
|
206 |
62f57ec16f29
[gaim-migrate @ 6091]
Christian Hammond <chipx86@chipx86.com>
parents:
5167
diff
changeset
|
207 /** |
10814
364a2ef907ae
[gaim-migrate @ 12468]
Luke Schierer <lschiere@pidgin.im>
parents:
10810
diff
changeset
|
208 * Returns the UI operations structure for GTK+ windows. |
4359 | 209 * |
10814
364a2ef907ae
[gaim-migrate @ 12468]
Luke Schierer <lschiere@pidgin.im>
parents:
10810
diff
changeset
|
210 * @return The GTK+ window operations structure. |
4359 | 211 */ |
7118
bf630f7dfdcd
[gaim-migrate @ 7685]
Christian Hammond <chipx86@chipx86.com>
parents:
7035
diff
changeset
|
212 GaimConvWindowUiOps *gaim_gtk_conversations_get_win_ui_ops(void); |
4359 | 213 |
214 /** | |
10814
364a2ef907ae
[gaim-migrate @ 12468]
Luke Schierer <lschiere@pidgin.im>
parents:
10810
diff
changeset
|
215 * Returns the UI operations structure for GTK+ conversations. |
4359 | 216 * |
10814
364a2ef907ae
[gaim-migrate @ 12468]
Luke Schierer <lschiere@pidgin.im>
parents:
10810
diff
changeset
|
217 * @return The GTK+ conversation operations structure. |
4359 | 218 */ |
7035
feb3d21a7794
[gaim-migrate @ 7598]
Christian Hammond <chipx86@chipx86.com>
parents:
6771
diff
changeset
|
219 GaimConversationUiOps *gaim_gtk_conversations_get_conv_ui_ops(void); |
4359 | 220 |
221 /** | |
222 * Updates the buddy icon on a conversation. | |
223 * | |
224 * @param conv The conversation. | |
225 */ | |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
226 void gaim_gtkconv_update_buddy_icon(GaimConversation *conv); |
4359 | 227 |
228 /** | |
229 * Updates the tab positions on all conversation windows to reflect any | |
230 * changed preferences. | |
231 */ | |
232 void gaim_gtkconv_update_tabs(void); | |
233 | |
234 /** | |
235 * Updates conversation buttons by protocol. | |
236 * | |
237 * @param conv The conversation. | |
238 */ | |
5676
dae79aefac8d
[gaim-migrate @ 6094]
Christian Hammond <chipx86@chipx86.com>
parents:
5674
diff
changeset
|
239 void gaim_gtkconv_update_buttons_by_protocol(GaimConversation *conv); |
4359 | 240 |
241 /** | |
9759 | 242 * Creates a conversation button |
243 * | |
244 * @param icon The stock icon name. | |
245 * @param text The text for the button. | |
246 * @param tooltip The tooltip text. | |
247 * @param tooltips The group of tooltips. | |
248 * @param callback A function to call when the button is clicked. | |
249 * @param data Data to pass to the callback. | |
250 * | |
251 * @return The button | |
252 */ | |
253 GtkWidget *gaim_gtkconv_button_new(const char *icon, const char *text, | |
254 const char *tooltip, GtkTooltips *tooltips, | |
255 void *callback, void *data); | |
256 | |
257 /** | |
4359 | 258 * Returns the window at the specified X, Y location. |
259 * | |
260 * If the window is not a GTK+ window, @c NULL is returned. | |
261 * | |
262 * @param x The X coordinate. | |
263 * @param y The Y coordinate. | |
264 * | |
265 * @return The GTK+ window at the location, if it exists, or @c NULL otherwise. | |
266 */ | |
7118
bf630f7dfdcd
[gaim-migrate @ 7685]
Christian Hammond <chipx86@chipx86.com>
parents:
7035
diff
changeset
|
267 GaimConvWindow *gaim_gtkwin_get_at_xy(int x, int y); |
4359 | 268 |
269 /** | |
270 * Returns the index of the tab at the specified X, Y location in a notebook. | |
271 * | |
272 * @param win The GTK+ window containing the notebook. | |
273 * @param x The X coordinate. | |
274 * @param y The Y coordinate. | |
275 * | |
276 * @return The index of the tab at the location. | |
277 */ | |
7118
bf630f7dfdcd
[gaim-migrate @ 7685]
Christian Hammond <chipx86@chipx86.com>
parents:
7035
diff
changeset
|
278 int gaim_gtkconv_get_tab_at_xy(GaimConvWindow *win, int x, int y); |
4359 | 279 |
280 /** | |
281 * Returns the index of the destination tab at the | |
282 * specified X, Y location in a notebook. | |
283 * | |
284 * This is used for drag-and-drop functions when the tab at the index | |
285 * is a destination tab. | |
286 * | |
287 * @param win The GTK+ window containing the notebook. | |
288 * @param x The X coordinate. | |
289 * @param y The Y coordinate. | |
290 * | |
291 * @return The index of the tab at the location. | |
292 */ | |
7118
bf630f7dfdcd
[gaim-migrate @ 7685]
Christian Hammond <chipx86@chipx86.com>
parents:
7035
diff
changeset
|
293 int gaim_gtkconv_get_dest_tab_at_xy(GaimConvWindow *win, int x, int y); |
4359 | 294 |
10827 | 295 GaimGtkConversation *gaim_gtk_get_gtkconv_at_index(const GaimConvWindow *win, int index); |
5673
62f57ec16f29
[gaim-migrate @ 6091]
Christian Hammond <chipx86@chipx86.com>
parents:
5167
diff
changeset
|
296 /*@}*/ |
62f57ec16f29
[gaim-migrate @ 6091]
Christian Hammond <chipx86@chipx86.com>
parents:
5167
diff
changeset
|
297 |
8582
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
298 /**************************************************************************/ |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
299 /** @name GTK+ Conversations Subsystem */ |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
300 /**************************************************************************/ |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
301 /*@{*/ |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
302 |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
303 /** |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
304 * Returns the gtk conversations subsystem handle. |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
305 * |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
306 * @return The conversations subsystem handle. |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
307 */ |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
308 void *gaim_gtk_conversations_get_handle(void); |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
309 |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
310 /** |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
311 * Initializes the GTK+ conversations subsystem. |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
312 */ |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
313 void gaim_gtk_conversations_init(void); |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
314 |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
315 /** |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
316 * Uninitialized the GTK+ conversation subsystem. |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
317 */ |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
318 void gaim_gtk_conversations_uninit(void); |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
319 |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
320 /*@}*/ |
d7c85220c685
[gaim-migrate @ 9332]
Christian Hammond <chipx86@chipx86.com>
parents:
8317
diff
changeset
|
321 |
9713 | 322 #endif /* _GAIM_GTKCONVERSATION_H_ */ |