diff -r 4bd5c5d271e6 -r 1cdcbc2739a3 src/gtkblist.c
--- a/src/gtkblist.c Sun May 18 19:59:43 2003 +0000
+++ b/src/gtkblist.c Sun May 18 21:17:31 2003 +0000
@@ -870,21 +870,22 @@
accounttext = g_markup_escape_text(b->account->username, -1);
text = g_strdup_printf("%s"
- "%s %s" /* Account */
- "%s %s" /* Alias */
- "%s %s" /* Nickname */
- "%s %s" /* Idle */
- "%s %s" /* Warning */
- "%s%s" /* Status */
- "%s",
- b->name,
- accounttext ? _("\nAccount:") : "", accounttext ? accounttext : "",
- aliastext ? _("\nAlias:") : "", aliastext ? aliastext : "",
- nicktext ? _("\nNickname:") : "", nicktext ? nicktext : "",
- idletime ? _("\nIdle:") : "", idletime ? idletime : "",
- b->evil ? _("\nWarned:") : "", b->evil ? warning : "",
- statustext ? "\n" : "", statustext ? statustext : "",
- !g_ascii_strcasecmp(b->name, "robflynn") ? _("\nDescription: Spooky") : "");
+ "%s %s" /* Account */
+ "%s %s" /* Alias */
+ "%s %s" /* Nickname */
+ "%s %s" /* Idle */
+ "%s %s" /* Warning */
+ "%s%s" /* Status */
+ "%s",
+ b->name,
+ accounttext ? _("\nAccount:") : "", accounttext ? accounttext : "",
+ aliastext ? _("\nAlias:") : "", aliastext ? aliastext : "",
+ nicktext ? _("\nNickname:") : "", nicktext ? nicktext : "",
+ idletime ? _("\nIdle:") : "", idletime ? idletime : "",
+ b->evil ? _("\nWarned:") : "", b->evil ? warning : "",
+ statustext ? "\n" : "", statustext ? statustext : "",
+ !g_ascii_strcasecmp(b->name, "robflynn") ? _("\nDescription: Spooky") :
+ !g_ascii_strcasecmp(b->name, "seanegn") ? _("\nStatus: Awesome") : "");
if(warning)
g_free(warning);
@@ -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));