X-Git-Url: https://git.street.me.uk/andy/viking.git/blobdiff_plain/8d70f07347fcd4d3c8e3a2e6a32a297ec661716f..41810542cca991dcbfb6ddf73c532faedb26accd:/src/datasource_gps.c diff --git a/src/datasource_gps.c b/src/datasource_gps.c index 6c341b1e..3e6ccced 100644 --- a/src/datasource_gps.c +++ b/src/datasource_gps.c @@ -2,6 +2,8 @@ * viking -- GPS Data and Topo Analyzer, Explorer, and Manager * * Copyright (C) 2003-2005, Evan Battaglia + * Copyright (C) 2006, Alex Foobarian + * Copyright (C) 2010, Rob Norris * * 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 @@ -22,7 +24,11 @@ #include "config.h" #endif #include +#ifdef HAVE_UNISTD_H +#include +#endif +#include #include #include @@ -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 );