X-Git-Url: https://git.street.me.uk/andy/viking.git/blobdiff_plain/a5daec1c5958e0be8aa108aa37d748b7d95fa363..2b756ea0f81ebe3ef92ba3d40b67b9ad0d2e19e6:/src/main.c diff --git a/src/main.c b/src/main.c index ec35b84e..7aafb44e 100644 --- a/src/main.c +++ b/src/main.c @@ -24,11 +24,18 @@ #endif /* HAVE_CONFIG */ #include "viking.h" -#include "icons/viking_icon.png_h" +#include "icons/icons.h" #include "mapcache.h" #include "background.h" #include "dems.h" #include "curl_download.h" +#include "preferences.h" +#include "globals.h" +#include "vikmapslayer.h" + +#ifdef VIK_CONFIG_GEOCACHES +void a_datasource_gc_init(); +#endif #include #include @@ -40,6 +47,14 @@ #define MAX_WINDOWS 1024 +/* FIXME LOCALEDIR must be configured by ./configure --localedir */ +/* But something does not work actually. */ +/* So, we need to redefine this variable on windows. */ +#ifdef WINDOWS +#undef LOCALEDIR +#define LOCALEDIR "locale" +#endif + static guint window_count = 0; static VikWindow *new_window (); @@ -47,6 +62,14 @@ static void open_window ( VikWindow *vw, const gchar **files ); static void destroy( GtkWidget *widget, gpointer data ); +/* Callback to mute log message */ +static void mute_log(const gchar *log_domain, + GLogLevelFlags log_level, + const gchar *message, + gpointer user_data) +{ + /* Nothing to do, we just want to mute */ +} /* Another callback */ static void destroy( GtkWidget *widget, @@ -89,11 +112,11 @@ static void open_window ( VikWindow *vw, const gchar **files ) } /* Options */ -static gboolean version = FALSE; - static GOptionEntry entries[] = { - { "version", 'v', 0, G_OPTION_ARG_NONE, &version, "Show version", NULL }, + { "debug", 'd', 0, G_OPTION_ARG_NONE, &vik_debug, N_("Enable debug output"), NULL }, + { "verbose", 'V', 0, G_OPTION_ARG_NONE, &vik_verbose, N_("Enable verbose output"), NULL }, + { "version", 'v', 0, G_OPTION_ARG_NONE, &vik_version, N_("Show version"), NULL }, { NULL } }; @@ -133,24 +156,35 @@ int main( int argc, char *argv[] ) return EXIT_FAILURE; } - if (version) + if (vik_version) { - g_printf ("%s %s, Copyright (c) 2003-2007 Evan Battaglia\n", PACKAGE_NAME, PACKAGE_VERSION); + g_printf ("%s %s, Copyright (c) 2003-2008 Evan Battaglia\n", PACKAGE_NAME, PACKAGE_VERSION); return EXIT_SUCCESS; } + if (!vik_debug) + g_log_set_handler (NULL, G_LOG_LEVEL_DEBUG, mute_log, NULL); + + a_preferences_init (); + + a_vik_preferences_init (); + + a_download_init(); curl_download_init(); /* Init modules/plugins */ modules_init(); + maps_layer_init (); a_mapcache_init (); a_background_init (); - vik_layer_cursors_init (); - vik_window_cursors_init (); + +#ifdef VIK_CONFIG_GEOCACHES + a_datasource_gc_init(); +#endif /* Set the icon */ - main_icon = gdk_pixbuf_from_pixdata(&viking_icon, FALSE, NULL); + main_icon = gdk_pixbuf_from_pixdata(&viking_pixbuf, FALSE, NULL); gtk_window_set_default_icon(main_icon); /* Create the first window */ @@ -167,10 +201,10 @@ int main( int argc, char *argv[] ) gtk_main (); gdk_threads_leave (); + a_background_uninit (); a_mapcache_uninit (); a_dems_uninit (); - vik_layer_cursors_uninit (); - vik_window_cursors_uninit (); + a_preferences_uninit (); return 0; }