Mercurial > pidgin.yaz
view src/eventloop.c @ 11815:821f40e1912f
[gaim-migrate @ 14106]
SF Patch #1336924 from sadrul
'From the wiki:
"If you have a tab open for a given contact, and then
drag an additional buddy into that contact, the send to
menu does not update."
This patch updates all the focused-conversations in
every window (note that not all conversation in every
tab). This wouldn't be necessary if it was possible to
tell which contact a buddy was removed from. But that
info is not available, so this is the way I can think of.
It works, and will probably not cause too much overhead
for most users -- assuming most of them use tabbed
convs and hence number of windows won't be too great.'
To track which contact was updated would be problematic, I think.
This doesn't seem like too much overhead to me and it keeps the code clean.
committer: Tailor Script <tailor@pidgin.im>
author | Richard Laager <rlaager@wiktel.com> |
---|---|
date | Tue, 25 Oct 2005 13:56:14 +0000 |
parents | 57fccea36e36 |
children |
line wrap: on
line source
/** * @file eventloop.c Gaim Event Loop API * @ingroup core * * gaim * * Gaim is the legal property of its developers, whose names are too numerous * to list here. Please refer to the COPYRIGHT file distributed with this * source distribution. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "eventloop.h" static GaimEventLoopUiOps *eventloop_ui_ops = NULL; guint gaim_timeout_add(guint interval, GSourceFunc function, gpointer data) { GaimEventLoopUiOps *ops = gaim_eventloop_get_ui_ops(); return ops->timeout_add(interval, function, data); } guint gaim_timeout_remove(guint tag) { GaimEventLoopUiOps *ops = gaim_eventloop_get_ui_ops(); return ops->timeout_remove(tag); } guint gaim_input_add(int source, GaimInputCondition condition, GaimInputFunction func, gpointer user_data) { GaimEventLoopUiOps *ops = gaim_eventloop_get_ui_ops(); return ops->input_add(source, condition, func, user_data); } guint gaim_input_remove(guint tag) { GaimEventLoopUiOps *ops = gaim_eventloop_get_ui_ops(); return ops->input_remove(tag); } void gaim_eventloop_set_ui_ops(GaimEventLoopUiOps *ops) { eventloop_ui_ops = ops; } GaimEventLoopUiOps * gaim_eventloop_get_ui_ops(void) { g_return_val_if_fail(eventloop_ui_ops != NULL, NULL); return eventloop_ui_ops; }