]> git.street.me.uk Git - andy/viking.git/blobdiff - src/datasource_gps.c
SF#3178554: Fix Sun Studio build
[andy/viking.git] / src / datasource_gps.c
index 6c341b1ef2724974fc2ded48833ce3e8b1661cc7..3e6ccced7c861e555321d3dc3bf07c251a1fcf01 100644 (file)
@@ -2,6 +2,8 @@
  * viking -- GPS Data and Topo Analyzer, Explorer, and Manager
  *
  * Copyright (C) 2003-2005, Evan Battaglia <gtoevan@gmx.net>
+ * Copyright (C) 2006, Alex Foobarian <foobarian@gmail.com>
+ * Copyright (C) 2010, Rob Norris <rw_norris@hotmail.com>
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
 #include "config.h"
 #endif
 #include <string.h>
+#ifdef HAVE_UNISTD_H
+#include <unistd.h>
+#endif
 
+#include <glib/gstdio.h>
 #include <glib/gprintf.h>
 #include <glib/gi18n.h>
 
@@ -43,6 +49,7 @@ static void datasource_gps_cleanup ( gpointer user_data );
 static void datasource_gps_progress ( BabelProgressCode c, gpointer data, acq_dialog_widgets_t *w );
 static void datasource_gps_add_setup_widgets ( GtkWidget *dialog, VikViewport *vvp, gpointer user_data );
 static void datasource_gps_add_progress_widgets ( GtkWidget *dialog, gpointer user_data );
+static void datasource_gps_off ( gpointer add_widgets_data_not_used, gchar **babelargs, gchar **input_file );
 
 VikDataSourceInterface vik_datasource_gps_interface = {
   N_("Acquire from GPS"),
@@ -51,13 +58,15 @@ VikDataSourceInterface vik_datasource_gps_interface = {
   VIK_DATASOURCE_CREATENEWLAYER,
   VIK_DATASOURCE_INPUTTYPE_NONE,
   TRUE,
+  TRUE,
   (VikDataSourceInitFunc)              datasource_gps_init_func,
   (VikDataSourceCheckExistenceFunc)    NULL,
   (VikDataSourceAddSetupWidgetsFunc)   datasource_gps_add_setup_widgets,
   (VikDataSourceGetCmdStringFunc)      datasource_gps_get_cmd_string,
   (VikDataSourceProgressFunc)          datasource_gps_progress,
   (VikDataSourceAddProgressWidgetsFunc)        datasource_gps_add_progress_widgets,
-  (VikDataSourceCleanupFunc)           datasource_gps_cleanup
+  (VikDataSourceCleanupFunc)           datasource_gps_cleanup,
+  (VikDataSourceOffFunc)                datasource_gps_off
 };
 
 /*********************************************************
@@ -73,6 +82,8 @@ typedef struct {
   GtkComboBox *proto_b;
   GtkWidget *ser_l;
   GtkComboBox *ser_b;
+  GtkWidget *off_request_l;
+  GtkCheckButton *off_request_b;
 
   /* progress dialog */
   GtkWidget *gps_label;
@@ -115,9 +126,16 @@ static void datasource_gps_get_cmd_string ( gpointer user_data, gchar **babelarg
 #endif
   if (!strcmp(proto, "Garmin")) {
     device = "garmin";
-  } else {
+  } else if (!strcmp(proto, "Magellan")) {
     device = "magellan";
   }
+  else if (!strcmp(proto, "DeLorme")) {
+    device = "delbin";
+  }
+  else {
+    device = "navilink";
+  }
+
   *babelargs = g_strdup_printf("-D 9 -t -w -i %s", device);
   /* device points to static content => no free */
   device = NULL;
@@ -133,6 +151,55 @@ static void datasource_gps_get_cmd_string ( gpointer user_data, gchar **babelarg
   g_debug(_("using cmdline '%s' and file '%s'\n"), *babelargs, *input_file);
 }
 
+
+static void datasource_gps_off ( gpointer user_data, gchar **babelargs, gchar **input_file )
+{
+  char *proto = NULL;
+  char *ser = NULL;
+  char *device = NULL;
+#ifndef USE_NEW_COMBO_BOX
+  GtkTreeIter iter;
+#endif
+  gps_user_data_t *w = (gps_user_data_t *)user_data;
+
+  if (gps_acquire_in_progress) {
+    *babelargs = *input_file = NULL;
+  }
+
+  /* See if we should turn off the device */
+  if (!gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(w->off_request_b))) {
+    return;
+  }
+  
+#ifdef USE_NEW_COMBO_BOX
+  proto = gtk_combo_box_get_active_text(GTK_COMBO_BOX(w->proto_b));
+#else
+  proto = gtk_combo_box_get_active_iter(GTK_COMBO_BOX(w->proto_b),&iter);
+#endif
+  if (!strcmp(proto, "Garmin")) {
+    device = "garmin,power_off";
+  }
+  else if (!strcmp(proto, "NAViLink")) {
+    device = "navilink,power_off";
+  }
+  else {
+    return;
+  }
+
+  *babelargs = g_strdup_printf("-i %s", device);
+  /* device points to static content => no free */
+  device = NULL;
+  
+  /* Old stuff */
+#ifdef USE_NEW_COMBO_BOX
+  ser = gtk_combo_box_get_active_text(GTK_COMBO_BOX(w->ser_b));
+#else
+  ser = gtk_combo_box_get_active_iter(GTK_COMBO_BOX(w->ser_b),&iter);
+#endif
+  *input_file = g_strdup(ser);
+}
+
+
 static void datasource_gps_cleanup ( gpointer user_data )
 {
   g_free ( user_data );
@@ -231,6 +298,18 @@ static void datasource_gps_progress ( BabelProgressCode c, gpointer data, acq_di
       }
       g_strfreev(tokens);
     }
+    /* eg: "Unit:\teTrex Legend HCx Software Version 2.90\n" */
+    if (strstr(line, "Unit:")) {
+      gchar **tokens = g_strsplit(line, "\t", 0);
+      int n_tokens = 0;
+      while (tokens[n_tokens])
+        n_tokens++;
+
+      if (n_tokens > 1) {
+        set_gps_info(tokens[1], w);
+      }
+      g_strfreev(tokens);
+    }
     if (strstr(line, "RECORD")) { 
       int lsb, msb, cnt;
 
@@ -263,6 +342,8 @@ void datasource_gps_add_setup_widgets ( GtkWidget *dialog, VikViewport *vvp, gpo
   w->proto_b = GTK_COMBO_BOX(gtk_combo_box_new_text ());
   gtk_combo_box_append_text (w->proto_b, "Garmin");
   gtk_combo_box_append_text (w->proto_b, "Magellan");
+  gtk_combo_box_append_text (w->proto_b, "DeLorme");
+  gtk_combo_box_append_text (w->proto_b, "NAViLink");
   gtk_combo_box_set_active (w->proto_b, 0);
   g_object_ref(w->proto_b);
 
@@ -271,20 +352,32 @@ void datasource_gps_add_setup_widgets ( GtkWidget *dialog, VikViewport *vvp, gpo
 #ifdef WINDOWS
   gtk_combo_box_append_text (w->ser_b, "com1");
 #else
-  gtk_combo_box_append_text (w->ser_b, "/dev/ttyS0");
-  gtk_combo_box_append_text (w->ser_b, "/dev/ttyS1");
-  gtk_combo_box_append_text (w->ser_b, "/dev/ttyUSB0");
-  gtk_combo_box_append_text (w->ser_b, "/dev/ttyUSB1");
+  /* Here just try to see if the device is available which gets passed onto gpsbabel
+     List USB devices first as these will generally only be present if autogenerated by udev or similar
+     User is still able to set their own free text entry */
+  if (g_access ("/dev/ttyUSB0", R_OK) == 0)
+    gtk_combo_box_append_text (w->ser_b, "/dev/ttyUSB0");
+  if (g_access ("/dev/ttyUSB1", R_OK) == 0)
+    gtk_combo_box_append_text (w->ser_b, "/dev/ttyUSB1");
+  if (g_access ("/dev/ttyS0", R_OK) == 0)
+    gtk_combo_box_append_text (w->ser_b, "/dev/ttyS0");
+  if (g_access ("/dev/ttyS1", R_OK) == 0)
+    gtk_combo_box_append_text (w->ser_b, "/dev/ttyS1");
 #endif
   gtk_combo_box_append_text (w->ser_b, "usb:");
   gtk_combo_box_set_active (w->ser_b, 0);
   g_object_ref(w->ser_b);
 
-  box = GTK_TABLE(gtk_table_new(2, 2, FALSE));
+  w->off_request_l = gtk_label_new (_("Turn Off After Transfer\n(Garmin/NAViLink Only)"));
+  w->off_request_b = GTK_CHECK_BUTTON ( gtk_check_button_new () );
+
+  box = GTK_TABLE(gtk_table_new(2, 3, FALSE));
   gtk_table_attach_defaults(box, GTK_WIDGET(w->proto_l), 0, 1, 0, 1);
   gtk_table_attach_defaults(box, GTK_WIDGET(w->proto_b), 1, 2, 0, 1);
   gtk_table_attach_defaults(box, GTK_WIDGET(w->ser_l), 0, 1, 1, 2);
   gtk_table_attach_defaults(box, GTK_WIDGET(w->ser_b), 1, 2, 1, 2);
+  gtk_table_attach_defaults(box, GTK_WIDGET(w->off_request_l), 0, 1, 2, 3);
+  gtk_table_attach_defaults(box, GTK_WIDGET(w->off_request_b), 1, 3, 2, 3);
   gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), GTK_WIDGET(box), FALSE, FALSE, 5 );
 
   gtk_widget_show_all ( dialog );