Use win32 functions for accessing filename
authorJohn Darrington <john@darrington.wattle.id.au>
Wed, 27 Jan 2016 19:18:20 +0000 (20:18 +0100)
committerJohn Darrington <john@darrington.wattle.id.au>
Sat, 30 Jan 2016 19:57:09 +0000 (20:57 +0100)
src/ui/gui/main.c
src/ui/gui/psppire.c
src/ui/gui/psppire.h

index 9bd278d3397965ef1c0b5d8b52d141decc930bdf..59ee43a7e7583bab55d12c0c75fc32c3bf167dd9 100644 (file)
@@ -300,7 +300,7 @@ main (int argc, char *argv[])
   ((struct init_source *) ss)->argc = &argc;
   ((struct init_source *) ss)->argv = &argv;
   ((struct init_source *) ss)->loop = loop;
-  ((struct init_source *) ss)->file = optind < argc ? argv[optind] : NULL;
+  ((struct init_source *) ss)->filename_arg = optind < argc ? optind : -1;
   
   g_source_unref (ss);
 
index 9ed7d15becb3e4757006d6bbfcc95238eb2c605e..1b0031b23f1303cf1ae65079e1ce84c97e40cc12 100644 (file)
@@ -126,12 +126,23 @@ initialize (const struct init_source *is)
       break;
     case 14:
       {
-      if (is->file)
+      if (is->filename_arg != -1)
        {
+#ifndef G_OS_WIN32
+         const char *file = (*is->argv)[is->filename_arg];
          const gchar *local_encoding = NULL;
          g_get_charset (&local_encoding);
-
-         struct file_handle *fh = fh_create_file (NULL, is->file, local_encoding, fh_default_properties ());
+#else
+         char **as = g_win32_get_command_line ();
+         const char *file = as[is->filename_arg];
+         const gchar *local_encoding = "UTF-8";
+#endif   
+
+         struct file_handle *fh = fh_create_file (NULL,
+                                                  file,
+                                                  local_encoding,
+                                                  fh_default_properties ());
+         
          const char *filename = fh_get_file_name (fh);
 
          int retval = any_reader_detect (fh, NULL);
index e0b3bcb133f00d8f878b8aea531d75a9b590cd89..32a412be35847dc98d433ddeed81610790706016 100644 (file)
@@ -29,7 +29,7 @@ struct init_source
   GSource parent;
   int state;
   GMainLoop *loop;
-  gchar *file;
+  int filename_arg;
   int *argc;
   char ***argv;
 };