X-Git-Url: https://git.street.me.uk/andy/viking.git/blobdiff_plain/69b825fe3dfce1201b0d9288cebc0c391e27036e..355fba114cb61cc3b9828c85f1341c46caf4a335:/src/datasource_google.c diff --git a/src/datasource_google.c b/src/datasource_google.c index 2ff6696b..7cafd330 100644 --- a/src/datasource_google.c +++ b/src/datasource_google.c @@ -18,31 +18,40 @@ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */ +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif #include + #include +#include #include "viking.h" #include "babel.h" #include "gpx.h" #include "acquire.h" -#define GOOGLE_DIRECTIONS_STRING "(wget -O - \"http://maps.google.com/maps?q=%s to %s&output=js\" 2>/dev/null)" +#define GOOGLE_DIRECTIONS_STRING "maps.google.com/maps?q=from:%s+to:%s&output=kml" typedef struct { GtkWidget *from_entry, *to_entry; } datasource_google_widgets_t; +static gchar *last_from_str = NULL; +static gchar *last_to_str = NULL; static gpointer datasource_google_init( ); static void datasource_google_add_setup_widgets ( GtkWidget *dialog, VikViewport *vvp, gpointer user_data ); -static void datasource_google_get_cmd_string ( datasource_google_widgets_t *widgets, gchar **cmd, gchar **input_type ); +static void datasource_google_get_cmd_string ( datasource_google_widgets_t *widgets, gchar **cmd, gchar **input_file_type ); static void datasource_google_cleanup ( gpointer data ); VikDataSourceInterface vik_datasource_google_interface = { - "Google Directions", - "Google Directions", - VIK_DATASOURCE_SHELL_CMD, + N_("Google Directions"), + N_("Google Directions"), + VIK_DATASOURCE_URL, VIK_DATASOURCE_ADDTOLAYER, + VIK_DATASOURCE_INPUTTYPE_NONE, + TRUE, (VikDataSourceInitFunc) datasource_google_init, (VikDataSourceCheckExistenceFunc) NULL, (VikDataSourceAddSetupWidgetsFunc) datasource_google_add_setup_widgets, @@ -50,6 +59,7 @@ VikDataSourceInterface vik_datasource_google_interface = { (VikDataSourceProgressFunc) NULL, (VikDataSourceAddProgressWidgetsFunc) NULL, (VikDataSourceCleanupFunc) datasource_google_cleanup, + (VikDataSourceOffFunc) NULL, }; static gpointer datasource_google_init ( ) @@ -62,10 +72,14 @@ static void datasource_google_add_setup_widgets ( GtkWidget *dialog, VikViewport { datasource_google_widgets_t *widgets = (datasource_google_widgets_t *)user_data; GtkWidget *from_label, *to_label; - from_label = gtk_label_new ("From:"); + from_label = gtk_label_new (_("From:")); widgets->from_entry = gtk_entry_new(); - to_label = gtk_label_new ("To:"); + to_label = gtk_label_new (_("To:")); widgets->to_entry = gtk_entry_new(); + if (last_from_str) + gtk_entry_set_text(GTK_ENTRY(widgets->from_entry), last_from_str); + if (last_to_str) + gtk_entry_set_text(GTK_ENTRY(widgets->to_entry), last_to_str); gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), from_label, FALSE, FALSE, 5 ); gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), widgets->from_entry, FALSE, FALSE, 5 ); gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), to_label, FALSE, FALSE, 5 ); @@ -73,18 +87,33 @@ static void datasource_google_add_setup_widgets ( GtkWidget *dialog, VikViewport gtk_widget_show_all(dialog); } -static void datasource_google_get_cmd_string ( datasource_google_widgets_t *widgets, gchar **cmd, gchar **input_type ) +static void datasource_google_get_cmd_string ( datasource_google_widgets_t *widgets, gchar **cmd, gchar **input_file_type ) { /* TODO: special characters handling!!! */ gchar *from_quoted, *to_quoted; + gchar **from_split, **to_split; from_quoted = g_shell_quote ( gtk_entry_get_text ( GTK_ENTRY(widgets->from_entry) ) ); to_quoted = g_shell_quote ( gtk_entry_get_text ( GTK_ENTRY(widgets->to_entry) ) ); + from_split = g_strsplit( from_quoted, " ", 0); + to_split = g_strsplit( to_quoted, " ", 0); + from_quoted = g_strjoinv( "%20", from_split); + to_quoted = g_strjoinv( "%20", to_split); + *cmd = g_strdup_printf( GOOGLE_DIRECTIONS_STRING, from_quoted, to_quoted ); - *input_type = g_strdup("google"); + *input_file_type = g_strdup("kml"); + + g_free(last_from_str); + g_free(last_to_str); + + last_from_str = g_strdup( gtk_entry_get_text ( GTK_ENTRY(widgets->from_entry) )); + last_to_str = g_strdup( gtk_entry_get_text ( GTK_ENTRY(widgets->to_entry) )); g_free(from_quoted); g_free(to_quoted); + g_strfreev(from_split); + g_strfreev(to_split); + } static void datasource_google_cleanup ( gpointer data )