Mercurial > pidgin.yaz
view console/libgnt/test/keys.c @ 14484:1f81919515ae
[gaim-migrate @ 17203]
Part of SF Patch #1554627 from Richard Nelson (wabz)
"The msn protocol currently calls serv_got_alias on all
buddy status changes (as they are NLN commands),
resulting in lots of unnecessary blist.xml write schedules.
serv_got_alias already checks if the alias has actually
changed before printing to the conv. The first hunk in
this patch checks it a bit earlier."
The second hunk checks in the MSN prpl, which also avoids
an extra call to msn_user_set_friendly_name().
committer: Tailor Script <tailor@pidgin.im>
author | Richard Laager <rlaager@wiktel.com> |
---|---|
date | Sat, 09 Sep 2006 20:27:48 +0000 |
parents | a766441af5ea |
children |
line wrap: on
line source
#include <gnt.h> #include <gntbox.h> #include <gntentry.h> #include <gntlabel.h> static gboolean print_keycode(GntEntry *entry, const char *text, gpointer null) { char *s = g_strdup_printf("%s ", text); gnt_entry_set_text(entry, s); g_free(s); if (text[0] == 27) { if (strncmp(text + 1, "[M ", 3) == 0) { int x = (unsigned)text[4]; int y = (unsigned)text[5]; if (x < 0) x += 256; if (y < 0) y += 256; x -= 33; y -= 33; s = g_strdup_printf("ldown %d %d", x, y); gnt_entry_set_text(entry, s); g_free(s); } else if (strncmp(text + 1, "[M#", 3) == 0) gnt_entry_set_text(entry, "up"); else return FALSE; return TRUE; } else return TRUE; } int main() { GntWidget *window, *entry; gnt_init(); freopen(".error", "w", stderr); window = gnt_hbox_new(FALSE); gnt_box_set_toplevel(GNT_BOX(window), TRUE); gnt_box_add_widget(GNT_BOX(window), gnt_label_new("Press any key: ")); entry = gnt_entry_new(NULL); gnt_box_add_widget(GNT_BOX(window), entry); g_signal_connect(G_OBJECT(entry), "key_pressed", G_CALLBACK(print_keycode), NULL); gnt_widget_set_position(window, getmaxx(stdscr) / 2 - 12, getmaxy(stdscr) / 2 - 3); gnt_widget_show(window); gnt_main(); gnt_quit(); return 0; }