# HG changeset patch # User Luke Schierer # Date 1177017269 0 # Node ID 7891ff4c8e9189c28c939b01dbaf0bf5d1652fb3 # Parent c25b815c29e36b650045005a8c5119b6652cc595# Parent 9815ba2af5707b4a95e19a375e43d5999a95b59f merge of '13c739f1a978be3498fc3c3d87e0742ac3d8e320' and 'b9846f927f8dc47d4b7faf36eb17a903528d7e18' diff -r c25b815c29e3 -r 7891ff4c8e91 .todo --- a/.todo Thu Apr 19 18:44:40 2007 +0000 +++ b/.todo Thu Apr 19 21:14:29 2007 +0000 @@ -2,173 +2,7 @@ Gaim TODO List - - UI stuff - - need to be able to copy/paste smilies - - done some time ago - - - - resizing text entry area below default doesn't work well. - - wysiwyg and changes from that time period fixed this - - - some people report being unable to shrink it at all - - - - copy grabs html as well as text. - - wysiwyg solved this - - - - kicking someone in #name-extension causes a kick to display in #name as well and vice-versa - - - SEARCH FUNCTION FOR LOG FILES - - current function only highlights every other entry (sf bug 980075) - - - - fix crash when someone writes just as you close the chat window. - - - Save buddy icon option does not work, it saves a screenname.icon file which is not openable. - - - status report w/out being on own list - - - option not to raise windows on event while away - - - make entry widget height preference a relative size, that is it doesn't change the overall height of the window. - - - buddy pounce stuff - - drop down list of buddies - - I think tab complete for the field solves this - - - - - blist does not resize correctly on some platforms. this does not seem to be an issue on linux. - - - better gtk2-ified icons: maybe a send icon? review the ones we're using now. do they make sense? - - - do not automatically resize windows that have been manually resized. - - is this fixed? - - - when a new tab is created - - I think this is solved now that tabs always display - - - - when a buddy icon is received - - - when an im image is received - - - - block buddy option from right click menu in blist - - - blist short cuts apparently not working - - - display status overlay for buddies on the blist that have been blocked - - - option to have input box scroll instead of line wrap. input box only. - - - Transparency for GtkIMHtml - - - - Prefs stuff - - make sure prefs save - - - move plugins out of prefs to their own dialog - - - preference to set logfile path. (i think there is a patch to add this) - - - add ircproxy option to proxy preferences. - - - per-sn controls on how to compute idle time - - - - Core stuff - - encryption and hash stuff currently in gaim consolidated to an api - - cipher api - - - - PERMIT ONLY PEOPLE ON MY LIST TO IM ME IS NEEDED ASAP!!!!!!!! - - for yahoo - - - icq - - - msn - - - - documentation needed. (both online and not) - - - better privacy controls. - - - networking code rethink (libgnet?) - - - Cancelable proxy_connect - - - - away rethink - - make it possible to create a state with exceptions - - - make it possible to use a saved state - - - Away needs to be modified to include "show" and "status", i.e. you can have an away state, and an away message. This is exactly what ICQ does - you're "N/A" (show in Jabber) and your away message is "I'm gone." (status in Jabber). Since it only applies to ICQ and Jabber (and actually, currently only Jabber, since icqlib doesn't handle away messages yet), there should be some way of indicating that it can do both without breaking the others. My suggestion is to put "/" at the end of the "state", and when that's there, have it be a menu with all of the custom messages, e.g. in Jabber it'd return "Away/" as one of the states, and you'd see "Away" with a menu of all the away messages you have. - - - - - - - - - - + WinGaim specific stuff @@ -187,142 +21,5 @@ Write a seperate program that implements multiple-users. It should encrypt/decrypt .gaimrc's based on a provided password, then launch gaim -f, with that .gaimrc. - - gaim-remote stuff - - GAIM-REMOTE: need a doc written up for gaim-remote on usage - - - GAIM-REMOTE: need to implement everything listed in gaim-remote --help - - - - In General (i don't know where this should be) - - person support - - faceprint added it - - - - fix memory leaks - - - gzip storage of logs - - a plugin could do this now - - - - throwaway away message (unsaved) for single account (vs. set all away) - - - add state saving and hook it to session management and user dialogs - - - importing/exporting blist files - - export one account's worth of blist.xml - - - import whatever we export, to any account - - - licq - - - trillian - - - - adding and removing buddies needs cleaned up. basically, add_buddy should be calling ui_add_buddy and serv_add_buddy as needed (require an extra arg to add_buddy to tell it what needs done) and the various ways a buddy can come to be needing added should be calling some type of request_add_buddy (this would be part of both the core<->ui interface and the core<->prpl interface) - - - some way to ask about differences bettween server lists and local lists - - - - Plugins/Scripts - - move to gobjects and gsignals - - - sean's plugin ideas - - screenshot plugin - - - xmms remote plugin - - - statusimage plugin - - - - docklet stuff - - make the docklet support blinking status icons where appropriate (requires setting up a better GAIM_STOCK_ICON framework) - - - - - DISCUSSION: entries here are things i'm not sure are desirable or doable. - - do we really need some of the preferences? (Ignore TIK messages. Does anyone use that method of retrieving Away messages anymore? no, but it is small and it would be a piece of history lost ;-)) - - prefsslash04 - - - - "console beep" sound option should use different frequency beeps for different events, or at least give some way to allow this behavior. - - - ximian serial numbers in rpms cause... problems. - - - msn auth expires (better, but still not perfect) - - - gaim should detect if message is sent and only log on success for protocols capable of offline messaging, this would always log, but aim messages would only be logged if sent to an online person. this would essentially entail making logging dependent on the return status of the serv send msg command. - - - the privacy dialog has five different options now. this looks rather ugly. When we redesign the dialog, perhaps we should change the privacy setting to a combobox? - - - protocol action to log into webmail for those that support such (aim, yahoo, msn) maybe a right-click option to send to user(yahoo, msn) - - - show alias in list of people in chat - - - tab complete to alias, translate to nick on send for chat - - - sorting of conversation tabs, if the ordering of left-to-right order by opening isn't good enough for you - - - option to disable close for x seconds after receive im. this would short circuit missing messages as you close the window. make it an option that's off by default. - - - options on key bindings. (different window managers map different things). - - make the control key switchable with the alt key or similar) - - - maybe make control/alt+arrow optionally replace control+bracket (since control-pageup and control-pagedown work, i'm inclined not to do this) - - - - make the option to have escape close a window be global (error messages, account editor, etc.) - - - - autotools/gettext - - automake 1.4 support bug, non-root users can't get gaim to compile by putting the gtk2 and glib2 m4 files in the m4 dir - - - automake 1.[56] support not perfect. - - + diff -r c25b815c29e3 -r 7891ff4c8e91 Doxyfile.in --- a/Doxyfile.in Thu Apr 19 18:44:40 2007 +0000 +++ b/Doxyfile.in Thu Apr 19 21:14:29 2007 +0000 @@ -615,13 +615,13 @@ # each generated HTML page. If it is left blank doxygen will generate a # standard header. -HTML_HEADER = doc/TracHeader.html +HTML_HEADER = @top_srcdir@/doc/TracHeader.html # The HTML_FOOTER tag can be used to specify a personal HTML footer for # each generated HTML page. If it is left blank doxygen will generate a # standard footer. -HTML_FOOTER = doc/TracFooter.html +HTML_FOOTER = @top_srcdir@/doc/TracFooter.html # The HTML_STYLESHEET tag can be used to specify a user-defined cascading # style sheet that is used by each HTML page. It can be used to diff -r c25b815c29e3 -r 7891ff4c8e91 TODO --- a/TODO Thu Apr 19 18:44:40 2007 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,92 +0,0 @@ -* conversation api {{{ - * need to handle: {{{ - * unnamed chats - * chats with the same name as a buddy - * this should be working now, but it needs to be kept in mind when (re-)designing - * jabber Messages (one off messages vrs a conversation with a backlog) - * multiple conversations with a single buddy (jabber, with thread tag) - * bugs - }}} - * notes: {{{ - * (12:58:39) Robot101: user list always|auto|never - * topic only where supported by the protocol - * how do we log this? {{{ - * rlaager's (NEW) proposal: {{{ - * each conversation has 1 or more logs associated with it. - * when someone joins, a new log is opened - * file based loggers should try to use hard-links in a smart way - to avoid duplicating data on disk as much as possible... - * this needs to be designed in such a way that a database logger - can handle it w/o duplication... - * TO SOLVE THESE CONCERNS, a link and/or copy function callback - will likely need to be added - }}} - }}} - }}} -}}} -* buddy list {{{ - * we have not committed any gobjectification, so this is not a blocker for 2.0.0 until we do. - * if we do, it is only a blocker to the extent that pidgin & finch need to run. That is, we do not - *necessarily* have to gobjectifiy everything as long as we preserve functionality. - * That being said, my understanding of the signals mess says that it is probly more work to - try to do this in stages than to start it or not start it. - * This would require some sort of signal aggregation, as gobject signals are unique to the instance. - * one way to do this would be to emit the signals from a non-descript buddy object. this would - most closely mimic the current functionality - * a second way would be to actually try to aggregate them in some way. I really don't know how - possible this is, but it would allow us to do things like set a pounce on everyone in a group - or define sounds on a per-group basis. - * we could look at replacing the UI ops with signals/call backs - * bugs - * wrong buddy given priority -}}} -* status {{{ - * Error messages aren't particularly usable currently. we need to be able to see the full text of - the error, and what account is in that error condition. - * No way to see accounts not in the global state. - * Easier access to saved states is needed. -}}} -* Privacy {{{ - * this is not a blocker for 2.0.0 - * Privacy sucks. it doesn't handle many of the protocols in a way that users understand. notably - msn, but also yahoo, jabber, and icq. - * We want to sync to the server as much as possible, entirely local-only privacy is not an option - except on protocols like irc that have no server-side. - * We want to be as consistent across protocols as possible. this will require renaming things on - some protocols. - * Bleeter suggests that we create a privacy.xml, remove privacy from blist.xml. He suggests - that each protocol define certain capabilities & defaults, with accounts.xml holding exceptions - to the defaults. -}}} -* Perl {{{ - * Block for 2.0.0 or remove perl: - * Extended testing and resolving the inevitable bugs remains. - * Test each call to make sure it actually works - * Make it work with G_MODULE_BIND_LOCAL -}}} -* Prefs {{{ - * on upgrade from 1.x, the timestamp preference often gets lost. -}}} -* system log {{{ - * The system log minimally should tell me what _I_ do in Pidgin. It should (minimally) tell me about - my accounts and actions. It should thus list - * Pidgin start and quit - * Account connection - * account disconnection, and reason if caused by error. - * account state changes, IFF we are logging that for buddies. - * This might include the state message(s). - * This might be done using one or more files. - * historically, the system log has also functioned to log things about buddies that do not relate - to a specific conversation. While I(luke) do not at all object to this, it could be argued that - such functionality more properly belongs in a plugin, such as the buddy state notification plugin. - if we continue to implement such functionality, it could include: - * logging when a buddy signs on, including in some form what account sees that change. - * logging when a buddy signs off, including in some form what account sees that change. - * " " " " goes idle, " " " " " " " " " - * " " " " goes away, " " " " " " " " " - * " " " " becomes available, " " " " " " " " " - * like the logging of my own accounts, this could be done in one or more files. - * one potential downside of using multiple files is the idea that either the file's contents - duplicate information contained in the file's location/name, or that we need to manipulate - the display so as to convey that information to the user from the graphical viewer -}}} diff -r c25b815c29e3 -r 7891ff4c8e91 doc/Makefile.am --- a/doc/Makefile.am Thu Apr 19 18:44:40 2007 +0000 +++ b/doc/Makefile.am Thu Apr 19 21:14:29 2007 +0000 @@ -4,6 +4,8 @@ C-HOWTO.dox \ PERL-HOWTO.dox \ TCL-HOWTO.dox \ + TracFooter.html \ + TracHeader.html \ account-signals.dox \ blist-signals.dox \ cipher-signals.dox \ diff -r c25b815c29e3 -r 7891ff4c8e91 finch/gntplugin.c --- a/finch/gntplugin.c Thu Apr 19 18:44:40 2007 +0000 +++ b/finch/gntplugin.c Thu Apr 19 21:14:29 2007 +0000 @@ -63,17 +63,22 @@ static void plugin_toggled_cb(GntWidget *tree, PurplePlugin *plugin, gpointer null) { + /* TODO: Mark these strings for translation after the freeze */ if (gnt_tree_get_choice(GNT_TREE(tree), plugin)) { - if(!purple_plugin_load(plugin)) + if (!purple_plugin_load(plugin)) { purple_notify_error(NULL, "ERROR", "loading plugin failed", NULL); + gnt_tree_set_choice(GNT_TREE(tree), plugin, FALSE); + } } else { GntWidget *win; - if (!purple_plugin_unload(plugin)) + if (!purple_plugin_unload(plugin)) { purple_notify_error(NULL, "ERROR", "unloading plugin failed", NULL); + gnt_tree_set_choice(GNT_TREE(tree), plugin, TRUE); + } if ((win = g_hash_table_lookup(confwins, plugin)) != NULL) { diff -r c25b815c29e3 -r 7891ff4c8e91 libpurple/prefs.c --- a/libpurple/prefs.c Thu Apr 19 18:44:40 2007 +0000 +++ b/libpurple/prefs.c Thu Apr 19 21:14:29 2007 +0000 @@ -1111,22 +1111,24 @@ if(newchild == NULL) { /* no rename happened, we weren't able to find the new pref */ char *tmpname = pref_full_name(child); - gaim_debug_error("prefs", "Unable to find rename pref for %s", tmpname); + purple_debug_error("prefs", "Unable to find rename pref for %s", tmpname); g_free(tmpname); } } + oldname = pref_full_name(oldpref); + newname = pref_full_name(newpref); + if (oldpref->type != newpref->type) { purple_debug_error("prefs", "Unable to rename %s to %s: differing types\n", oldname, newname); + g_free(oldname); + g_free(newname); return; } - oldname = pref_full_name(oldpref); - newname = pref_full_name(newpref); purple_debug_info("prefs", "Renaming %s to %s\n", oldname, newname); g_free(oldname); - g_free(newname); switch(oldpref->type) { case PURPLE_PREF_NONE: @@ -1150,6 +1152,7 @@ purple_prefs_set_path_list(newname, oldpref->value.stringlist); break; } + g_free(newname); remove_pref(oldpref); } diff -r c25b815c29e3 -r 7891ff4c8e91 libpurple/protocols/gg/.todo --- a/libpurple/protocols/gg/.todo Thu Apr 19 18:44:40 2007 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,8 +0,0 @@ - - - New User Registration - - - There's probably 100 other things but since I've hardly used the Windows client before I'm not sure what any of them are - - diff -r c25b815c29e3 -r 7891ff4c8e91 libpurple/protocols/irc/.todo --- a/libpurple/protocols/irc/.todo Thu Apr 19 18:44:40 2007 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,38 +0,0 @@ - - - fix duplication of names on rejoin (depends on convo API) - - someone fixed this - - - - no list of people on /join - - This is a convo issue, not an IRC issue - - - - /ignore - - - Error 421, unknown command when going away. sometimes. (has to do with html in away messages?) - - I think this was caused by embedded newlines -- fixed, if that's the case. - - - - /names - - - Allow text to be sent on /query - - - error message on unknown commands (don't just pass to ircd) - - - Make /part smarter ... part the current channel with a part message on '/part message' if we can determine the first word is not a channel name - - - UI to see the banlist output in - - diff -r c25b815c29e3 -r 7891ff4c8e91 libpurple/protocols/msn/.todo --- a/libpurple/protocols/msn/.todo Thu Apr 19 18:44:40 2007 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,65 +0,0 @@ - - - Bugs - - bug: some people receive blank messages. clicking to ignore font faces font when the requested font isn't found. - - - bug: doesn't save blist to file on read from server as this could be introducing new people, esp. if there is no existing file, it should - - - when you authorize someone to add you, the corresponding dialog to add them is blank - - - Majortool says to tell sean about "already in opposite list" errors are still happening, now whenever you start gaim. follow from prior conversation. javabsp|away: the (C) and (R) works (23:02:54) MajorTool: LSchiere: yeah what javabsp|away is talking about but its certain ones - - - - Features - - store group name that buddy is in on server - - - File Transfer - - shx did this - - - - Group chat support. - - Typing notification in group chats. - - - Start chat. - - - Better support in general. - - - - International friendly name support. - - - Need some way of indicating "invite" in IM window. - - - Auto-reply on away. - - - People search. - - - Mobile MSN support. - - - support for displaying the number of emails in the inbox. - - - Set the friendly name to be the self alias. - - - Voice chat. - - - diff -r c25b815c29e3 -r 7891ff4c8e91 libpurple/protocols/yahoo/.todo --- a/libpurple/protocols/yahoo/.todo Thu Apr 19 18:44:40 2007 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,38 +0,0 @@ - - - offline messages get lost, esp. if more than 1 sent (is this fixed?) - - I've not heard a report on this for some time - - - - color - - patch is in, but it doesn't do bg colors right currently and doesn't do default colors - - - <fade> tags need parsed. - - - - display profile - - this is as done as it is likely to get any time soon - - - - bug: won't allow me to delete myself from my list past sign on - - - make away message display like that of aim/icq/jabber - - - auto reply on away - - - web cam support - - - voice chat - - diff -r c25b815c29e3 -r 7891ff4c8e91 libpurple/protocols/zephyr/.todo --- a/libpurple/protocols/zephyr/.todo Thu Apr 19 18:44:40 2007 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,153 +0,0 @@ - - - - God help us. - - Yup - - - - clean up code - - Being worked on - - - - write code to output a WGFILE with a sane name - - done - - - - get server supplied subscriptions to properly get added as chats - - works. - - - - zephyr freezes up sometimes (possibly when zlocating, and possibly when krb tickets have expired)? Debug and fix - - This is a libzephyr bug. I suppose I could always submit it upstream.... - - - - Does away actually work for zephyr - - - Deal with %host% and %canon, and unsubscriptions (beginning with ! and - ?) - - dealt with %host% and %canon%. - - - - Code to resubscribe, reload subs from file, set exposure, zctl ret, zctl new_server, set signature, set display, and other protocol options. - - dealt with resubscriptions, "zctl ret". - - - - Add zctl ret ("Show what the server thinks you're subscribed to") - - Done - - - - should pop up errors when subs (with the sub command or zephyr_join_chat) fails - - - update the progress bar for zephyr - - - get non-kerberized zephyr working for windows - - buggy, untested code exists on hard driveSee 991208, basically works - - - - get kerberized zephyr working for windows - - see 991208 - - - - get opener and closer tags for @ formatting to only match the correct closing tag, not any closing tag (e.g. [ matches ], and not ) - - tested, but code needs cleanup - - - - use tzc as a backend - - code exists on hard drive but needs lots of work (cleanup, and bug checking) - - - - properly detect when subscriptions get lost - - - support zcrypt - - Written as a perl plugin (for receiving) - - - - support /commands - - /msg (personals), /zl, /inst, /zc, /zi, /zci, /zir, /zcir now supported - - - - look for more memory leaks - - - Add instance name tabbing support - - - Add support for typing notification (using PING's) - - done - - - - Make zlocate be more efficient - - - add zstat support - - - remove unused imhtml buttons (background color, link description) - - done - - - - Intergalactic zephyr support - - - support multiple zephyr accounts - - Depends on "use tzc as a backend" - - - - support gpg - - Maybe this should go with gaim-e (gaim-encryption). possibly more useful as a plugin - - - - import chats into blist.xml and autojoin on startup? - - - support kzwrite - - possibly only useful at MIT. kzwrite might be deprecated - - - - add xzewd like buddy faces - - This may only be useful at MIT. Uses out of protocol mechanisms to get buddy pixmap (hesiod to determine user's homedirectory, and AFS to retrieve the file. - - - diff -r c25b815c29e3 -r 7891ff4c8e91 pidgin/gtkstatusbox.c --- a/pidgin/gtkstatusbox.c Thu Apr 19 18:44:40 2007 +0000 +++ b/pidgin/gtkstatusbox.c Thu Apr 19 21:14:29 2007 +0000 @@ -540,6 +540,32 @@ ); } +static GdkPixbuf * +pidgin_status_box_get_pixbuf(PidginStatusBox *status_box, PurpleStatusPrimitive prim) +{ + GdkPixbuf *pixbuf; + GtkIconSize icon_size = gtk_icon_size_from_name(PIDGIN_ICON_SIZE_TANGO_EXTRA_SMALL); + if (prim == PURPLE_STATUS_UNAVAILABLE) + pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_BUSY, + icon_size, "PidginStatusBox"); + else if (prim == PURPLE_STATUS_AWAY) + pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_AWAY, + icon_size, "PidginStatusBox"); + else if (prim == PURPLE_STATUS_EXTENDED_AWAY) + pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_XA, + icon_size, "PidginStatusBox"); + else if (prim == PURPLE_STATUS_INVISIBLE) + pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_INVISIBLE, + icon_size, "PidginStatusBox"); + else if (prim == PURPLE_STATUS_OFFLINE) + pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_OFFLINE, + icon_size, "PidginStatusBox"); + else + pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_AVAILABLE, + icon_size, "PidginStatusBox"); + return pixbuf; +} + /** * This updates the text displayed on the status box so that it shows * the current status. This is the only function in this file that @@ -636,7 +662,6 @@ { PurpleStatusType *status_type; PurpleStatusPrimitive prim; - GtkIconSize icon_size = gtk_icon_size_from_name(PIDGIN_ICON_SIZE_TANGO_EXTRA_SMALL); if (account_status) { status_type = purple_status_get_type(purple_account_get_active_status(acct)); prim = purple_status_type_get_primitive(status_type); @@ -644,21 +669,7 @@ prim = purple_savedstatus_get_type(saved_status); } - if (prim == PURPLE_STATUS_UNAVAILABLE) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_BUSY, - icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_AWAY) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_AWAY, - icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_EXTENDED_AWAY) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_XA, - icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_OFFLINE) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_OFFLINE, - icon_size, "PidginStatusBox"); - else - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_AVAILABLE, - icon_size, "PidginStatusBox"); + pixbuf = pidgin_status_box_get_pixbuf(status_box, prim); #if 0 if (account_status) pixbuf = pidgin_create_prpl_icon_with_status(acct, @@ -876,7 +887,6 @@ static void add_popular_statuses(PidginStatusBox *statusbox) { - GtkIconSize icon_size; GList *list, *cur; GdkPixbuf *pixbuf; @@ -885,8 +895,6 @@ /* Odd... oh well, nothing we can do about it. */ return; - icon_size = gtk_icon_size_from_name(PIDGIN_ICON_SIZE_TANGO_EXTRA_SMALL); - pidgin_status_box_add_separator(statusbox); for (cur = list; cur != NULL; cur = cur->next) @@ -899,21 +907,8 @@ /* Get an appropriate status icon */ prim = purple_savedstatus_get_type(saved); - if (prim == PURPLE_STATUS_UNAVAILABLE) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(statusbox), - PIDGIN_STOCK_STATUS_BUSY, icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_AWAY) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(statusbox), - PIDGIN_STOCK_STATUS_AWAY, icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_EXTENDED_AWAY) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(statusbox), - PIDGIN_STOCK_STATUS_XA, icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_OFFLINE) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(statusbox), - PIDGIN_STOCK_STATUS_OFFLINE, icon_size, "PidginStatusBox"); - else - pixbuf = gtk_widget_render_icon (GTK_WIDGET(statusbox), - PIDGIN_STOCK_STATUS_AVAILABLE, icon_size, "PidginStatusBox"); + + pixbuf = pidgin_status_box_get_pixbuf(statusbox, prim); if (purple_savedstatus_is_transient(saved)) { @@ -1019,28 +1014,13 @@ { PurpleStatusType *status_type = (PurpleStatusType *)l->data; PurpleStatusPrimitive prim; - GtkIconSize icon_size = gtk_icon_size_from_name(PIDGIN_ICON_SIZE_TANGO_EXTRA_SMALL); if (!purple_status_type_is_user_settable(status_type)) continue; prim = purple_status_type_get_primitive(status_type); - if (prim == PURPLE_STATUS_UNAVAILABLE) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_BUSY, - icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_AWAY) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_AWAY, - icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_EXTENDED_AWAY) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_XA, - icon_size, "PidginStatusBox"); - else if (prim == PURPLE_STATUS_OFFLINE) - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_OFFLINE, - icon_size, "PidginStatusBox"); - else - pixbuf = gtk_widget_render_icon (GTK_WIDGET(status_box), PIDGIN_STOCK_STATUS_AVAILABLE, - icon_size, "PidginStatusBox"); + pixbuf = pidgin_status_box_get_pixbuf(status_box, prim); pidgin_status_box_add(PIDGIN_STATUS_BOX(status_box), PIDGIN_STATUS_BOX_TYPE_PRIMITIVE, pixbuf, diff -r c25b815c29e3 -r 7891ff4c8e91 pidgin/gtkutils.c --- a/pidgin/gtkutils.c Thu Apr 19 18:44:40 2007 +0000 +++ b/pidgin/gtkutils.c Thu Apr 19 21:14:29 2007 +0000 @@ -1569,6 +1569,9 @@ else if (prim == PURPLE_STATUS_EXTENDED_AWAY) pixbuf = gtk_widget_render_icon (w, PIDGIN_STOCK_STATUS_XA, icon_size, "GtkWidget"); + else if (prim == PURPLE_STATUS_INVISIBLE) + pixbuf = gtk_widget_render_icon (w, PIDGIN_STOCK_STATUS_INVISIBLE, + icon_size, "GtkWidget"); else if (prim == PURPLE_STATUS_OFFLINE) pixbuf = gtk_widget_render_icon (w, PIDGIN_STOCK_STATUS_OFFLINE, icon_size, "GtkWidget");