]> git.street.me.uk Git - andy/viking.git/blob - src/main.c
Merge branch 'TrackMergeSplitImprovements'
[andy/viking.git] / src / main.c
1 /*
2  * viking -- GPS Data and Topo Analyzer, Explorer, and Manager
3  *
4  * Copyright (C) 2003-2005, Evan Battaglia <gtoevan@gmx.net>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  */
21
22 #ifdef HAVE_CONFIG
23 #include "config.h"
24 #endif /* HAVE_CONFIG */
25
26 #include "viking.h"
27 #include "icons/icons.h"
28 #include "mapcache.h"
29 #include "background.h"
30 #include "dems.h"
31 #include "babel.h"
32 #include "curl_download.h"
33 #include "preferences.h"
34 #include "globals.h"
35 #include "vikmapslayer.h"
36
37 #ifdef VIK_CONFIG_GEOCACHES
38 void a_datasource_gc_init();
39 #endif
40
41 #ifdef HAVE_STDLIB_H
42 #include <stdlib.h>
43 #endif
44 #ifdef HAVE_STRING_H
45 #include <string.h>
46 #endif
47
48 #include <glib/gprintf.h>
49 #include <glib/gi18n.h>
50
51 #include "modules.h"
52
53 /* FIXME LOCALEDIR must be configured by ./configure --localedir */
54 /* But something does not work actually. */
55 /* So, we need to redefine this variable on windows. */
56 #ifdef WINDOWS
57 #undef LOCALEDIR
58 #define LOCALEDIR "locale"
59 #endif
60
61 #if GLIB_CHECK_VERSION (2, 32, 0)
62 /* Callback to log message */
63 static void log_debug(const gchar *log_domain,
64                       GLogLevelFlags log_level,
65                       const gchar *message,
66                       gpointer user_data)
67 {
68   g_print("** (viking): DEBUG: %s\n", message);
69 }
70 #else
71 /* Callback to mute log message */
72 static void mute_log(const gchar *log_domain,
73                      GLogLevelFlags log_level,
74                      const gchar *message,
75                      gpointer user_data)
76 {
77   /* Nothing to do, we just want to mute */
78 }
79 #endif
80
81 /* Options */
82 static GOptionEntry entries[] = 
83 {
84   { "debug", 'd', 0, G_OPTION_ARG_NONE, &vik_debug, N_("Enable debug output"), NULL },
85   { "verbose", 'V', 0, G_OPTION_ARG_NONE, &vik_verbose, N_("Enable verbose output"), NULL },
86   { "version", 'v', 0, G_OPTION_ARG_NONE, &vik_version, N_("Show version"), NULL },
87   { NULL }
88 };
89
90 int main( int argc, char *argv[] )
91 {
92   VikWindow *first_window;
93   GdkPixbuf *main_icon;
94   gboolean dashdash_already = FALSE;
95   int i = 0;
96   GError *error = NULL;
97   gboolean gui_initialized;
98         
99   bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR);  
100   bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
101   textdomain (GETTEXT_PACKAGE);
102
103   g_thread_init ( NULL );
104   gdk_threads_init ();
105
106   gui_initialized = gtk_init_with_args (&argc, &argv, "files+", entries, NULL, &error);
107   if (!gui_initialized)
108   {
109     /* check if we have an error message */
110     if (error == NULL)
111     {
112       /* no error message, the GUI initialization failed */
113       const gchar *display_name = gdk_get_display_arg_name ();
114       g_fprintf (stderr, "Failed to open display: %s\n", (display_name != NULL) ? display_name : " ");
115     }
116     else
117     {
118       /* yep, there's an error, so print it */
119       g_fprintf (stderr, "Parsing command line options failed: %s\n", error->message);
120       g_error_free (error);
121       g_fprintf (stderr, "Run \"%s --help\" to see the list of recognized options.\n",argv[0]);
122     }
123     return EXIT_FAILURE;
124   }
125    
126   if (vik_version)
127   {
128     g_printf ("%s %s\nCopyright (c) 2003-2008 Evan Battaglia\nCopyright (c) 2008-2012 Viking's contributors\n", PACKAGE_NAME, PACKAGE_VERSION);
129     return EXIT_SUCCESS;
130   }
131
132 #if GLIB_CHECK_VERSION (2, 32, 0)
133   if (vik_debug)
134     g_log_set_handler (NULL, G_LOG_LEVEL_DEBUG, log_debug, NULL);
135 #else
136   if (!vik_debug)
137     g_log_set_handler (NULL, G_LOG_LEVEL_DEBUG, mute_log, NULL);
138 #endif
139
140   a_preferences_init ();
141
142   a_vik_preferences_init ();
143
144   a_download_init();
145   curl_download_init();
146
147   a_babel_init ();
148
149   /* Init modules/plugins */
150   modules_init();
151
152   maps_layer_init ();
153   a_mapcache_init ();
154   a_background_init ();
155
156 #ifdef VIK_CONFIG_GEOCACHES
157   a_datasource_gc_init();
158 #endif
159
160   /* Set the icon */
161   main_icon = gdk_pixbuf_from_pixdata(&viking_pixbuf, FALSE, NULL);
162   gtk_window_set_default_icon(main_icon);
163
164   /* Create the first window */
165   first_window = vik_window_new_window();
166
167   gdk_threads_enter ();
168   while ( ++i < argc ) {
169     if ( strcmp(argv[i],"--") == 0 && !dashdash_already )
170       dashdash_already = TRUE; /* hack to open '-' */
171     else
172       vik_window_open_file ( first_window, argv[i], argc == 2 );
173   }
174
175   gtk_main ();
176   gdk_threads_leave ();
177
178   a_babel_uninit ();
179
180   a_background_uninit ();
181   a_mapcache_uninit ();
182   a_dems_uninit ();
183   a_preferences_uninit ();
184
185   curl_download_uninit();
186
187   return 0;
188 }