]> git.street.me.uk Git - andy/viking.git/blobdiff - src/main.c
Add Windows' path to configuration files
[andy/viking.git] / src / main.c
index 8b6263a4844891cdcbdf4abc5d5ef212666a57d4..3de336f4779936707cb28ff3533b4679f294b2ed 100644 (file)
@@ -28,6 +28,7 @@
 #include "mapcache.h"
 #include "background.h"
 #include "dems.h"
+#include "babel.h"
 #include "curl_download.h"
 #include "preferences.h"
 #include "globals.h"
 void a_datasource_gc_init();
 #endif
 
+#ifdef HAVE_STDLIB_H
 #include <stdlib.h>
+#endif
+#ifdef HAVE_STRING_H
 #include <string.h>
+#endif
 
 #include <glib/gprintf.h>
 #include <glib/gi18n.h>
@@ -103,18 +108,23 @@ static VikWindow *new_window ()
 
 static void open_window ( VikWindow *vw, const gchar **files )
 {
-  VikWindow *newvw = new_window();
   gboolean change_fn = (!files[1]); /* only change fn if one file */
-  if ( newvw )
-    while ( *files ) {
-      vik_window_open_file ( newvw, *(files++), change_fn );
+  while ( *files ) {
+    // Only open a new window if a viking file
+    if (vw != NULL && check_file_magic_vik ( *(files) ) ) {
+      VikWindow *newvw = new_window();
+      if (newvw)
+       vik_window_open_file ( newvw, *(files++), change_fn );
     }
+    else {
+      vik_window_open_file ( vw, *(files++), change_fn );
+    }
+  }
 }
 
 /* Options */
 static GOptionEntry entries[] = 
 {
-  { "small_waypoint", 's', 0, G_OPTION_ARG_NONE, &vik_use_small_wp_icons, N_("Use smaller symbols for waypoints"), 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 },
@@ -159,7 +169,7 @@ int main( int argc, char *argv[] )
    
   if (vik_version)
   {
-    g_printf ("%s %s, Copyright (c) 2003-2008 Evan Battaglia\n", PACKAGE_NAME, PACKAGE_VERSION);
+    g_printf ("%s %s\nCopyright (c) 2003-2008 Evan Battaglia\nCopyright (c) 2008-2010 Viking's contributors\n", PACKAGE_NAME, PACKAGE_VERSION);
     return EXIT_SUCCESS;
   }
 
@@ -173,6 +183,8 @@ int main( int argc, char *argv[] )
   a_download_init();
   curl_download_init();
 
+  a_babel_init ();
+
   /* Init modules/plugins */
   modules_init();
 
@@ -202,10 +214,14 @@ int main( int argc, char *argv[] )
   gtk_main ();
   gdk_threads_leave ();
 
+  a_babel_uninit ();
+
   a_background_uninit ();
   a_mapcache_uninit ();
   a_dems_uninit ();
   a_preferences_uninit ();
 
+  curl_download_uninit();
+
   return 0;
 }