X-Git-Url: https://git.street.me.uk/andy/viking.git/blobdiff_plain/d03413f27f0ce32fcd74391ae7c0874d74ccdfac..c3cf4e3e0f27e9c6b05cab2fd5700831878f601f:/src/datasource_google.c diff --git a/src/datasource_google.c b/src/datasource_google.c index 54c25b3d..10d4991a 100644 --- a/src/datasource_google.c +++ b/src/datasource_google.c @@ -18,15 +18,20 @@ * 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; @@ -37,21 +42,26 @@ 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, + TRUE, (VikDataSourceInitFunc) datasource_google_init, (VikDataSourceCheckExistenceFunc) NULL, (VikDataSourceAddSetupWidgetsFunc) datasource_google_add_setup_widgets, (VikDataSourceGetCmdStringFunc) datasource_google_get_cmd_string, + (VikDataSourceProcessFunc) NULL, (VikDataSourceProgressFunc) NULL, (VikDataSourceAddProgressWidgetsFunc) NULL, (VikDataSourceCleanupFunc) datasource_google_cleanup, + (VikDataSourceOffFunc) NULL, }; static gpointer datasource_google_init ( ) @@ -64,14 +74,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(widgets->from_entry, last_from_str); + gtk_entry_set_text(GTK_ENTRY(widgets->from_entry), last_from_str); if (last_to_str) - gtk_entry_set_text(widgets->to_entry, 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 ); @@ -79,26 +89,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"); - if (last_from_str) - free(last_from_str); - if (last_to_str) - free(last_to_str); + 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) ) ); + 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 )