]> git.street.me.uk Git - andy/viking.git/blobdiff - src/datasource_gc.c
Carto CSS support to generate Mapnik XML.
[andy/viking.git] / src / datasource_gc.c
index 82b825d47e7f76ffa55411a4d4ef55e953dcc57e..d8e209372e6bf642bf3e31a2ff9a2936e8e7c2b7 100644 (file)
 #include "acquire.h"
 #include "preferences.h"
 
+// Could have an array of programs instead...
+#define GC_PROGRAM1 "geo-nearest"
+#define GC_PROGRAM2 "geo-html2gpx"
+
 /* params will be geocaching.username, geocaching.password */
 /* we have to make sure these don't collide. */
 #define VIKING_GC_PARAMS_GROUP_KEY "geocaching"
@@ -40,7 +44,7 @@
 
 typedef struct {
   GtkWidget *num_spin;
-  GtkWidget *center_entry;
+  GtkWidget *center_entry; // TODO make separate widgets for lat/lon
   GtkWidget *miles_radius_spin;
 
   GdkGC *circle_gc;
@@ -50,9 +54,9 @@ typedef struct {
 } datasource_gc_widgets_t;
 
 
-static gpointer datasource_gc_init ( );
+static gpointer datasource_gc_init ( acq_vik_t *avt );
 static void datasource_gc_add_setup_widgets ( GtkWidget *dialog, VikViewport *vvp, gpointer user_data );
-static void datasource_gc_get_cmd_string ( datasource_gc_widgets_t *widgets, gchar **cmd, gchar **input_file_type );   
+static void datasource_gc_get_cmd_string ( datasource_gc_widgets_t *widgets, gchar **cmd, gchar **input_file_type, gpointer not_used );
 static void datasource_gc_cleanup ( datasource_gc_widgets_t *widgets );
 static gchar *datasource_gc_check_existence ();
 
@@ -61,15 +65,16 @@ static gchar *datasource_gc_check_existence ();
 VikDataSourceInterface vik_datasource_gc_interface = {
   N_("Download Geocaches"),
   N_("Geocaching.com Caches"),
-  VIK_DATASOURCE_SHELL_CMD,
-  VIK_DATASOURCE_ADDTOLAYER,
+  VIK_DATASOURCE_AUTO_LAYER_MANAGEMENT,
   VIK_DATASOURCE_INPUTTYPE_NONE,
-  FALSE,
+  TRUE, // Yes automatically update the display - otherwise we won't see the geocache waypoints!
+  TRUE,
   TRUE,
   (VikDataSourceInitFunc)              datasource_gc_init,
   (VikDataSourceCheckExistenceFunc)    datasource_gc_check_existence,
   (VikDataSourceAddSetupWidgetsFunc)   datasource_gc_add_setup_widgets,
   (VikDataSourceGetCmdStringFunc)      datasource_gc_get_cmd_string,
+  (VikDataSourceProcessFunc)           a_babel_convert_from_shellcommand,
   (VikDataSourceProgressFunc)          NULL,
   (VikDataSourceAddProgressWidgetsFunc)        NULL,
   (VikDataSourceCleanupFunc)           datasource_gc_cleanup,
@@ -77,8 +82,8 @@ VikDataSourceInterface vik_datasource_gc_interface = {
 };
 
 static VikLayerParam prefs[] = {
-  { VIKING_GC_PARAMS_NAMESPACE "username", VIK_LAYER_PARAM_STRING, VIK_LAYER_GROUP_NONE, N_("geocaching.com username:"), VIK_LAYER_WIDGET_ENTRY },
-  { VIKING_GC_PARAMS_NAMESPACE "password", VIK_LAYER_PARAM_STRING, VIK_LAYER_GROUP_NONE, N_("geocaching.com password:"), VIK_LAYER_WIDGET_ENTRY },
+  { VIK_LAYER_NUM_TYPES, VIKING_GC_PARAMS_NAMESPACE "username", VIK_LAYER_PARAM_STRING, VIK_LAYER_GROUP_NONE, N_("geocaching.com username:"), VIK_LAYER_WIDGET_ENTRY, NULL, NULL, NULL, NULL, NULL },
+  { VIK_LAYER_NUM_TYPES, VIKING_GC_PARAMS_NAMESPACE "password", VIK_LAYER_PARAM_STRING, VIK_LAYER_GROUP_NONE, N_("geocaching.com password:"), VIK_LAYER_WIDGET_ENTRY, NULL, NULL, NULL, NULL, NULL },
 };
 
 void a_datasource_gc_init()
@@ -93,7 +98,7 @@ void a_datasource_gc_init()
 }
 
 
-static gpointer datasource_gc_init ( )
+static gpointer datasource_gc_init ( acq_vik_t *avt )
 {
   datasource_gc_widgets_t *widgets = g_malloc(sizeof(*widgets));
   return widgets;
@@ -101,12 +106,25 @@ static gpointer datasource_gc_init ( )
 
 static gchar *datasource_gc_check_existence ()
 {
-  gchar *gcget_location = g_find_program_in_path("gcget");
-  if ( gcget_location ) {
-    g_free(gcget_location);
-    return NULL;
+  gboolean OK1 = FALSE;
+  gboolean OK2 = FALSE;
+
+  gchar *location1 = g_find_program_in_path(GC_PROGRAM1);
+  if ( location1 ) {
+    g_free(location1);
+    OK1 = TRUE;
+  }
+
+  gchar *location2 = g_find_program_in_path(GC_PROGRAM2);
+  if ( location2 ) {
+    g_free(location2);
+    OK2 = TRUE;
   }
-  return g_strdup(_("Can't find gcget in path! Check that you have installed gcget correctly."));
+
+  if ( OK1 && OK2 )
+    return NULL;
+
+  return g_strdup_printf(_("Can't find %s or %s in path! Check that you have installed it correctly."), GC_PROGRAM1, GC_PROGRAM2);
 }
 
 static void datasource_gc_draw_circle ( datasource_gc_widgets_t *widgets )
@@ -169,11 +187,11 @@ static void datasource_gc_add_setup_widgets ( GtkWidget *dialog, VikViewport *vv
   gchar *s_ll;
 
   num_label = gtk_label_new (_("Number geocaches:"));
-  widgets->num_spin = gtk_spin_button_new ( GTK_ADJUSTMENT(gtk_adjustment_new( 100, 1, 1000, 10, 20, 0 )), 25, 0 );
+  widgets->num_spin = gtk_spin_button_new ( GTK_ADJUSTMENT(gtk_adjustment_new( 20, 1, 1000, 10, 20, 0 )), 10, 0 );
   center_label = gtk_label_new (_("Centered around:"));
   widgets->center_entry = gtk_entry_new();
   miles_radius_label = gtk_label_new ("Miles Radius:");
-  widgets->miles_radius_spin = gtk_spin_button_new ( GTK_ADJUSTMENT(gtk_adjustment_new( 100, 1, 1000, 5, 20, 0 )), 25, 2 );
+  widgets->miles_radius_spin = gtk_spin_button_new ( GTK_ADJUSTMENT(gtk_adjustment_new( 5, 1, 1000, 1, 20, 0 )), 25, 1 );
 
   vik_coord_to_latlon ( vik_viewport_get_center(vvp), &ll );
   s_ll = g_strdup_printf("%f,%f", ll.lat, ll.lon );
@@ -184,33 +202,59 @@ static void datasource_gc_add_setup_widgets ( GtkWidget *dialog, VikViewport *vv
   widgets->vvp = vvp;
   widgets->circle_gc = vik_viewport_new_gc ( vvp, "#000000", 3 );
   gdk_gc_set_function ( widgets->circle_gc, GDK_INVERT );
-  widgets->circle_onscreen = FALSE;
+  widgets->circle_onscreen = TRUE;
   datasource_gc_draw_circle ( widgets );
 
   g_signal_connect_swapped ( G_OBJECT(widgets->center_entry), "changed", G_CALLBACK(datasource_gc_draw_circle), widgets );
   g_signal_connect_swapped ( G_OBJECT(widgets->miles_radius_spin), "value-changed", G_CALLBACK(datasource_gc_draw_circle), widgets );
 
-  gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), num_label, FALSE, FALSE, 5 );
-  gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), widgets->num_spin, FALSE, FALSE, 5 );
-  gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), center_label, FALSE, FALSE, 5 );
-  gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), widgets->center_entry, FALSE, FALSE, 5 );
-  gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), miles_radius_label, FALSE, FALSE, 5 );
-  gtk_box_pack_start ( GTK_BOX(GTK_DIALOG(dialog)->vbox), widgets->miles_radius_spin, FALSE, FALSE, 5 );
+  /* Packing all these widgets */
+  GtkBox *box = GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dialog)));
+  gtk_box_pack_start ( box, num_label, FALSE, FALSE, 5 );
+  gtk_box_pack_start ( box, widgets->num_spin, FALSE, FALSE, 5 );
+  gtk_box_pack_start ( box, center_label, FALSE, FALSE, 5 );
+  gtk_box_pack_start ( box, widgets->center_entry, FALSE, FALSE, 5 );
+  gtk_box_pack_start ( box, miles_radius_label, FALSE, FALSE, 5 );
+  gtk_box_pack_start ( box, widgets->miles_radius_spin, FALSE, FALSE, 5 );
   gtk_widget_show_all(dialog);
 }
 
-static void datasource_gc_get_cmd_string ( datasource_gc_widgets_t *widgets, gchar **cmd, gchar **input_file_type )
+static void datasource_gc_get_cmd_string ( datasource_gc_widgets_t *widgets, gchar **cmd, gchar **input_file_type, gpointer not_used )
 {
-  gchar *safe_string = g_shell_quote ( gtk_entry_get_text ( GTK_ENTRY(widgets->center_entry) ) );
+  //gchar *safe_string = g_shell_quote ( gtk_entry_get_text ( GTK_ENTRY(widgets->center_entry) ) );
   gchar *safe_user = g_shell_quote ( a_preferences_get ( VIKING_GC_PARAMS_NAMESPACE "username")->s );
   gchar *safe_pass = g_shell_quote ( a_preferences_get ( VIKING_GC_PARAMS_NAMESPACE "password")->s );
-  *cmd = g_strdup_printf( "gcget -u %s -p %s %s %d %.2lf", safe_user, safe_pass, safe_string, 
-       gtk_spin_button_get_value_as_int ( GTK_SPIN_BUTTON(widgets->num_spin) ),
-       gtk_spin_button_get_value_as_float ( GTK_SPIN_BUTTON(widgets->miles_radius_spin) ) );
+  gchar *slat, *slon;
+  gdouble lat, lon;
+  if ( 2 != sscanf ( gtk_entry_get_text ( GTK_ENTRY(widgets->center_entry) ), "%lf,%lf", &lat, &lon ) ) {
+    g_warning (_("Broken input - using some defaults"));
+    lat = a_vik_get_default_lat();
+    lon = a_vik_get_default_long();
+  }
+  // Convert double as string in C locale
+  slat = a_coords_dtostr ( lat );
+  slon = a_coords_dtostr ( lon );
+
+  // Unix specific shell commands
+  // 1. Remove geocache webpages (maybe be from different location)
+  // 2, Gets upto n geocaches as webpages for the specified user in radius r Miles
+  // 3. Converts webpages into a single waypoint file, ignoring zero location waypoints '-z'
+  //       Probably as they are premium member only geocaches and user is only a basic member
+  //  Final output is piped into GPSbabel - hence removal of *html is done at beginning of the command sequence
+  *cmd = g_strdup_printf( "rm -f ~/.geo/caches/*html ; %s -P -n%d -r%.1fM -u %s -p %s %s %s ; %s -z ~/.geo/caches/*html ",
+                         GC_PROGRAM1,
+                         gtk_spin_button_get_value_as_int ( GTK_SPIN_BUTTON(widgets->num_spin) ),
+                         gtk_spin_button_get_value_as_float ( GTK_SPIN_BUTTON(widgets->miles_radius_spin) ),
+                         safe_user,
+                         safe_pass,
+                         slat, slon,
+                         GC_PROGRAM2 );
   *input_file_type = NULL;
-  g_free ( safe_string );
+  //g_free ( safe_string );
   g_free ( safe_user );
   g_free ( safe_pass );
+  g_free ( slat );
+  g_free ( slon );
 }
 
 static void datasource_gc_cleanup ( datasource_gc_widgets_t *widgets )