Mercurial > pidgin
view src/multi.h @ 5438:6e7ba9efd1f4
[gaim-migrate @ 5820]
I wrote sort-by-status.
Index: src/gtkblist.c
===================================================================
RCS file: /cvsroot/gaim/gaim/src/gtkblist.c,v
retrieving revision 1.28
diff -u -r1.28 gtkblist.c
--- src/gtkblist.c 18 May 2003 07:54:53 -0000 1.28
+++ src/gtkblist.c 18 May 2003 21:13:36 -0000
@@ -1319,11 +1320,11 @@
void gaim_gtk_blist_setup_sort_methods()
{
- gaim_gtk_blist_sort_method_reg("None", sort_method_none);
- gaim_gtk_blist_sort_method_reg("Alphabetical", sort_method_alphabetical);
- gaim_gtk_blist_sort_method_reg("By status", sort_method_status);
- gaim_gtk_blist_sort_method_reg("By log size", sort_method_log);
- gaim_gtk_blist_sort_method_set(sort_method[0] ? sort_method : "None");
+ gaim_gtk_blist_sort_method_reg(_("None"), sort_method_none);
+ gaim_gtk_blist_sort_method_reg(_("Alphabetical"), sort_method_alphabetical);
+ gaim_gtk_blist_sort_method_reg(_("By status"), sort_method_status);
+ gaim_gtk_blist_sort_method_reg(_("By log size"), sort_method_log);
+ gaim_gtk_blist_sort_method_set(sort_method[0] ? sort_method : _("None"));
}
@@ -2229,15 +2230,23 @@
if (n && GAIM_BLIST_NODE_IS_BUDDY(n)) {
struct buddy *new = (struct buddy*)node, *it = (struct buddy*)n;
- - if (it->idle > new->idle)
+ printf("Add %s (%d) before %s (%d)... ", new->name, new->idle, it->name, it->idle);
+ + /* This is the worst if statement ever. */
+ if ((it->present < new->present) ||
+ ((it->present == new->present) && (it->uc & UC_UNAVAILABLE) > (new->uc & UC_UNAVAILABLE)) ||
+ ((it->present == new->present) && ((it->uc & UC_UNAVAILABLE) == (new->uc & UC_UNAVAILABLE)) &&
+ ((it->idle && !new->idle) || (it->idle && (it->idle < new->idle)))) ||
+ + ((it->present == new->present) && (it->uc & UC_UNAVAILABLE) == (new->uc & UC_UNAVAILABLE) && (it->idle == new->idle) &&
+ (gaim_utf8_strcasecmp(gaim_get_buddy_alias((struct buddy*)node), gaim_get_buddy_alias((struct buddy*)n)) < 0)))
{
- printf("Inserting %s before %s\n", new->name, it->name);
+ printf("yes\n");
gtk_tree_store_insert_before(gtkblist->treemodel, &iter, &groupiter, &more_z);
newpath = gtk_tree_model_get_path(GTK_TREE_MODEL(gtkblist->treemodel), &iter);
gtknode->row = gtk_tree_row_reference_new(GTK_TREE_MODEL(gtkblist->treemodel), newpath);
gtk_tree_path_free(newpath);
return iter;
}
+ printf("no\n");
g_value_unset(&val);
}
} while (gtk_tree_model_iter_next (GTK_TREE_MODEL(gtkblist->treemodel), &more_z));
committer: Tailor Script <tailor@pidgin.im>
author | Sean Egan <seanegan@gmail.com> |
---|---|
date | Sun, 18 May 2003 21:17:31 +0000 |
parents | 890b29f00b68 |
children | df653f6f2978 |
line wrap: on
line source
/* * gaim * * Copyright (C) 1998-1999, Mark Spencer <markster@marko.net> * * 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 * */ #ifndef _MULTI_H_ #define _MULTI_H_ #include "core.h" #include "plugin.h" /* ok. now the fun begins. first we create a connection structure */ struct gaim_connection { int edittype; /* XXX CUI: this is ui-specific and should be removed */ /* we need to do either oscar or TOC */ /* we make this as an int in case if we want to add more protocols later */ int protocol; GaimPlugin *prpl; guint32 flags; /* erg. */ char *checkbox; /* all connections need an input watcher */ int inpa; /* all connections need a list of chats, even if they don't have chat */ GSList *buddy_chats; /* each connection then can have its own protocol-specific data */ void *proto_data; struct gaim_account *account; char username[64]; char displayname[128]; char password[32]; guint keepalive; /* stuff needed for per-connection idle times */ guint idle_timer; time_t login_time; time_t login_time_official; time_t lastsent; int is_idle; char *away; /* set by protos, is NULL when not away, or set * * to "" or a custom message when away */ char *away_state; /* updated by serv_set_away, keeps the last set * * away type */ int is_auto_away; /* used by idle.c */ int evil; /* warning level for AIM (why is this here?) */ gboolean wants_to_die; /* defaults to FALSE */ }; #define OPT_CONN_HTML 0x00000001 /* set this flag on a gc if you want serv_got_im to autoreply when away */ #define OPT_CONN_AUTO_RESP 0x00000002 struct proto_user_split { char sep; char *label; char *def; }; struct proto_user_opt { char *label; char *def; int pos; }; struct proto_actions_menu { char *label; void (*callback)(struct gaim_connection *); struct gaim_connection *gc; }; struct proto_buddy_menu { char *label; void (*callback)(struct gaim_connection *, const char *); struct gaim_connection *gc; }; struct proto_chat_entry { char *label; char *identifier; char *def; gboolean is_int; int min; int max; }; /* now that we have our struct, we're going to need lots of them. Maybe even a list of them. */ extern GSList *connections; /* number of accounts that are currently in the process of connecting */ extern int connecting_count; struct gaim_account *gaim_account_new(const char *, int, int); struct gaim_connection *new_gaim_conn(struct gaim_account *); void destroy_gaim_conn(struct gaim_connection *); void regenerate_user_list(); void account_online(struct gaim_connection *); void account_offline(struct gaim_connection *); void auto_login(); void set_login_progress(struct gaim_connection *, float, char *); void hide_login_progress(struct gaim_connection *, char *); void hide_login_progress_notice(struct gaim_connection *, char *); void hide_login_progress_error(struct gaim_connection *, char *); #endif /* _MULTI_H_ */