]> git.street.me.uk Git - andy/viking.git/blobdiff - src/vikexttools.c
Fix spelling in gpsd retry warning print out
[andy/viking.git] / src / vikexttools.c
index 4dc31583563ce1e69234286b04271415ce63a7c2..d504a50a0befae75ccd6ee13dce94c00ddbf929f 100644 (file)
@@ -30,6 +30,7 @@
 #include <glib/gi18n.h>
 
 #define VIK_TOOL_DATA_KEY "vik-tool-data"
+#define VIK_TOOL_WIN_KEY "vik-tool-win"
 
 static GList *ext_tools_list = NULL;
 
@@ -51,7 +52,7 @@ static void ext_tools_open_cb ( GtkWidget *widget, VikWindow *vwindow )
   vik_ext_tool_open ( ext_tool, vwindow );
 }
 
-void vik_ext_tools_add_menu_items_to_menu ( VikWindow *vwindow, GtkMenu *menu )
+void vik_ext_tools_add_action_items ( VikWindow *vwindow, GtkUIManager *uim, GtkActionGroup *action_group, guint mid )
 {
   GList *iter;
   for (iter = ext_tools_list; iter; iter = iter->next)
@@ -62,24 +63,57 @@ void vik_ext_tools_add_menu_items_to_menu ( VikWindow *vwindow, GtkMenu *menu )
     label = vik_ext_tool_get_label ( ext_tool );
     if ( label )
     {
+      gtk_ui_manager_add_ui ( uim, mid, "/ui/MainMenu/Tools/Exttools",
+                              _(label),
+                              label,
+                              GTK_UI_MANAGER_MENUITEM, FALSE );
+
+      GtkAction *action = gtk_action_new ( label, label, NULL, NULL );
+      g_object_set_data ( G_OBJECT(action), VIK_TOOL_DATA_KEY, ext_tool );
+      g_signal_connect ( G_OBJECT(action), "activate", G_CALLBACK(ext_tools_open_cb), vwindow );
+
+      gtk_action_group_add_action ( action_group, action );
+
+      g_object_unref ( action );
+
+      g_free ( label ); label = NULL;
+    }
+  }
+}
+
+static void ext_tool_open_at_position_cb ( GtkWidget *widget, VikCoord *vc )
+{
+  gpointer ptr = g_object_get_data ( G_OBJECT(widget), VIK_TOOL_DATA_KEY );
+  VikExtTool *ext_tool = VIK_EXT_TOOL ( ptr );
+  gpointer wptr = g_object_get_data ( G_OBJECT(widget), VIK_TOOL_WIN_KEY );
+  VikWindow *vw = VIK_WINDOW ( wptr );
+  vik_ext_tool_open_at_position ( ext_tool, vw, vc );
+}
+
+/**
+ * Add to any menu
+ *  mostly for allowing to assign for TrackWaypoint layer menus
+ */
+void vik_ext_tools_add_menu_items_to_menu ( VikWindow *vw, GtkMenu *menu, VikCoord *vc )
+{
+  for (GList *iter = ext_tools_list; iter; iter = iter->next)  {
+    VikExtTool *ext_tool = NULL;
+    gchar *label = NULL;
+    ext_tool = VIK_EXT_TOOL ( iter->data );
+    label = vik_ext_tool_get_label ( ext_tool );
+    if ( label ) {
       GtkWidget *item = NULL;
       item = gtk_menu_item_new_with_label ( _(label) );
       g_free ( label ); label = NULL;
-      // Store tool's ref into the menu entry
+      // Store some data into the menu entry
       g_object_set_data ( G_OBJECT(item), VIK_TOOL_DATA_KEY, ext_tool );
-      g_signal_connect ( G_OBJECT(item), "activate", G_CALLBACK(ext_tools_open_cb), vwindow );
+      g_object_set_data ( G_OBJECT(item), VIK_TOOL_WIN_KEY, vw );
+      if ( vc )
+        g_signal_connect ( G_OBJECT(item), "activate", G_CALLBACK(ext_tool_open_at_position_cb), vc );
+      else
+        g_signal_connect ( G_OBJECT(item), "activate", G_CALLBACK(ext_tools_open_cb), vw );
       gtk_menu_shell_append (GTK_MENU_SHELL (menu), item);
       gtk_widget_show ( item );
     }
   }
 }
-
-void vik_ext_tools_add_menu_items ( VikWindow *vwindow, GtkUIManager *uim )
-{
-  GtkWidget *widget = NULL;
-  GtkMenu *menu = NULL;
-  widget = gtk_ui_manager_get_widget (uim, "/MainMenu/Tools/Exttools");
-  menu = GTK_MENU ( gtk_menu_item_get_submenu ( GTK_MENU_ITEM ( widget ) ) );
-  vik_ext_tools_add_menu_items_to_menu ( vwindow, menu );
-  gtk_widget_show ( widget );
-}