Mercurial > pidgin
view console/gntdebug.c @ 14428:f3645fe3da47
[gaim-migrate @ 17142]
Let's find the ncurses.h we're after, without a bunch of hacking in individual files for it. This checks for some ncursesw specific stuff, and now will not build gntgaim unless we have ncursesw.h. This could be adapted to just add a define in case we want to support non ncursesw, but this is more than adequate for the time being.
committer: Tailor Script <tailor@pidgin.im>
| author | Gary Kramlich <grim@reaperworld.com> |
|---|---|
| date | Sun, 03 Sep 2006 18:44:11 +0000 |
| parents | 43d9afee9c3c |
| children | 81650a27f253 |
line wrap: on
line source
#include <gnt.h> #include <gntbox.h> #include <gnttextview.h> #include "gntdebug.h" #include "gntgaim.h" #include <stdio.h> #include <string.h> static struct { GntWidget *window; GntWidget *tview; } debug; static gboolean debug_window_kpress_cb(GntWidget *wid, const char *key, GntTextView *view) { if (key[0] == 27) { if (strcmp(key+1, GNT_KEY_DOWN) == 0) gnt_text_view_scroll(view, 1); else if (strcmp(key+1, GNT_KEY_UP) == 0) gnt_text_view_scroll(view, -1); else if (strcmp(key+1, GNT_KEY_PGDOWN) == 0) gnt_text_view_scroll(view, wid->priv.height - 2); else if (strcmp(key+1, GNT_KEY_PGUP) == 0) gnt_text_view_scroll(view, -(wid->priv.height - 2)); else return FALSE; return TRUE; } return FALSE; } static void gg_debug_print(GaimDebugLevel level, const char *category, const char *args) { if (debug.window) { GntTextFormatFlags flag = GNT_TEXT_FLAG_NORMAL; gnt_text_view_append_text_with_flags(GNT_TEXT_VIEW(debug.tview), category, GNT_TEXT_FLAG_BOLD); gnt_text_view_append_text_with_flags(GNT_TEXT_VIEW(debug.tview), ": ", GNT_TEXT_FLAG_BOLD); switch (level) { case GAIM_DEBUG_WARNING: flag |= GNT_TEXT_FLAG_UNDERLINE; case GAIM_DEBUG_ERROR: case GAIM_DEBUG_FATAL: flag |= GNT_TEXT_FLAG_BOLD; break; default: break; } gnt_text_view_append_text_with_flags(GNT_TEXT_VIEW(debug.tview), args, flag); gnt_text_view_scroll(GNT_TEXT_VIEW(debug.tview), 0); } } static GaimDebugUiOps uiops = { gg_debug_print, }; GaimDebugUiOps *gg_debug_get_ui_ops() { return &uiops; } static void reset_debug_win(GntWidget *w, gpointer null) { debug.window = debug.tview = NULL; } static void print_stderr(const char *string) { g_printerr("%s", string); } void gg_debug_window_show() { if (debug.window == NULL) { debug.window = gnt_vbox_new(FALSE); gnt_box_set_toplevel(GNT_BOX(debug.window), TRUE); gnt_box_set_title(GNT_BOX(debug.window), _("Debug Window")); debug.tview = gnt_text_view_new(); gnt_box_add_widget(GNT_BOX(debug.window), debug.tview); /* XXX: Add checkboxes/buttons for Clear, Pause, Timestamps */ g_signal_connect(G_OBJECT(debug.window), "destroy", G_CALLBACK(reset_debug_win), NULL); g_signal_connect(G_OBJECT(debug.window), "key_pressed", G_CALLBACK(debug_window_kpress_cb), debug.tview); } gnt_widget_show(debug.window); } static gboolean start_with_debugwin(gpointer null) { gg_debug_window_show(); return FALSE; } void gg_debug_init() { g_set_print_handler(print_stderr); /* Redirect the debug messages to stderr */ if (gaim_debug_is_enabled()) g_timeout_add(0, start_with_debugwin, NULL); } void gg_debug_uninit() { }
