]> 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 0c9e032402ab158b70b51f9a0dccbfd0d2d4f605..3de336f4779936707cb28ff3533b4679f294b2ed 100644 (file)
 #include "mapcache.h"
 #include "background.h"
 #include "dems.h"
+#include "babel.h"
 #include "curl_download.h"
 #include "preferences.h"
 #include "globals.h"
+#include "vikmapslayer.h"
 
 #ifdef VIK_CONFIG_GEOCACHES
 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>
@@ -102,12 +108,18 @@ 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 */
@@ -157,22 +169,26 @@ int main( int argc, char *argv[] )
    
   if (vik_version)
   {
-    g_printf ("%s %s, Copyright (c) 2003-2007 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;
   }
 
   if (!vik_debug)
     g_log_set_handler (NULL, G_LOG_LEVEL_DEBUG, mute_log, NULL);
 
-  curl_download_init();
-
   a_preferences_init ();
 
   a_vik_preferences_init ();
 
+  a_download_init();
+  curl_download_init();
+
+  a_babel_init ();
+
   /* Init modules/plugins */
   modules_init();
 
+  maps_layer_init ();
   a_mapcache_init ();
   a_background_init ();
 
@@ -181,7 +197,7 @@ int main( int argc, char *argv[] )
 #endif
 
   /* Set the icon */
-  main_icon = gdk_pixbuf_from_pixdata(&viking_icon_pixbuf, FALSE, NULL);
+  main_icon = gdk_pixbuf_from_pixdata(&viking_pixbuf, FALSE, NULL);
   gtk_window_set_default_icon(main_icon);
 
   /* Create the first window */
@@ -198,9 +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;
 }