Sat, 28 Apr 2007 02:33:40 +0000
Quoth Charkins:
This patch has two changes:
"This patch has two changes:
First is to slightly change the re-creation behavior of the docklet. Sadrul pointed out on gaim-devel that the x11 docklet re-creates itself when it is destroyed and thought this might be causing problems with fluxbox. This patch now distinguishes between initial creation and re-creation. When re-creating, the docklet no longer registers itself as a visibility manager until it successfully embeds.
Second is to change the timeout behavior for embedding. Because the notification area API is asynchronous, gaim assumes the docklet gets embeded for a certain timeout period, allowing the buddy list to start hidden before the docklet has been embeded in the notification area. If the timeout occurs, it is removed as a visibility manager and the buddy list will become visible. This timeout has been set at 5 seconds. There have been a few reports that indicate this timeout period is not long enough when starting gaim from a saved session upon login. I have been hesitant to increase the timeout, as it has the potential of delaying the startup of gaim for the timeout period if the buddy list was hidden when gaim last closed and there is not currently a notification area available. This patch makes the x11 docklet track whether it was successfully embedded and uses a longer timeout (15 seconds in this patch) only if it successfully embedded on the previous execution. Otherwise, it uses the shorter 5 second timeout. "
package Purple::GtkUI; use 5.008; use strict; use warnings; use Carp; our $VERSION = '0.01'; use Purple; require XSLoader; XSLoader::load('Purple::GtkUI', $VERSION); 1; __END__ =head1 NAME Purple::GtkUI - Perl extension for the Pidgin instant messenger. =head1 SYNOPSIS use Purple::GtkUI; =head1 ABSTRACT This module provides the interface for using perl scripts as plugins in Pidgin, with access to the Pidgin Gtk interface functions. =head1 DESCRIPTION This module provides the interface for using perl scripts as plugins in Pidgin, with access to the Pidgin Gtk interface functions. With this, developers can write perl scripts that can be loaded in Pidgin as plugins. The script can interact with IMs, chats, accounts, the buddy list, pidgin signals, and more. The API for the perl interface is very similar to that of the Pidgin C API, which can be viewed at http://developer.pidgin.im/doxygen/ or in the header files in the Pidgin source tree. =head1 FUNCTIONS =over =back =head1 SEE ALSO Pidgin C API documentation - http://developer.pidgin.im/doxygen/ The Pidgin perl module. Pidgin website - http://pidgin.im/ =head1 AUTHOR Etan Reisner, E<lt>deryni@gmail.comE<gt> =head1 COPYRIGHT AND LICENSE Copyright 2006 by Etan Reisner