Diff of /trunk/src/main.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2 by harbaum, Sat Jun 20 11:44:14 2009 UTC revision 44 by harbaum, Tue Aug 4 14:07:18 2009 UTC
# Line 120  gpx_t *choose_file(appdata_t *appdata, g Line 120  gpx_t *choose_file(appdata_t *appdata, g
120                   HELP_ID_IMPORT, appdata->osso_context);                   HELP_ID_IMPORT, appdata->osso_context);
121  #endif  #endif
122  #else  #else
123    dialog = gtk_file_chooser_dialog_new (whole_dir?_("Open Directory"):    dialog = gtk_file_chooser_dialog_new (whole_dir?_("Import directory"):
124                                          _("Open File"),                                          _("Import file"),
125                          GTK_WINDOW(appdata->window),                          GTK_WINDOW(appdata->window),
126                          whole_dir?GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER :                          whole_dir?GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER :
127                                          GTK_FILE_CHOOSER_ACTION_OPEN,                                          GTK_FILE_CHOOSER_ACTION_OPEN,
# Line 202  void cachelist_view_onRowActivated(GtkTr Line 202  void cachelist_view_onRowActivated(GtkTr
202    GtkTreeIter   iter;    GtkTreeIter   iter;
203    GtkTreeModel *model = gtk_tree_view_get_model(treeview);    GtkTreeModel *model = gtk_tree_view_get_model(treeview);
204    
205      /* check if a cache is already selected and ignore click if yes */
206      /* (was probably a double click) */
207      if(appdata->cur_cache) return;
208    
209    if(gtk_tree_model_get_iter(model, &iter, path)) {    if(gtk_tree_model_get_iter(model, &iter, path)) {
210      cache_t *cache;      cache_t *cache;
211      gtk_tree_model_get(model, &iter, CACHELIST_COL_DATA, &cache, -1);      gtk_tree_model_get(model, &iter, CACHELIST_COL_DATA, &cache, -1);
# Line 264  void cachelist_redraw(appdata_t *appdata Line 268  void cachelist_redraw(appdata_t *appdata
268    // gtk_widget_show_all(appdata->vbox);    // gtk_widget_show_all(appdata->vbox);
269  #else  #else
270    
271      if(!appdata->cur_view) {
272        printf("cachelist redraw: no active view\n");
273        return;
274      }
275    
276    g_assert(!appdata->cur_cache);    g_assert(!appdata->cur_cache);
277    int redraw = 0;    int redraw = 0;
278    if(appdata->search_results)    if(appdata->search_results)
# Line 274  void cachelist_redraw(appdata_t *appdata Line 283  void cachelist_redraw(appdata_t *appdata
283    }    }
284    
285    if(redraw) {    if(redraw) {
286      gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view);      GtkWidget *container = appdata->vbox;
287    
288        printf("redraw %d\n", redraw);
289    
290    #ifdef USE_STACKABLE_WINDOW
291        HildonWindowStack *stack = hildon_window_stack_get_default();
292        container = hildon_window_stack_peek(stack);
293    #endif
294    
295        gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view);
296      switch(redraw) {      switch(redraw) {
297      case 1:      case 1:
298        appdata->cur_view = cachelist_create(appdata,        appdata->cur_view = cachelist_create(appdata,
# Line 286  void cachelist_redraw(appdata_t *appdata Line 304  void cachelist_redraw(appdata_t *appdata
304        break;        break;
305      }      }
306    
307      gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view);  #ifdef USE_STACKABLE_WINDOW
308      gtk_widget_show_all(appdata->vbox);      if(container != appdata->vbox)
309          gtk_container_add(GTK_CONTAINER(container), appdata->cur_view);
310        else
311    #endif
312          gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view);
313    
314        gtk_widget_show_all(container);
315    }    }
316  #endif  #endif
317  }  }
# Line 300  static gboolean cachelist_update(gpointe Line 324  static gboolean cachelist_update(gpointe
324  #ifdef USE_MAEMO  #ifdef USE_MAEMO
325    appdata_t *appdata = (appdata_t*)data;    appdata_t *appdata = (appdata_t*)data;
326    
327      if(appdata->cur_cache)
328        return TRUE;
329    
330    if(appdata->cachelist_disable_screensaver)    if(appdata->cachelist_disable_screensaver)
331      if (osso_display_blanking_pause(appdata->osso_context) != OSSO_OK)      if (osso_display_blanking_pause(appdata->osso_context) != OSSO_OK)
332        fprintf(stderr, "error with display blank\n");        fprintf(stderr, "error with display blank\n");
# Line 312  static gboolean cachelist_update(gpointe Line 339  static gboolean cachelist_update(gpointe
339  }  }
340    
341  static void cachelist_timer_reset(appdata_t *appdata) {  static void cachelist_timer_reset(appdata_t *appdata) {
342      printf("cachelist timer reset\n");
343    g_assert(appdata->cachelist_handler_id);    g_assert(appdata->cachelist_handler_id);
344    gtk_timeout_remove(appdata->cachelist_handler_id);    gtk_timeout_remove(appdata->cachelist_handler_id);
345    appdata->cachelist_handler_id =    appdata->cachelist_handler_id =
# Line 543  void cachelist_dialog(appdata_t *appdata Line 571  void cachelist_dialog(appdata_t *appdata
571  }  }
572  #else  #else
573  #ifdef USE_STACKABLE_WINDOW  #ifdef USE_STACKABLE_WINDOW
574    static void search_result_free(gpx_t *result);
575    
576    void on_cachelist_destroy(GtkWidget *widget, appdata_t *appdata) {
577      if(appdata->search_results) {
578        search_result_free(appdata->search_results);
579        appdata->search_results = NULL;
580      }
581      appdata->cur_gpx = NULL;
582    
583      /* restore cur_view */
584      appdata->cur_view = g_object_get_data(G_OBJECT(widget), "cur_view");
585    }
586    
587  void cachelist_dialog(appdata_t *appdata, gpx_t *gpx) {  void cachelist_dialog(appdata_t *appdata, gpx_t *gpx) {
588    GtkWidget *window = hildon_stackable_window_new();    GtkWidget *window = hildon_stackable_window_new();
589    
590    gtk_window_set_title(GTK_WINDOW(window), gpx->name);    /* store last "cur_view" in window */
591      g_object_set_data(G_OBJECT(window), "cur_view", appdata->cur_view);
592    
593    gtk_container_add(GTK_CONTAINER(window),    appdata->cur_gpx = gpx;
594                      cachelist_create(appdata, gpx, NULL));    char *title = g_strdup_printf("%s - GPXView", gpx->name);
595      gtk_window_set_title(GTK_WINDOW(window), title);
596      g_free(title);
597    
598      appdata->cur_view = cachelist_create(appdata, gpx, NULL);
599      gtk_container_add(GTK_CONTAINER(window), appdata->cur_view);
600    
601    
602      hildon_window_set_app_menu(HILDON_WINDOW(window),
603                                 menu_create(appdata, MENU_CACHELIST));
604    
605      g_signal_connect(G_OBJECT(window), "destroy",
606                       G_CALLBACK(on_cachelist_destroy), appdata);
607    
608    gtk_widget_show_all(window);    gtk_widget_show_all(window);
609  }  }
# Line 663  static void gpxlist_view_onRowActivated( Line 717  static void gpxlist_view_onRowActivated(
717    GtkTreeIter   iter;    GtkTreeIter   iter;
718    GtkTreeModel *model = gtk_tree_view_get_model(treeview);    GtkTreeModel *model = gtk_tree_view_get_model(treeview);
719    
720      /* check if a cache is already selected and ignore click if yes */
721      /* (was probably a double click) */
722      if(appdata->cur_gpx) return;
723    
724    if (gtk_tree_model_get_iter(model, &iter, path)) {    if (gtk_tree_model_get_iter(model, &iter, path)) {
725      gpx_t *gpx;      gpx_t *gpx;
726      gtk_tree_model_get(model, &iter, GPXLIST_COL_DATA, &gpx, -1);      gtk_tree_model_get(model, &iter, GPXLIST_COL_DATA, &gpx, -1);
# Line 761  static void gpxlist_view_onRowActivated( Line 819  static void gpxlist_view_onRowActivated(
819          gpx_busy_dialog_destroy(dialog);          gpx_busy_dialog_destroy(dialog);
820        }        }
821  #ifndef USE_BREAD_CRUMB_TRAIL  #ifndef USE_BREAD_CRUMB_TRAIL
822        cachelist_dialog(appdata, gpx);  #ifdef USE_STACKABLE_WINDOW
823          if(!appdata->cur_gpx)
824    #endif
825            cachelist_dialog(appdata, gpx);
826    #ifdef USE_STACKABLE_WINDOW
827          else
828            printf("selected gpx, but cachelist window already present\n");
829    #endif
830  #else  #else
831        gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view);        gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view);
832        appdata->cur_view = cachelist_create(appdata, gpx, NULL);        appdata->cur_view = cachelist_create(appdata, gpx, NULL);
# Line 966  cb_menu_about(GtkWidget *window, gpointe Line 1031  cb_menu_about(GtkWidget *window, gpointe
1031    
1032    gtk_about_dialog_set_name(about, "GPXView");    gtk_about_dialog_set_name(about, "GPXView");
1033    gtk_about_dialog_set_version(about, VERSION);    gtk_about_dialog_set_version(about, VERSION);
1034    gtk_about_dialog_set_copyright(about,  
1035           _("GPXView (c) 2008 by\n"  #ifdef ENABLE_LIBLOCATION
1036           "Till Harbaum <till@harbaum.org>\n"    char *uses = "uses liblocation";
1037           "Geocaching.com: Tantil"));  #elif defined(ENABLE_GPSBT)
1038      char *uses = "uses gpsbt and gpsd";
1039    #else
1040      char *uses = "uses gpsd";
1041    #endif
1042    
1043      char *str = g_strdup_printf("%s\n\n(%s)",
1044                          _("GPXView (c) 2008-2009 by\n"
1045                            "Till Harbaum <till@harbaum.org>\n"
1046                            "Mailing list: gpxview-users@garage.maemo.org"),
1047                          _(uses)
1048                          );
1049    
1050      gtk_about_dialog_set_copyright(about, str);
1051      g_free(str);
1052    
1053    gtk_about_dialog_set_website(about,    gtk_about_dialog_set_website(about,
1054         _("http://www.harbaum.org/till/maemo"));         _("http://www.harbaum.org/till/maemo"));
# Line 1007  cb_menu_adddir(GtkWidget *window, gpoint Line 1086  cb_menu_adddir(GtkWidget *window, gpoint
1086    if(new) gpxlist_add(appdata, new);    if(new) gpxlist_add(appdata, new);
1087  }  }
1088    
 static void  
 cb_menu_geomath(GtkWidget *window, gpointer data) {  
   geomath_dialog((appdata_t *)data);  
 }  
   
 static void  
 cb_menu_geotext(GtkWidget *window, gpointer data) {  
   geotext_dialog((appdata_t *)data);  
 }  
   
 static void  
 cb_menu_precpos(GtkWidget *window, gpointer data) {  
   precise_position((appdata_t *)data);  
 }  
   
1089  #ifndef USE_PANNABLE_AREA  #ifndef USE_PANNABLE_AREA
1090  static void  static void
1091  cb_menu_close(GtkWidget *window, gpointer data) {  cb_menu_close(GtkWidget *window, gpointer data) {
# Line 1340  cb_menu_search(GtkWidget *window, gpoint Line 1404  cb_menu_search(GtkWidget *window, gpoint
1404      /* don't search if we are asked to search for nothing */      /* don't search if we are asked to search for nothing */
1405      if(((appdata->search & (SEARCH_ID|SEARCH_NAME|SEARCH_DESC|SEARCH_OWNER)) &&      if(((appdata->search & (SEARCH_ID|SEARCH_NAME|SEARCH_DESC|SEARCH_OWNER)) &&
1406          strlen(p) > 0) || (appdata->search & SEARCH_FINDS)) {          strlen(p) > 0) || (appdata->search & SEARCH_FINDS)) {
       gpx_t *found = NULL;  
1407    
1408        printf("Search for %s (flags = %x)...\n", p, appdata->search);        printf("Search for %s (flags = %x)...\n", p, appdata->search);
1409    
1410  #ifndef USE_BREAD_CRUMB_TRAIL  #ifndef USE_BREAD_CRUMB_TRAIL
1411        found = search_do(appdata, appdata->gpx, p, appdata->search, FALSE);        gpx_t *found =
1412            search_do(appdata, appdata->gpx, p, appdata->search, FALSE);
1413    
1414        /* do search result dialog here ... */        /* do search result dialog here ... */
1415        cachelist_dialog(appdata, found);        cachelist_dialog(appdata, found);
1416    #ifndef USE_STACKABLE_WINDOW
1417        search_result_free(found);        search_result_free(found);
1418  #else  #else
1419          appdata->search_results = found;
1420    #endif
1421    #else
1422          gpx_t *found = NULL;
1423    
1424        if(appdata->cur_gpx)        if(appdata->cur_gpx)
1425          found = search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE);          found = search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE);
1426        else        else
# Line 1371  cb_menu_search(GtkWidget *window, gpoint Line 1441  cb_menu_search(GtkWidget *window, gpoint
1441      gtk_widget_destroy(dialog);      gtk_widget_destroy(dialog);
1442  }  }
1443    
1444  void on_window_destroy (GtkWidget *widget, gpointer data);  static void on_window_destroy (GtkWidget *widget, gpointer data);
1445    
1446  #ifndef USE_MAEMO  #ifndef USE_MAEMO
1447  static void  static void
# Line 1447  cb_menu_export_garmin(GtkWidget *widget, Line 1517  cb_menu_export_garmin(GtkWidget *widget,
1517    garmin_export(appdata);    garmin_export(appdata);
1518  }  }
1519    
1520    #ifdef ENABLE_OSM_GPS_MAP
1521    static void
1522    cb_menu_map(GtkWidget *window, gpointer data) {
1523      map((appdata_t *)data);
1524    }
1525    #endif
1526    
1527    static void
1528    cb_menu_geomath(GtkWidget *window, gpointer data) {
1529      geomath_dialog((appdata_t *)data);
1530    }
1531    
1532    static void
1533    cb_menu_geotext(GtkWidget *window, gpointer data) {
1534      geotext_dialog((appdata_t *)data);
1535    }
1536    
1537    static void
1538    cb_menu_precpos(GtkWidget *window, gpointer data) {
1539      precise_position((appdata_t *)data);
1540    }
1541    
1542    #ifdef USE_STACKABLE_WINDOW
1543    typedef struct {
1544      char *label, *desc;
1545      GtkSignalFunc activate_cb;
1546    } menu_entry_t;
1547    
1548    typedef struct {
1549      const char *title;
1550      const menu_entry_t *menu;
1551      int len;
1552    } submenu_t;
1553    
1554    #define COLUMNS  1
1555    
1556    void on_submenu_entry_clicked(GtkButton *button, GtkWidget *menu) {
1557    
1558      /* force closing of submenu dialog */
1559      gtk_dialog_response(GTK_DIALOG(menu), GTK_RESPONSE_NONE);
1560      gtk_widget_hide(menu);
1561    
1562      /* let gtk clean up */
1563      while(gtk_events_pending())
1564        gtk_main_iteration();
1565    }
1566    
1567    static GtkWidget *app_submenu_create(appdata_t *appdata,
1568                                         const submenu_t *submenu) {
1569    
1570      /* create a oridinary dialog box */
1571      GtkWidget *dialog = gtk_dialog_new();
1572      gtk_window_set_title(GTK_WINDOW(dialog), _(submenu->title));
1573      gtk_window_set_modal(GTK_WINDOW(dialog), TRUE);
1574      gtk_window_set_transient_for(GTK_WINDOW(dialog),
1575                                   GTK_WINDOW(appdata->window));
1576      gtk_dialog_set_has_separator(GTK_DIALOG(dialog), FALSE);
1577    
1578      GtkWidget *table = gtk_table_new(submenu->len/COLUMNS, COLUMNS, TRUE);
1579      int x = 0, y = 0;
1580    
1581      const menu_entry_t *menu_entries = submenu->menu;
1582      while(menu_entries->label) {
1583        GtkWidget *button = NULL;
1584    
1585        button = hildon_button_new_with_text(
1586                HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH,
1587                HILDON_BUTTON_ARRANGEMENT_VERTICAL,
1588                _(menu_entries->label), _(menu_entries->desc));
1589    
1590        /* try to center both texts */
1591        hildon_button_set_title_alignment(HILDON_BUTTON(button), 0.5, 0.5);
1592        hildon_button_set_value_alignment(HILDON_BUTTON(button), 0.5, 0.5);
1593    
1594        g_signal_connect(button, "clicked",
1595                         G_CALLBACK(on_submenu_entry_clicked), dialog);
1596    
1597        g_signal_connect(button, "clicked",
1598                         menu_entries->activate_cb, appdata);
1599    
1600        gtk_table_attach_defaults(GTK_TABLE(table),  button, x, x+1, y, y+1);
1601    
1602        x++;
1603        if(x == COLUMNS) { x = 0; y++; }
1604    
1605        menu_entries++;
1606      }
1607    
1608      gtk_box_pack_start_defaults(GTK_BOX(GTK_DIALOG(dialog)->vbox), table);
1609    
1610      return dialog;
1611    }
1612    
1613    /* popup the dialog shaped submenu */
1614    static void submenu_popup(GtkWidget *menu) {
1615      gtk_widget_show_all(menu);
1616      gtk_dialog_run(GTK_DIALOG(menu));
1617      gtk_widget_hide(menu);
1618    }
1619    
1620    static void submenu_cleanup(GtkWidget *menu) {
1621      gtk_widget_destroy(menu);
1622    }
1623    
1624    static const menu_entry_t submenu_export_entries[] = {
1625      { "Export to Maemo Mapper" , "Save a Maemo Mapper POI file",
1626        G_CALLBACK(cb_menu_export_mmpoi)  },
1627      { "Export Field Notes",      "Save a Garmin Field Notes file",
1628        G_CALLBACK(cb_menu_export_log)    },
1629      { "Export Garmin GPX",       "Save modified waypoints in GPX file",
1630        G_CALLBACK(cb_menu_export_garmin) },
1631      { NULL, NULL, NULL }
1632    };
1633    
1634    static const submenu_t submenu_export = {
1635      "Export", submenu_export_entries,
1636      sizeof(submenu_export_entries)/sizeof(menu_entry_t)-1
1637    };
1638    
1639    /* the export submenu */
1640    void on_export_clicked(GtkButton *button, appdata_t *appdata) {
1641      if(!appdata->export_menu)
1642        appdata->export_menu = app_submenu_create(appdata, &submenu_export);
1643    
1644      submenu_popup(appdata->export_menu);
1645    }
1646    
1647    static const menu_entry_t submenu_tools_entries[] = {
1648      { "Geomath",          "Geocoordinate calculation",
1649        G_CALLBACK(cb_menu_geomath) },
1650      { "Geotext",          "Text analysis",
1651        G_CALLBACK(cb_menu_geotext) },
1652      { "Precise Position", "Calculate a precise GPS position",
1653        G_CALLBACK(cb_menu_precpos) },
1654      { NULL, NULL, NULL }
1655    };
1656    
1657    static const submenu_t submenu_tools = {
1658      "Tools", submenu_tools_entries,
1659      sizeof(submenu_tools_entries)/sizeof(menu_entry_t)-1
1660    };
1661    
1662    /* the tools submenu */
1663    void on_tools_clicked(GtkButton *button, appdata_t *appdata) {
1664      if(!appdata->tools_menu)
1665        appdata->tools_menu = app_submenu_create(appdata, &submenu_tools);
1666    
1667      submenu_popup(appdata->tools_menu);
1668    }
1669    
1670    HildonAppMenu *menu_create(appdata_t *appdata, int mode) {
1671      GtkWidget *button;
1672      HildonAppMenu *menu = HILDON_APP_MENU(hildon_app_menu_new());
1673    
1674      /* ------- */
1675      button = gtk_button_new_with_label(_("About"));
1676      g_signal_connect_after(button, "clicked",
1677                             G_CALLBACK(cb_menu_about), appdata);
1678      hildon_app_menu_append(menu, GTK_BUTTON(button));
1679    
1680      button = gtk_button_new_with_label(_("Settings"));
1681      g_signal_connect_after(button, "clicked", G_CALLBACK(cb_menu_settings),
1682                             appdata);
1683      hildon_app_menu_append(menu, GTK_BUTTON(button));
1684    
1685      if(mode == MENU_GPXLIST) {
1686        button = gtk_button_new_with_label(_("Import file"));
1687        g_signal_connect_after(button, "clicked",
1688                               G_CALLBACK(cb_menu_add), appdata);
1689        hildon_app_menu_append(menu, GTK_BUTTON(button));
1690    
1691        button = gtk_button_new_with_label(_("Import directory"));
1692        g_signal_connect_after(button, "clicked",
1693                               G_CALLBACK(cb_menu_adddir), appdata);
1694        hildon_app_menu_append(menu, GTK_BUTTON(button));
1695    
1696        button = gtk_button_new_with_label(_("Export"));
1697        g_signal_connect_after(button, "clicked",
1698                               G_CALLBACK(on_export_clicked), appdata);
1699        hildon_app_menu_append(menu, GTK_BUTTON(button));
1700    
1701        button = gtk_button_new_with_label(_("Search"));
1702        g_signal_connect_after(button, "clicked",
1703                               G_CALLBACK(cb_menu_search), appdata);
1704        hildon_app_menu_append(menu, GTK_BUTTON(button));
1705      }
1706    
1707      button = gtk_button_new_with_label(_("Tools"));
1708      g_signal_connect_after(button, "clicked",
1709                             G_CALLBACK(on_tools_clicked), appdata);
1710      hildon_app_menu_append(menu, GTK_BUTTON(button));
1711    
1712    #ifdef ENABLE_OSM_GPS_MAP
1713      if((mode == MENU_GPXLIST) || (mode == MENU_CACHELIST)) {
1714        button = gtk_button_new_with_label(_("Map"));
1715        g_signal_connect_after(button, "clicked",
1716                               G_CALLBACK(cb_menu_map), appdata);
1717        hildon_app_menu_append(menu, GTK_BUTTON(button));
1718      }
1719    #endif
1720    
1721    #ifdef HILDON_HELP
1722      button = gtk_button_new_with_label(_("Help"));
1723      g_signal_connect_after(button, "clicked",
1724                             G_CALLBACK(cb_menu_help), appdata);
1725      hildon_app_menu_append(menu, GTK_BUTTON(button));
1726    #endif
1727    
1728      gtk_widget_show_all(GTK_WIDGET(menu));
1729    
1730      return menu;
1731    }
1732    #else
1733    
1734  void menu_create(appdata_t *appdata) {  void menu_create(appdata_t *appdata) {
1735    GtkWidget *menu, *item;    GtkWidget *menu, *item;
1736    menu = gtk_menu_new();    menu = gtk_menu_new();
1737    
1738  #ifdef USE_MAEMO  #ifdef USE_BREAD_CRUMB_TRAIL
1739    appdata->menu_import =    appdata->menu_import =
1740  #endif  #endif
1741    item = gtk_menu_item_new_with_label(_("Import"));    item = gtk_menu_item_new_with_label(_("Import"));
# Line 1459  void menu_create(appdata_t *appdata) { Line 1743  void menu_create(appdata_t *appdata) {
1743    GtkWidget *submenu = gtk_menu_new();    GtkWidget *submenu = gtk_menu_new();
1744    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
1745    
1746    item = gtk_menu_item_new_with_label( _("File...") );    item = gtk_menu_item_new_with_label( _("File") );
1747    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1748    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_add), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_add), appdata);
1749    
1750    item = gtk_menu_item_new_with_label( _("Directory...") );    item = gtk_menu_item_new_with_label( _("Directory") );
1751    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1752    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_adddir), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_adddir), appdata);
1753    
# Line 1481  void menu_create(appdata_t *appdata) { Line 1765  void menu_create(appdata_t *appdata) {
1765    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_remove), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_remove), appdata);
1766  #endif  #endif
1767    
1768  #ifdef USE_MAEMO  #ifdef USE_BREAD_CRUMB_TRAIL
1769    appdata->menu_export =    appdata->menu_export =
1770  #endif  #endif
1771      item = gtk_menu_item_new_with_label(_("Export"));      item = gtk_menu_item_new_with_label(_("Export"));
# Line 1490  void menu_create(appdata_t *appdata) { Line 1774  void menu_create(appdata_t *appdata) {
1774    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
1775    
1776  #ifdef USE_MAEMO  #ifdef USE_MAEMO
1777    item = gtk_menu_item_new_with_label( _("Maemo Mapper POI...") );    item = gtk_menu_item_new_with_label( _("Maemo Mapper POI") );
1778    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1779    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1780                     GTK_SIGNAL_FUNC(cb_menu_export_mmpoi), appdata);                     GTK_SIGNAL_FUNC(cb_menu_export_mmpoi), appdata);
1781  #endif  #endif
1782    
1783    item = gtk_menu_item_new_with_label( _("Garmin Field Notes...") );    item = gtk_menu_item_new_with_label( _("Garmin Field Notes") );
1784    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1785    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1786                     GTK_SIGNAL_FUNC(cb_menu_export_log), appdata);                     GTK_SIGNAL_FUNC(cb_menu_export_log), appdata);
1787    
1788    item = gtk_menu_item_new_with_label( _("Garmin GPX...") );    item = gtk_menu_item_new_with_label( _("Garmin GPX") );
1789    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1790    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1791                     GTK_SIGNAL_FUNC(cb_menu_export_garmin), appdata);                     GTK_SIGNAL_FUNC(cb_menu_export_garmin), appdata);
1792    
1793  #ifdef USE_MAEMO  #ifdef USE_BREAD_CRUMB_TRAIL
1794    appdata->menu_search =    appdata->menu_search =
1795  #endif  #endif
1796    item = gtk_menu_item_new_with_label( _("Search...") );    item = gtk_menu_item_new_with_label( _("Search") );
1797    gtk_menu_append(GTK_MENU_SHELL(menu), item);    gtk_menu_append(GTK_MENU_SHELL(menu), item);
1798    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_search), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_search), appdata);
1799    
# Line 1539  void menu_create(appdata_t *appdata) { Line 1823  void menu_create(appdata_t *appdata) {
1823    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_paste), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_paste), appdata);
1824  #endif  #endif
1825    
1826    item = gtk_menu_item_new_with_label( _("Settings...") );    item = gtk_menu_item_new_with_label( _("Settings") );
1827    gtk_menu_append(GTK_MENU_SHELL(menu), item);    gtk_menu_append(GTK_MENU_SHELL(menu), item);
1828    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_settings),    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_settings),
1829                     appdata);                     appdata);
# Line 1551  void menu_create(appdata_t *appdata) { Line 1835  void menu_create(appdata_t *appdata) {
1835    submenu = gtk_menu_new();    submenu = gtk_menu_new();
1836    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
1837    
1838    item = gtk_menu_item_new_with_label( _("Geomath...") );  #ifdef ENABLE_OSM_GPS_MAP
1839      item = gtk_menu_item_new_with_label( _("Map") );
1840      gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1841      g_signal_connect(item, "activate",
1842                       GTK_SIGNAL_FUNC(cb_menu_map), appdata);
1843    #endif
1844    
1845      item = gtk_menu_item_new_with_label( _("Geomath") );
1846    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1847    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1848                     GTK_SIGNAL_FUNC(cb_menu_geomath), appdata);                     GTK_SIGNAL_FUNC(cb_menu_geomath), appdata);
1849    
1850    item = gtk_menu_item_new_with_label( _("Geotext...") );    item = gtk_menu_item_new_with_label( _("Geotext") );
1851    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1852    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1853                     GTK_SIGNAL_FUNC(cb_menu_geotext), appdata);                     GTK_SIGNAL_FUNC(cb_menu_geotext), appdata);
1854    
1855    item = gtk_menu_item_new_with_label( _("Precise Position...") );    item = gtk_menu_item_new_with_label( _("Precise Position") );
1856    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1857    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1858                     GTK_SIGNAL_FUNC(cb_menu_precpos), appdata);                     GTK_SIGNAL_FUNC(cb_menu_precpos), appdata);
# Line 1569  void menu_create(appdata_t *appdata) { Line 1860  void menu_create(appdata_t *appdata) {
1860    gtk_menu_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new());    gtk_menu_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new());
1861    
1862  #if defined(USE_MAEMO) && defined(HILDON_HELP)  #if defined(USE_MAEMO) && defined(HILDON_HELP)
1863    item = gtk_menu_item_new_with_label( _("Help...") );    item = gtk_menu_item_new_with_label( _("Help") );
1864    gtk_menu_append(GTK_MENU_SHELL(menu), item);    gtk_menu_append(GTK_MENU_SHELL(menu), item);
1865    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_help), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_help), appdata);
1866  #endif  #endif
1867    
1868    item = gtk_menu_item_new_with_label( _("About...") );    item = gtk_menu_item_new_with_label( _("About") );
1869    gtk_menu_append(GTK_MENU_SHELL(menu), item);    gtk_menu_append(GTK_MENU_SHELL(menu), item);
1870    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_about), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_about), appdata);
1871    
# Line 1600  void menu_create(appdata_t *appdata) { Line 1891  void menu_create(appdata_t *appdata) {
1891    gtk_box_pack_start(GTK_BOX(appdata->vbox), menu_bar, 0, 0, 0);    gtk_box_pack_start(GTK_BOX(appdata->vbox), menu_bar, 0, 0, 0);
1892  #endif  #endif
1893  }  }
1894    #endif
1895    
1896  /********************* end of menu **********************/  /********************* end of menu **********************/
1897    
# Line 1609  void cleanup(appdata_t *appdata) { Line 1901  void cleanup(appdata_t *appdata) {
1901    if(appdata->image_path) free(appdata->image_path);    if(appdata->image_path) free(appdata->image_path);
1902    if(appdata->search_str) free(appdata->search_str);    if(appdata->search_str) free(appdata->search_str);
1903    
1904    #ifdef USE_STACKABLE_WINDOW
1905      if(appdata->export_menu) submenu_cleanup(appdata->export_menu);
1906      if(appdata->tools_menu)  submenu_cleanup(appdata->tools_menu);
1907    #endif
1908    
1909    gnome_vfs_shutdown();    gnome_vfs_shutdown();
1910    icons_free();    icons_free();
1911    gps_release(appdata);    gps_release(appdata);
# Line 1637  void cleanup(appdata_t *appdata) { Line 1934  void cleanup(appdata_t *appdata) {
1934    puts("everything is gone");    puts("everything is gone");
1935  }  }
1936    
1937  void on_window_destroy (GtkWidget *widget, gpointer data) {  static void on_window_destroy (GtkWidget *widget, gpointer data) {
1938    appdata_t *appdata = (appdata_t*)data;    appdata_t *appdata = (appdata_t*)data;
1939    
1940    gconf_save_state(appdata);    gconf_save_state(appdata);
# Line 1646  void on_window_destroy (GtkWidget *widge Line 1943  void on_window_destroy (GtkWidget *widge
1943  }  }
1944    
1945  gboolean on_window_key_press(GtkWidget *widget,  gboolean on_window_key_press(GtkWidget *widget,
1946                           GdkEventKey *event, gpointer data) {                           GdkEventKey *event, appdata_t *appdata) {
   appdata_t *appdata = (appdata_t*)data;  
1947    int handled = FALSE;    int handled = FALSE;
1948    
1949    //  printf("key event %d\n", event->keyval);    //  printf("key event %d\n", event->keyval);
# Line 1655  gboolean on_window_key_press(GtkWidget * Line 1951  gboolean on_window_key_press(GtkWidget *
1951    switch(event->keyval) {    switch(event->keyval) {
1952  #ifdef USE_MAEMO  #ifdef USE_MAEMO
1953    
 #if 0  /* don't do this as it interferes with gtkentry fields */  
   case HILDON_HARDKEY_SELECT:  
     /* remove as long as we haven't reached the main gpx list */  
     if(appdata->cur_gpx)  
       hildon_bread_crumb_trail_pop(HILDON_BREAD_CRUMB_TRAIL(appdata->bct));  
     handled = TRUE;  
     break;  
 #endif  
   
1954  #ifdef HILDON_HARDKEY_INCREASE  #ifdef HILDON_HARDKEY_INCREASE
1955    case HILDON_HARDKEY_INCREASE:    case HILDON_HARDKEY_INCREASE:
1956      html_zoom(appdata, TRUE);      html_zoom(appdata, TRUE);
# Line 1848  static void crumb_add(appdata_t *appdata Line 2135  static void crumb_add(appdata_t *appdata
2135  #endif // USE_BREAD_CRUMB_TRAIL  #endif // USE_BREAD_CRUMB_TRAIL
2136    
2137  void main_after_settings_redraw(appdata_t *appdata, int flags) {  void main_after_settings_redraw(appdata_t *appdata, int flags) {
2138      printf("main after settings redraw\n");
2139    
2140      if(!appdata->cur_view) {
2141        printf("no active view\n");
2142        return;
2143      }
2144    
2145  #ifndef USE_MAEMO  #ifndef USE_MAEMO
2146    // in non-maemo setup this can only affect the main screen as    // in non-maemo setup this can only affect the main screen as
2147    // the menu is blocked while a dialog is open. also the main    // the menu is blocked while a dialog is open. also the main
# Line 1883  void main_after_settings_redraw(appdata_ Line 2177  void main_after_settings_redraw(appdata_
2177    }    }
2178    
2179    if(redraw) {    if(redraw) {
2180      gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view);      GtkWidget *container = appdata->vbox;
2181    
2182    #ifdef USE_STACKABLE_WINDOW
2183        HildonWindowStack *stack = hildon_window_stack_get_default();
2184        container = hildon_window_stack_peek(stack);
2185    #endif
2186    
2187        gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view);
2188      switch(redraw) {      switch(redraw) {
2189      case 1:      case 1:
2190        appdata->cur_view = cachelist_create(appdata,        appdata->cur_view = cachelist_create(appdata,
# Line 1898  void main_after_settings_redraw(appdata_ Line 2199  void main_after_settings_redraw(appdata_
2199        break;        break;
2200      }      }
2201    
2202      gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view);  #ifdef USE_STACKABLE_WINDOW
2203      gtk_widget_show_all(appdata->vbox);      if(container != appdata->vbox)
2204    }        gtk_container_add(GTK_CONTAINER(container), appdata->cur_view);
2205        else
2206  #endif  #endif
2207          gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view);
2208    
2209        gtk_widget_show_all(container);
2210      }
2211    #endif // USE_MAEMO
2212  }  }
2213    
2214  int main(int argc, char *argv[]) {  int main(int argc, char *argv[]) {
# Line 1958  int main(int argc, char *argv[]) { Line 2265  int main(int argc, char *argv[]) {
2265    gtk_window_set_default_size(GTK_WINDOW(appdata.window), 500, 300);    gtk_window_set_default_size(GTK_WINDOW(appdata.window), 500, 300);
2266  #endif  #endif
2267    
2268    #if MAEMO_VERSION_MAJOR == 5
2269    gtk_window_set_title(GTK_WINDOW(appdata.window), "GPXView");    gtk_window_set_title(GTK_WINDOW(appdata.window), "GPXView");
2270    #endif
2271    
2272    g_signal_connect(G_OBJECT(appdata.window), "destroy",    g_signal_connect(G_OBJECT(appdata.window), "destroy",
2273                     G_CALLBACK(on_window_destroy), &appdata);                     G_CALLBACK(on_window_destroy), &appdata);
2274    
# Line 1967  int main(int argc, char *argv[]) { Line 2277  int main(int argc, char *argv[]) {
2277    
2278    appdata.vbox = gtk_vbox_new(FALSE, 2);    appdata.vbox = gtk_vbox_new(FALSE, 2);
2279    gtk_container_add(GTK_CONTAINER(appdata.window), appdata.vbox);    gtk_container_add(GTK_CONTAINER(appdata.window), appdata.vbox);
2280    #ifndef USE_STACKABLE_WINDOW
2281    menu_create(&appdata);    menu_create(&appdata);
2282    #else
2283      hildon_window_set_app_menu(HILDON_WINDOW(appdata.window),
2284                                 menu_create(&appdata, MENU_GPXLIST));
2285    #endif
2286    
2287  #ifdef USE_BREAD_CRUMB_TRAIL  #ifdef USE_BREAD_CRUMB_TRAIL
2288    appdata.bct = hildon_bread_crumb_trail_new();    appdata.bct = hildon_bread_crumb_trail_new();

Legend:
Removed from v.2  
changed lines
  Added in v.44