itti_analyzer.c 3.91 KB
Newer Older
1 2 3 4 5 6 7
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>

#include <gtk/gtk.h>

winckel's avatar
winckel committed
8 9
#include <libxml/parser.h>

10 11 12 13 14 15 16 17
#include "xml_parse.h"
#include "resolvers.h"
#include "locate_root.h"
#include "file.h"
#include "ui_main_screen.h"

#include "rc.h"

18 19 20 21 22 23 24
#define G_LOG_LEVELS (G_LOG_LEVEL_ERROR     | \
                      G_LOG_LEVEL_CRITICAL  | \
                      G_LOG_LEVEL_WARNING   | \
                      G_LOG_LEVEL_MESSAGE   | \
                      G_LOG_LEVEL_INFO      | \
                      G_LOG_LEVEL_DEBUG)

25 26 27
int debug_buffers = 1;
int debug_parser = 0;

28 29
static void console_log_handler(const char *log_domain, GLogLevelFlags log_level,
                                const char *message, gpointer user_data)
30
{
31
    GLogLevelFlags domain_log_level = (GLogLevelFlags) user_data;
32 33 34 35
    time_t curr;
    struct tm *today;
    const char *level;

36
    if (ui_main_data.log_flags & domain_log_level & log_level)
37 38 39
    {
        switch (log_level & G_LOG_LEVEL_MASK)
        {
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
        case G_LOG_LEVEL_ERROR:
            level = "Err ";
            break;
        case G_LOG_LEVEL_CRITICAL:
            level = "Crit";
            break;
        case G_LOG_LEVEL_WARNING:
            level = "Warn";
            break;
        case G_LOG_LEVEL_MESSAGE:
            level = "Msg ";
            break;
        case G_LOG_LEVEL_INFO:
            level = "Info";
            break;
        case G_LOG_LEVEL_DEBUG:
            level = "Dbg ";
            break;
        default:
            fprintf(stderr, "unknown log_level %u\n", log_level);
            level = NULL;
            g_assert_not_reached();
winckel's avatar
winckel committed
62
            break;
63
        }
64

65 66 67
        /* create a "timestamp" */
        time(&curr);
        today = localtime(&curr);
68

69
        fprintf(stderr, "%02u:%02u:%02u %-9s %s %s\n", today->tm_hour, today->tm_min, today->tm_sec,
70 71
                log_domain != NULL ? log_domain : "", level, message);
    }
72 73
}

74 75 76 77
int main(int argc, char *argv[])
{
    int ret = 0;

78 79 80 81 82 83 84 85
    GLogLevelFlags log_flags;

    log_flags = (GLogLevelFlags)
        (G_LOG_LEVEL_ERROR      |
        G_LOG_LEVEL_CRITICAL    |
        G_LOG_LEVEL_WARNING     |
        G_LOG_LEVEL_MESSAGE     |
        G_LOG_LEVEL_INFO        |
86
        G_LOG_LEVEL_DEBUG);
87

winckel's avatar
winckel committed
88 89 90 91
    /* This initialize the library and check potential ABI mismatches
     * between the version it was compiled for and the actual shared
     * library used.
     */
92 93
    LIBXML_TEST_VERSION;
    xmlInitParser();
winckel's avatar
winckel committed
94

95 96 97
    /* Initialize the widget set */
    gtk_init(&argc, &argv);

98 99 100 101 102 103 104
    /* Parse command line options */
    ui_gtk_parse_arg (argc, argv);

    /* Set log handlers:
     *                 Domain,      Levels,    Handler,             Domain enabled levels */
    g_log_set_handler( NULL,        log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS));
    g_log_set_handler("BUFFERS",    log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS & (~(G_LOG_LEVEL_DEBUG))));
105
    g_log_set_handler("PARSER",     log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS & (~(G_LOG_LEVEL_DEBUG))));
106 107 108 109 110 111
    g_log_set_handler("RESOLVER",   log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS & (~(G_LOG_LEVEL_DEBUG))));
    g_log_set_handler("UI",         log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS & (~(G_LOG_LEVEL_DEBUG))));
    g_log_set_handler("UI_CB",      log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS));
    g_log_set_handler("UI_FILTER",  log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS & (~(G_LOG_LEVEL_DEBUG))));
    g_log_set_handler("UI_INTER",   log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS));
    g_log_set_handler("UI_TREE",    log_flags, console_log_handler, (gpointer) (G_LOG_LEVELS & (~(G_LOG_LEVEL_DEBUG))));
112

113 114
    CHECK_FCT(ui_gtk_initialize(argc, argv));

115 116 117
    /* Enter the main event loop, and wait for user interaction */
    gtk_main ();

118 119 120 121 122
    /* Free the global variables that may
     * have been allocated by the parser.
     */
    xmlCleanupParser ();

123 124
    return ret;
}