Mercurial > pidgin
annotate src/gtkeventloop.c @ 12476:18b16e801e6f
[gaim-migrate @ 14787]
SF Patch #1379107 from evands
'Properly notify the UI when a buddy icon changes
gaim_buddy_set_icon() currently does nothing if the incoming
GaimBuddyIcon* is the same as buddy->icon.
This is wrong, however, because gaim_buddy_icon_new() will recycle an
existing GaimBuddyIcon* object for the buddy, replacing its data with the
new buddy icon data, if possible. The recycling means that just because
(icon == buddy->icon) we can't assume nothing has changed.
This patch makes the "buddy-icon-changed" signal be sent and the
gaim_blist_update_buddy_icon() function be called appropriately when the
buddy icon changes.
Call stack that gets us here from prpl code, for those keeping score at
home:
gaim_buddy_icons_set_for_user() -> gaim_buddy_icon_new() ->
gaim_buddy_icon_set_data() -> gaim_buddy_icon_update() ->
gaim_buddy_set_icon()'
committer: Tailor Script <tailor@pidgin.im>
author | Richard Laager <rlaager@wiktel.com> |
---|---|
date | Tue, 13 Dec 2005 08:10:28 +0000 |
parents | 8e97c8befc0b |
children |
rev | line source |
---|---|
8273 | 1 /** |
2 * @file gtk_eventloop.c Gaim Event Loop API (gtk implementation) | |
3 * @ingroup gtkui | |
4 * | |
5 * gaim | |
6 * | |
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. | |
10 * | |
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 */ | |
25 | |
26 #include <glib.h> | |
27 #include "gtkeventloop.h" | |
28 #include "eventloop.h" | |
29 | |
30 #define GAIM_GTK_READ_COND (G_IO_IN | G_IO_HUP | G_IO_ERR) | |
31 #define GAIM_GTK_WRITE_COND (G_IO_OUT | G_IO_HUP | G_IO_ERR | G_IO_NVAL) | |
32 | |
33 typedef struct _GaimGtkIOClosure { | |
34 GaimInputFunction function; | |
35 guint result; | |
36 gpointer data; | |
37 | |
38 } GaimGtkIOClosure; | |
39 | |
40 static void gaim_gtk_io_destroy(gpointer data) | |
41 { | |
42 g_free(data); | |
43 } | |
44 | |
45 static gboolean gaim_gtk_io_invoke(GIOChannel *source, GIOCondition condition, gpointer data) | |
46 { | |
47 GaimGtkIOClosure *closure = data; | |
48 GaimInputCondition gaim_cond = 0; | |
49 | |
50 if (condition & GAIM_GTK_READ_COND) | |
51 gaim_cond |= GAIM_INPUT_READ; | |
52 if (condition & GAIM_GTK_WRITE_COND) | |
53 gaim_cond |= GAIM_INPUT_WRITE; | |
54 | |
55 #if 0 | |
56 gaim_debug(GAIM_DEBUG_MISC, "gtk_eventloop", | |
57 "CLOSURE: callback for %d, fd is %d\n", | |
58 closure->result, g_io_channel_unix_get_fd(source)); | |
59 #endif | |
60 | |
11065
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
61 #ifdef _WIN32 |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
62 if(! gaim_cond) { |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
63 #if DEBUG |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
64 gaim_debug(GAIM_DEBUG_MISC, "gtk_eventloop", |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
65 "CLOSURE received GIOCondition of 0x%x, which does not" |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
66 " match 0x%x (READ) or 0x%x (WRITE)\n", |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
67 condition, GAIM_GTK_READ_COND, GAIM_GTK_WRITE_COND); |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
68 #endif /* DEBUG */ |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
69 |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
70 return TRUE; |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
71 } |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
72 #endif /* _WIN32 */ |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
73 |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
74 closure->function(closure->data, g_io_channel_unix_get_fd(source), |
8e97c8befc0b
[gaim-migrate @ 13046]
Christopher O'Brien <siege@pidgin.im>
parents:
8807
diff
changeset
|
75 gaim_cond); |
8273 | 76 |
77 return TRUE; | |
78 } | |
79 | |
8280
084ed9f7ac19
[gaim-migrate @ 9004]
Christian Hammond <chipx86@chipx86.com>
parents:
8273
diff
changeset
|
80 static guint gaim_gtk_input_add(gint fd, GaimInputCondition condition, GaimInputFunction function, |
8273 | 81 gpointer data) |
82 { | |
83 GaimGtkIOClosure *closure = g_new0(GaimGtkIOClosure, 1); | |
84 GIOChannel *channel; | |
85 GIOCondition cond = 0; | |
86 | |
87 closure->function = function; | |
88 closure->data = data; | |
89 | |
90 if (condition & GAIM_INPUT_READ) | |
91 cond |= GAIM_GTK_READ_COND; | |
92 if (condition & GAIM_INPUT_WRITE) | |
93 cond |= GAIM_GTK_WRITE_COND; | |
94 | |
8280
084ed9f7ac19
[gaim-migrate @ 9004]
Christian Hammond <chipx86@chipx86.com>
parents:
8273
diff
changeset
|
95 channel = g_io_channel_unix_new(fd); |
8273 | 96 closure->result = g_io_add_watch_full(channel, G_PRIORITY_DEFAULT, cond, |
97 gaim_gtk_io_invoke, closure, gaim_gtk_io_destroy); | |
98 | |
99 #if 0 | |
100 gaim_debug(GAIM_DEBUG_MISC, "gtk_eventloop", | |
101 "CLOSURE: adding input watcher %d for fd %d\n", | |
8280
084ed9f7ac19
[gaim-migrate @ 9004]
Christian Hammond <chipx86@chipx86.com>
parents:
8273
diff
changeset
|
102 closure->result, fd); |
8273 | 103 #endif |
104 | |
105 g_io_channel_unref(channel); | |
106 return closure->result; | |
107 } | |
108 | |
109 static GaimEventLoopUiOps eventloop_ops = | |
110 { | |
111 g_timeout_add, | |
8470
9949b752d1ab
[gaim-migrate @ 9203]
Christian Hammond <chipx86@chipx86.com>
parents:
8287
diff
changeset
|
112 (guint (*)(guint))g_source_remove, |
8273 | 113 gaim_gtk_input_add, |
8807 | 114 (guint (*)(guint))g_source_remove |
8273 | 115 }; |
116 | |
117 GaimEventLoopUiOps * | |
118 gaim_gtk_eventloop_get_ui_ops(void) | |
119 { | |
120 return &eventloop_ops; | |
121 } |