Diff of /trunk/src/main.c

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

revision 5 by harbaum, Tue Jun 23 12:53:07 2009 UTC revision 20 by harbaum, Sat Jul 4 19:42:28 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 264  void cachelist_redraw(appdata_t *appdata Line 264  void cachelist_redraw(appdata_t *appdata
264    // gtk_widget_show_all(appdata->vbox);    // gtk_widget_show_all(appdata->vbox);
265  #else  #else
266    
267      if(!appdata->cur_view) {
268        printf("cachelist redraw: no active view\n");
269        return;
270      }
271    
272    g_assert(!appdata->cur_cache);    g_assert(!appdata->cur_cache);
273    int redraw = 0;    int redraw = 0;
274    if(appdata->search_results)    if(appdata->search_results)
# Line 274  void cachelist_redraw(appdata_t *appdata Line 279  void cachelist_redraw(appdata_t *appdata
279    }    }
280    
281    if(redraw) {    if(redraw) {
282      gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view);      GtkWidget *container = appdata->vbox;
283    
284        printf("redraw %d\n", redraw);
285    
286    #ifdef USE_STACKABLE_WINDOW
287        HildonWindowStack *stack = hildon_window_stack_get_default();
288        container = hildon_window_stack_peek(stack);
289    #endif
290    
291        gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view);
292      switch(redraw) {      switch(redraw) {
293      case 1:      case 1:
294        appdata->cur_view = cachelist_create(appdata,        appdata->cur_view = cachelist_create(appdata,
# Line 286  void cachelist_redraw(appdata_t *appdata Line 300  void cachelist_redraw(appdata_t *appdata
300        break;        break;
301      }      }
302    
303      gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view);  #ifdef USE_STACKABLE_WINDOW
304      gtk_widget_show_all(appdata->vbox);      if(container != appdata->vbox)
305          gtk_container_add(GTK_CONTAINER(container), appdata->cur_view);
306        else
307    #endif
308          gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view);
309    
310        gtk_widget_show_all(container);
311    }    }
312  #endif  #endif
313  }  }
# Line 300  static gboolean cachelist_update(gpointe Line 320  static gboolean cachelist_update(gpointe
320  #ifdef USE_MAEMO  #ifdef USE_MAEMO
321    appdata_t *appdata = (appdata_t*)data;    appdata_t *appdata = (appdata_t*)data;
322    
323      if(appdata->cur_cache)
324        return TRUE;
325    
326    if(appdata->cachelist_disable_screensaver)    if(appdata->cachelist_disable_screensaver)
327      if (osso_display_blanking_pause(appdata->osso_context) != OSSO_OK)      if (osso_display_blanking_pause(appdata->osso_context) != OSSO_OK)
328        fprintf(stderr, "error with display blank\n");        fprintf(stderr, "error with display blank\n");
# Line 312  static gboolean cachelist_update(gpointe Line 335  static gboolean cachelist_update(gpointe
335  }  }
336    
337  static void cachelist_timer_reset(appdata_t *appdata) {  static void cachelist_timer_reset(appdata_t *appdata) {
338      printf("cachelist timer reset\n");
339    g_assert(appdata->cachelist_handler_id);    g_assert(appdata->cachelist_handler_id);
340    gtk_timeout_remove(appdata->cachelist_handler_id);    gtk_timeout_remove(appdata->cachelist_handler_id);
341    appdata->cachelist_handler_id =    appdata->cachelist_handler_id =
# Line 543  void cachelist_dialog(appdata_t *appdata Line 567  void cachelist_dialog(appdata_t *appdata
567  }  }
568  #else  #else
569  #ifdef USE_STACKABLE_WINDOW  #ifdef USE_STACKABLE_WINDOW
570    static void search_result_free(gpx_t *result);
571    
572    void on_cachelist_destroy(GtkWidget *widget, appdata_t *appdata) {
573      if(appdata->search_results) {
574        search_result_free(appdata->search_results);
575        appdata->search_results = NULL;
576      }
577      appdata->cur_gpx = NULL;
578    
579      /* restore cur_view */
580      appdata->cur_view = g_object_get_data(G_OBJECT(widget), "cur_view");
581    }
582    
583  void cachelist_dialog(appdata_t *appdata, gpx_t *gpx) {  void cachelist_dialog(appdata_t *appdata, gpx_t *gpx) {
584    GtkWidget *window = hildon_stackable_window_new();    GtkWidget *window = hildon_stackable_window_new();
585    
586    gtk_window_set_title(GTK_WINDOW(window), gpx->name);    /* store last "cur_view" in window */
587      g_object_set_data(G_OBJECT(window), "cur_view", appdata->cur_view);
588    
589    gtk_container_add(GTK_CONTAINER(window),    appdata->cur_gpx = gpx;
590                      cachelist_create(appdata, gpx, NULL));    char *title = g_strdup_printf("GPXView - %s", gpx->name);
591      gtk_window_set_title(GTK_WINDOW(window), title);
592      g_free(title);
593    
594      appdata->cur_view = cachelist_create(appdata, gpx, NULL);
595      gtk_container_add(GTK_CONTAINER(window), appdata->cur_view);
596    
597    
598    hildon_window_set_app_menu(HILDON_WINDOW(window),    hildon_window_set_app_menu(HILDON_WINDOW(window),
599                               menu_create(appdata, MENU_CACHELIST));                               menu_create(appdata, MENU_CACHELIST));
600    
601      g_signal_connect(G_OBJECT(window), "destroy",
602                       G_CALLBACK(on_cachelist_destroy), appdata);
603    
604    gtk_widget_show_all(window);    gtk_widget_show_all(window);
605  }  }
606  #endif  #endif
# Line 764  static void gpxlist_view_onRowActivated( Line 811  static void gpxlist_view_onRowActivated(
811          gpx_busy_dialog_destroy(dialog);          gpx_busy_dialog_destroy(dialog);
812        }        }
813  #ifndef USE_BREAD_CRUMB_TRAIL  #ifndef USE_BREAD_CRUMB_TRAIL
814        cachelist_dialog(appdata, gpx);  #ifdef USE_STACKABLE_WINDOW
815          if(!appdata->cur_gpx)
816    #endif
817            cachelist_dialog(appdata, gpx);
818    #ifdef USE_STACKABLE_WINDOW
819          else
820            printf("selected gpx, but cachelist window already present\n");
821    #endif
822  #else  #else
823        gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view);        gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view);
824        appdata->cur_view = cachelist_create(appdata, gpx, NULL);        appdata->cur_view = cachelist_create(appdata, gpx, NULL);
# Line 969  cb_menu_about(GtkWidget *window, gpointe Line 1023  cb_menu_about(GtkWidget *window, gpointe
1023    
1024    gtk_about_dialog_set_name(about, "GPXView");    gtk_about_dialog_set_name(about, "GPXView");
1025    gtk_about_dialog_set_version(about, VERSION);    gtk_about_dialog_set_version(about, VERSION);
1026    gtk_about_dialog_set_copyright(about,  
1027           _("GPXView (c) 2008 by\n"  #ifdef ENABLE_LIBLOCATION
1028           "Till Harbaum <till@harbaum.org>\n"    char *uses = "uses liblocation";
1029           "Geocaching.com: Tantil"));  #elif defined(ENABLE_GPSBT)
1030      char *uses = "uses gpsbt and gpsd";
1031    #else
1032      char *uses = "uses gpsd";
1033    #endif
1034    
1035      char *str = g_strdup_printf("%s\n\n(%s)",
1036                          _("GPXView (c) 2008-2009 by\n"
1037                            "Till Harbaum <till@harbaum.org>\n"
1038                            "Mailing list: gpxview-users@garage.maemo.org"),
1039                          _(uses)
1040                          );
1041    
1042      gtk_about_dialog_set_copyright(about, str);
1043      g_free(str);
1044    
1045    gtk_about_dialog_set_website(about,    gtk_about_dialog_set_website(about,
1046         _("http://www.harbaum.org/till/maemo"));         _("http://www.harbaum.org/till/maemo"));
# Line 1328  cb_menu_search(GtkWidget *window, gpoint Line 1396  cb_menu_search(GtkWidget *window, gpoint
1396      /* don't search if we are asked to search for nothing */      /* don't search if we are asked to search for nothing */
1397      if(((appdata->search & (SEARCH_ID|SEARCH_NAME|SEARCH_DESC|SEARCH_OWNER)) &&      if(((appdata->search & (SEARCH_ID|SEARCH_NAME|SEARCH_DESC|SEARCH_OWNER)) &&
1398          strlen(p) > 0) || (appdata->search & SEARCH_FINDS)) {          strlen(p) > 0) || (appdata->search & SEARCH_FINDS)) {
       gpx_t *found = NULL;  
1399    
1400        printf("Search for %s (flags = %x)...\n", p, appdata->search);        printf("Search for %s (flags = %x)...\n", p, appdata->search);
1401    
1402  #ifndef USE_BREAD_CRUMB_TRAIL  #ifndef USE_BREAD_CRUMB_TRAIL
1403        found = search_do(appdata, appdata->gpx, p, appdata->search, FALSE);        gpx_t *found =
1404            search_do(appdata, appdata->gpx, p, appdata->search, FALSE);
1405    
1406        /* do search result dialog here ... */        /* do search result dialog here ... */
1407        cachelist_dialog(appdata, found);        cachelist_dialog(appdata, found);
1408    #ifndef USE_STACKABLE_WINDOW
1409        search_result_free(found);        search_result_free(found);
1410  #else  #else
1411          appdata->search_results = found;
1412    #endif
1413    #else
1414          gpx_t *found = NULL;
1415    
1416        if(appdata->cur_gpx)        if(appdata->cur_gpx)
1417          found = search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE);          found = search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE);
1418        else        else
# Line 1415  cb_menu_paste(GtkWidget *widget, gpointe Line 1489  cb_menu_paste(GtkWidget *widget, gpointe
1489  }  }
1490  #endif  #endif
1491    
1492    static void
1493    cb_menu_export_log(GtkWidget *widget, gpointer data) {
1494      appdata_t *appdata = (appdata_t*)data;
1495      notes_log_export(appdata);
1496  #ifdef USE_STACKABLE_WINDOW  #ifdef USE_STACKABLE_WINDOW
1497  typedef struct {    hildon_window_stack_pop_1 (hildon_window_stack_get_default());
1498    appdata_t *appdata;  #endif
1499    GtkWidget *dialog;  }
 } appmenu_context_t;  
   
 void on_export_mmpoi_clicked(appmenu_context_t *context) {  
   gtk_widget_destroy(context->dialog);  
   while(gtk_events_pending())  
     gtk_main_iteration();  
1500    
1501    mmpoi_export(context->appdata);  #ifdef USE_MAEMO
1502    static void
1503    cb_menu_export_mmpoi(GtkWidget *widget, gpointer data) {
1504      appdata_t *appdata = (appdata_t*)data;
1505      mmpoi_export(appdata);
1506    #ifdef USE_STACKABLE_WINDOW
1507      hildon_window_stack_pop_1 (hildon_window_stack_get_default());
1508    #endif
1509  }  }
1510    #endif
1511    
1512  void on_export_garmin_clicked(appmenu_context_t *context) {  static void
1513    gtk_widget_destroy(context->dialog);  cb_menu_export_garmin(GtkWidget *widget, gpointer data) {
1514    while(gtk_events_pending())    appdata_t *appdata = (appdata_t*)data;
1515      gtk_main_iteration();    garmin_export(appdata);
1516    #ifdef USE_STACKABLE_WINDOW
1517      hildon_window_stack_pop_1 (hildon_window_stack_get_default());
1518    #endif
1519    }
1520    
1521    garmin_export(context->appdata);  static void
1522    cb_menu_geomath(GtkWidget *window, gpointer data) {
1523      geomath_dialog((appdata_t *)data);
1524    #ifdef USE_STACKABLE_WINDOW
1525      hildon_window_stack_pop_1 (hildon_window_stack_get_default());
1526    #endif
1527  }  }
1528    
1529  void on_export_notes_log_clicked(appmenu_context_t *context) {  static void
1530    gtk_widget_destroy(context->dialog);  cb_menu_geotext(GtkWidget *window, gpointer data) {
1531    while(gtk_events_pending())    geotext_dialog((appdata_t *)data);
1532      gtk_main_iteration();  #ifdef USE_STACKABLE_WINDOW
1533      hildon_window_stack_pop_1 (hildon_window_stack_get_default());
1534    #endif
1535    }
1536    
1537    notes_log_export(context->appdata);  static void
1538    cb_menu_precpos(GtkWidget *window, gpointer data) {
1539      precise_position((appdata_t *)data);
1540    #ifdef USE_STACKABLE_WINDOW
1541      hildon_window_stack_pop_1 (hildon_window_stack_get_default());
1542    #endif
1543  }  }
1544    
1545  void on_export_clicked(GtkButton *button, appdata_t *appdata) {  #ifdef USE_STACKABLE_WINDOW
1546    GtkWidget *but;  static GtkWidget *export_menu_create(appdata_t *appdata) {
1547    appmenu_context_t context;    GtkWidget *button;
1548      HildonAppMenu *menu = HILDON_APP_MENU(hildon_app_menu_new());
1549    
1550    context.appdata = appdata;    button = hildon_button_new_with_text(
1551    context.dialog = gtk_dialog_new();              HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH,
1552                HILDON_BUTTON_ARRANGEMENT_VERTICAL,
1553                _("Export to Maemo Mapper"),
1554                _("Save a Maemo Mapper POI file"));
1555      g_signal_connect(button, "clicked",
1556                       G_CALLBACK(cb_menu_export_mmpoi), appdata);
1557      hildon_app_menu_append(menu, GTK_BUTTON(button));
1558    
1559    gtk_window_set_decorated(GTK_WINDOW(context.dialog), FALSE);    button = hildon_button_new_with_text(
1560                HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH,
1561                HILDON_BUTTON_ARRANGEMENT_VERTICAL,
1562                _("Export Field Notes"),
1563                _("Save a Garmin Field Notes file"));
1564      g_signal_connect(button, "clicked",
1565                       G_CALLBACK(cb_menu_export_log), appdata);
1566      hildon_app_menu_append(menu, GTK_BUTTON(button));
1567    
1568    but = hildon_button_new_with_text(HILDON_SIZE_AUTO,    button = hildon_button_new_with_text(
1569                                      HILDON_BUTTON_ARRANGEMENT_VERTICAL,              HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH,
1570                                      _("Export to Maemo Mapper"),              HILDON_BUTTON_ARRANGEMENT_VERTICAL,
1571                                      _("Save a Maemo Mapper POI file"));              _("Export Garmin GPX"),
1572    gtk_container_add(GTK_CONTAINER(GTK_DIALOG(context.dialog)->vbox), but);              _("Save modified waypoints in GPX file"));
1573    g_signal_connect_swapped(but, "clicked",    g_signal_connect(button, "clicked",
1574                             G_CALLBACK(on_export_mmpoi_clicked), &context);                     G_CALLBACK(cb_menu_export_garmin), appdata);
1575      hildon_app_menu_append(menu, GTK_BUTTON(button));
1576    
1577    but = hildon_button_new_with_text(HILDON_SIZE_AUTO,    gtk_widget_show_all(GTK_WIDGET(menu));
                                     HILDON_BUTTON_ARRANGEMENT_VERTICAL,  
                                     _("Export Field Notes"),  
                                     _("Save a Garmin Field Notes file"));  
   gtk_container_add(GTK_CONTAINER(GTK_DIALOG(context.dialog)->vbox), but);  
   g_signal_connect_swapped(but, "clicked",  
                    G_CALLBACK(on_export_notes_log_clicked), &context);  
   
1578    
1579    but = hildon_button_new_with_text(HILDON_SIZE_AUTO,    return GTK_WIDGET(menu);
1580                                      HILDON_BUTTON_ARRANGEMENT_VERTICAL,  }
                                     _("Export Garmin GPX"),  
                                     _("Save a GPX file of modified points"));  
   gtk_container_add(GTK_CONTAINER(GTK_DIALOG(context.dialog)->vbox), but);  
   g_signal_connect_swapped(but, "clicked",  
                            G_CALLBACK(on_export_garmin_clicked), &context);  
1581    
1582     gtk_widget_show_all(context.dialog);  /* the export submenu */
1583     gint result = gtk_dialog_run(GTK_DIALOG(context.dialog));  void on_export_clicked(GtkButton *button, appdata_t *appdata) {
1584      if(!appdata->export_menu)
1585        appdata->export_menu = export_menu_create(appdata);
1586    
1587     /* user clicked outside dialog */    /* draw a popup menu */
1588     if(result == GTK_RESPONSE_DELETE_EVENT)    hildon_app_menu_popup(HILDON_APP_MENU(appdata->export_menu),
1589       gtk_widget_destroy(context.dialog);                          GTK_WINDOW(hildon_window_stack_peek(
1590                        hildon_window_stack_get_default())));
1591  }  }
1592    
1593  void on_tools_geomath_clicked(appmenu_context_t *context) {  static GtkWidget *tools_menu_create(appdata_t *appdata) {
1594    gtk_widget_destroy(context->dialog);    GtkWidget *button;
1595    while(gtk_events_pending())    HildonAppMenu *menu = HILDON_APP_MENU(hildon_app_menu_new());
     gtk_main_iteration();  
1596    
1597    geomath_dialog(context->appdata);    button = hildon_button_new_with_text(
1598  }              HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH,
1599                HILDON_BUTTON_ARRANGEMENT_VERTICAL,
1600                _("Geomath"),
1601                _("Geocoordinate calculation"));
1602      g_signal_connect(button, "clicked",
1603                       G_CALLBACK(cb_menu_geomath), appdata);
1604      hildon_app_menu_append(menu, GTK_BUTTON(button));
1605    
 void on_tools_geotext_clicked(appmenu_context_t *context) {  
   gtk_widget_destroy(context->dialog);  
   while(gtk_events_pending())  
     gtk_main_iteration();  
1606    
1607    geotext_dialog(context->appdata);    button = hildon_button_new_with_text(
1608  }              HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH,
1609                HILDON_BUTTON_ARRANGEMENT_VERTICAL,
1610                _("Geotext"),
1611                _("Text analysis"));
1612      g_signal_connect(button, "clicked",
1613                       G_CALLBACK(cb_menu_geotext), appdata);
1614      hildon_app_menu_append(menu, GTK_BUTTON(button));
1615    
1616    
1617  void on_tools_precpos_clicked(appmenu_context_t *context) {    button = hildon_button_new_with_text(
1618    gtk_widget_destroy(context->dialog);              HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH,
1619    while(gtk_events_pending())              HILDON_BUTTON_ARRANGEMENT_VERTICAL,
1620      gtk_main_iteration();              _("Precise Position"),
1621                _("Calculate a precise GPS position"));
1622      g_signal_connect(button, "clicked",
1623                       G_CALLBACK(cb_menu_precpos), appdata);
1624      hildon_app_menu_append(menu, GTK_BUTTON(button));
1625    
1626    precise_position(context->appdata);    gtk_widget_show_all(GTK_WIDGET(menu));
1627    
1628      return GTK_WIDGET(menu);
1629  }  }
1630    
1631    /* the tools submenu */
1632  void on_tools_clicked(GtkButton *button, appdata_t *appdata) {  void on_tools_clicked(GtkButton *button, appdata_t *appdata) {
1633    GtkWidget *but;    if(!appdata->tools_menu)
1634    appmenu_context_t context;      appdata->tools_menu = tools_menu_create(appdata);
   
   context.appdata = appdata;  
   context.dialog = gtk_dialog_new();  
   
   gtk_window_set_decorated(GTK_WINDOW(context.dialog), FALSE);  
1635    
1636    but = hildon_button_new_with_text(HILDON_SIZE_AUTO,    /* draw a popup menu */
1637                                      HILDON_BUTTON_ARRANGEMENT_VERTICAL,    hildon_app_menu_popup(HILDON_APP_MENU(appdata->tools_menu),
1638                                      _("Geomath"),                          GTK_WINDOW(hildon_window_stack_peek(
1639                                      _("Geocoordinate calculation"));                      hildon_window_stack_get_default())));
   gtk_container_add(GTK_CONTAINER(GTK_DIALOG(context.dialog)->vbox), but);  
   g_signal_connect_swapped(but, "clicked",  
                            G_CALLBACK(on_tools_geomath_clicked), &context);  
   
   but = hildon_button_new_with_text(HILDON_SIZE_AUTO,  
                                     HILDON_BUTTON_ARRANGEMENT_VERTICAL,  
                                     _("Geotext"),  
                                     _("Text analysis, letter counting etc"));  
   gtk_container_add(GTK_CONTAINER(GTK_DIALOG(context.dialog)->vbox), but);  
   g_signal_connect_swapped(but, "clicked",  
                    G_CALLBACK(on_tools_geotext_clicked), &context);  
   
   
   but = hildon_button_new_with_text(HILDON_SIZE_AUTO,  
                                     HILDON_BUTTON_ARRANGEMENT_VERTICAL,  
                                     _("Precise Position"),  
                                     _("Calculate a very precise GPS posotions"));  
   gtk_container_add(GTK_CONTAINER(GTK_DIALOG(context.dialog)->vbox), but);  
   g_signal_connect_swapped(but, "clicked",  
                            G_CALLBACK(on_tools_precpos_clicked), &context);  
   
    gtk_widget_show_all(context.dialog);  
    gint result = gtk_dialog_run(GTK_DIALOG(context.dialog));  
   
    /* user clicked outside dialog */  
    if(result == GTK_RESPONSE_DELETE_EVENT)  
      gtk_widget_destroy(context.dialog);  
1640  }  }
1641    
1642    
1643  HildonAppMenu *menu_create(appdata_t *appdata, int mode) {  HildonAppMenu *menu_create(appdata_t *appdata, int mode) {
1644    GtkWidget *button;    GtkWidget *button;
1645    HildonAppMenu *menu = HILDON_APP_MENU(hildon_app_menu_new());    HildonAppMenu *menu = HILDON_APP_MENU(hildon_app_menu_new());
1646    
1647    /* ------- */    /* ------- */
1648      button = gtk_button_new_with_label(_("About"));
1649      g_signal_connect_after(button, "clicked",
1650                             G_CALLBACK(cb_menu_about), appdata);
1651      hildon_app_menu_append(menu, GTK_BUTTON(button));
1652    
1653    button = gtk_button_new_with_label(_("Settings"));    button = gtk_button_new_with_label(_("Settings"));
1654    g_signal_connect_after(button, "clicked", G_CALLBACK(cb_menu_settings),    g_signal_connect_after(button, "clicked", G_CALLBACK(cb_menu_settings),
1655                           appdata);                           appdata);
# Line 1569  HildonAppMenu *menu_create(appdata_t *ap Line 1661  HildonAppMenu *menu_create(appdata_t *ap
1661                             G_CALLBACK(cb_menu_add), appdata);                             G_CALLBACK(cb_menu_add), appdata);
1662      hildon_app_menu_append(menu, GTK_BUTTON(button));      hildon_app_menu_append(menu, GTK_BUTTON(button));
1663    
1664      button = gtk_button_new_with_label(_("Import dir"));      button = gtk_button_new_with_label(_("Import directory"));
1665      g_signal_connect_after(button, "clicked",      g_signal_connect_after(button, "clicked",
1666                             G_CALLBACK(cb_menu_adddir), appdata);                             G_CALLBACK(cb_menu_adddir), appdata);
1667      hildon_app_menu_append(menu, GTK_BUTTON(button));      hildon_app_menu_append(menu, GTK_BUTTON(button));
# Line 1592  HildonAppMenu *menu_create(appdata_t *ap Line 1684  HildonAppMenu *menu_create(appdata_t *ap
1684                           G_CALLBACK(on_tools_clicked), appdata);                           G_CALLBACK(on_tools_clicked), appdata);
1685    hildon_app_menu_append(menu, GTK_BUTTON(button));    hildon_app_menu_append(menu, GTK_BUTTON(button));
1686    
1687    button = gtk_button_new_with_label(_("About"));  #ifdef HILDON_HELP
1688      button = gtk_button_new_with_label(_("Help"));
1689    g_signal_connect_after(button, "clicked",    g_signal_connect_after(button, "clicked",
1690                           G_CALLBACK(cb_menu_about), appdata);                           G_CALLBACK(cb_menu_help), appdata);
1691    hildon_app_menu_append(menu, GTK_BUTTON(button));    hildon_app_menu_append(menu, GTK_BUTTON(button));
1692    #endif
1693    
1694    gtk_widget_show(GTK_WIDGET(menu));    gtk_widget_show_all(GTK_WIDGET(menu));
1695    
1696    return menu;    return menu;
1697  }  }
1698  #else  #else
 static void  
 cb_menu_export_log(GtkWidget *widget, gpointer data) {  
   appdata_t *appdata = (appdata_t*)data;  
   notes_log_export(appdata);  
 }  
   
 #ifdef USE_MAEMO  
 static void  
 cb_menu_export_mmpoi(GtkWidget *widget, gpointer data) {  
   appdata_t *appdata = (appdata_t*)data;  
   mmpoi_export(appdata);  
 }  
 #endif  
   
 static void  
 cb_menu_export_garmin(GtkWidget *widget, gpointer data) {  
   appdata_t *appdata = (appdata_t*)data;  
   garmin_export(appdata);  
 }  
   
 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);  
 }  
1699    
1700  void menu_create(appdata_t *appdata) {  void menu_create(appdata_t *appdata) {
1701    GtkWidget *menu, *item;    GtkWidget *menu, *item;
# Line 1649  void menu_create(appdata_t *appdata) { Line 1709  void menu_create(appdata_t *appdata) {
1709    GtkWidget *submenu = gtk_menu_new();    GtkWidget *submenu = gtk_menu_new();
1710    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
1711    
1712    item = gtk_menu_item_new_with_label( _("File...") );    item = gtk_menu_item_new_with_label( _("File") );
1713    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1714    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_add), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_add), appdata);
1715    
1716    item = gtk_menu_item_new_with_label( _("Directory...") );    item = gtk_menu_item_new_with_label( _("Directory") );
1717    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1718    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_adddir), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_adddir), appdata);
1719    
# Line 1680  void menu_create(appdata_t *appdata) { Line 1740  void menu_create(appdata_t *appdata) {
1740    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
1741    
1742  #ifdef USE_MAEMO  #ifdef USE_MAEMO
1743    item = gtk_menu_item_new_with_label( _("Maemo Mapper POI...") );    item = gtk_menu_item_new_with_label( _("Maemo Mapper POI") );
1744    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1745    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1746                     GTK_SIGNAL_FUNC(cb_menu_export_mmpoi), appdata);                     GTK_SIGNAL_FUNC(cb_menu_export_mmpoi), appdata);
1747  #endif  #endif
1748    
1749    item = gtk_menu_item_new_with_label( _("Garmin Field Notes...") );    item = gtk_menu_item_new_with_label( _("Garmin Field Notes") );
1750    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1751    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1752                     GTK_SIGNAL_FUNC(cb_menu_export_log), appdata);                     GTK_SIGNAL_FUNC(cb_menu_export_log), appdata);
1753    
1754    item = gtk_menu_item_new_with_label( _("Garmin GPX...") );    item = gtk_menu_item_new_with_label( _("Garmin GPX") );
1755    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1756    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1757                     GTK_SIGNAL_FUNC(cb_menu_export_garmin), appdata);                     GTK_SIGNAL_FUNC(cb_menu_export_garmin), appdata);
# Line 1699  void menu_create(appdata_t *appdata) { Line 1759  void menu_create(appdata_t *appdata) {
1759  #ifdef USE_BREAD_CRUMB_TRAIL  #ifdef USE_BREAD_CRUMB_TRAIL
1760    appdata->menu_search =    appdata->menu_search =
1761  #endif  #endif
1762    item = gtk_menu_item_new_with_label( _("Search...") );    item = gtk_menu_item_new_with_label( _("Search") );
1763    gtk_menu_append(GTK_MENU_SHELL(menu), item);    gtk_menu_append(GTK_MENU_SHELL(menu), item);
1764    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_search), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_search), appdata);
1765    
# Line 1741  void menu_create(appdata_t *appdata) { Line 1801  void menu_create(appdata_t *appdata) {
1801    submenu = gtk_menu_new();    submenu = gtk_menu_new();
1802    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
1803    
1804    item = gtk_menu_item_new_with_label( _("Geomath...") );    item = gtk_menu_item_new_with_label( _("Geomath") );
1805    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1806    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1807                     GTK_SIGNAL_FUNC(cb_menu_geomath), appdata);                     GTK_SIGNAL_FUNC(cb_menu_geomath), appdata);
1808    
1809    item = gtk_menu_item_new_with_label( _("Geotext...") );    item = gtk_menu_item_new_with_label( _("Geotext") );
1810    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1811    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1812                     GTK_SIGNAL_FUNC(cb_menu_geotext), appdata);                     GTK_SIGNAL_FUNC(cb_menu_geotext), appdata);
1813    
1814    item = gtk_menu_item_new_with_label( _("Precise Position...") );    item = gtk_menu_item_new_with_label( _("Precise Position") );
1815    gtk_menu_append(GTK_MENU_SHELL(submenu), item);    gtk_menu_append(GTK_MENU_SHELL(submenu), item);
1816    g_signal_connect(item, "activate",    g_signal_connect(item, "activate",
1817                     GTK_SIGNAL_FUNC(cb_menu_precpos), appdata);                     GTK_SIGNAL_FUNC(cb_menu_precpos), appdata);
# Line 1759  void menu_create(appdata_t *appdata) { Line 1819  void menu_create(appdata_t *appdata) {
1819    gtk_menu_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new());    gtk_menu_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new());
1820    
1821  #if defined(USE_MAEMO) && defined(HILDON_HELP)  #if defined(USE_MAEMO) && defined(HILDON_HELP)
1822    item = gtk_menu_item_new_with_label( _("Help...") );    item = gtk_menu_item_new_with_label( _("Help") );
1823    gtk_menu_append(GTK_MENU_SHELL(menu), item);    gtk_menu_append(GTK_MENU_SHELL(menu), item);
1824    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_help), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_help), appdata);
1825  #endif  #endif
1826    
1827    item = gtk_menu_item_new_with_label( _("About...") );    item = gtk_menu_item_new_with_label( _("About") );
1828    gtk_menu_append(GTK_MENU_SHELL(menu), item);    gtk_menu_append(GTK_MENU_SHELL(menu), item);
1829    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_about), appdata);    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_about), appdata);
1830    
# Line 1837  void on_window_destroy (GtkWidget *widge Line 1897  void on_window_destroy (GtkWidget *widge
1897  }  }
1898    
1899  gboolean on_window_key_press(GtkWidget *widget,  gboolean on_window_key_press(GtkWidget *widget,
1900                           GdkEventKey *event, gpointer data) {                           GdkEventKey *event, appdata_t *appdata) {
   appdata_t *appdata = (appdata_t*)data;  
1901    int handled = FALSE;    int handled = FALSE;
1902    
1903    //  printf("key event %d\n", event->keyval);    //  printf("key event %d\n", event->keyval);
# Line 1846  gboolean on_window_key_press(GtkWidget * Line 1905  gboolean on_window_key_press(GtkWidget *
1905    switch(event->keyval) {    switch(event->keyval) {
1906  #ifdef USE_MAEMO  #ifdef USE_MAEMO
1907    
 #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  
   
1908  #ifdef HILDON_HARDKEY_INCREASE  #ifdef HILDON_HARDKEY_INCREASE
1909    case HILDON_HARDKEY_INCREASE:    case HILDON_HARDKEY_INCREASE:
1910      html_zoom(appdata, TRUE);      html_zoom(appdata, TRUE);
# Line 2039  static void crumb_add(appdata_t *appdata Line 2089  static void crumb_add(appdata_t *appdata
2089  #endif // USE_BREAD_CRUMB_TRAIL  #endif // USE_BREAD_CRUMB_TRAIL
2090    
2091  void main_after_settings_redraw(appdata_t *appdata, int flags) {  void main_after_settings_redraw(appdata_t *appdata, int flags) {
2092      printf("main after settings redraw\n");
2093    
2094      if(!appdata->cur_view) {
2095        printf("no active view\n");
2096        return;
2097      }
2098    
2099  #ifndef USE_MAEMO  #ifndef USE_MAEMO
2100    // in non-maemo setup this can only affect the main screen as    // in non-maemo setup this can only affect the main screen as
2101    // 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 2074  void main_after_settings_redraw(appdata_ Line 2131  void main_after_settings_redraw(appdata_
2131    }    }
2132    
2133    if(redraw) {    if(redraw) {
2134      gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view);      GtkWidget *container = appdata->vbox;
2135    
2136    #ifdef USE_STACKABLE_WINDOW
2137        HildonWindowStack *stack = hildon_window_stack_get_default();
2138        container = hildon_window_stack_peek(stack);
2139    #endif
2140    
2141        gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view);
2142      switch(redraw) {      switch(redraw) {
2143      case 1:      case 1:
2144        appdata->cur_view = cachelist_create(appdata,        appdata->cur_view = cachelist_create(appdata,
# Line 2089  void main_after_settings_redraw(appdata_ Line 2153  void main_after_settings_redraw(appdata_
2153        break;        break;
2154      }      }
2155    
2156      gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view);  #ifdef USE_STACKABLE_WINDOW
2157      gtk_widget_show_all(appdata->vbox);      if(container != appdata->vbox)
2158    }        gtk_container_add(GTK_CONTAINER(container), appdata->cur_view);
2159        else
2160  #endif  #endif
2161          gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view);
2162    
2163        gtk_widget_show_all(container);
2164      }
2165    #endif // USE_MAEMO
2166  }  }
2167    
2168  int main(int argc, char *argv[]) {  int main(int argc, char *argv[]) {
# Line 2149  int main(int argc, char *argv[]) { Line 2219  int main(int argc, char *argv[]) {
2219    gtk_window_set_default_size(GTK_WINDOW(appdata.window), 500, 300);    gtk_window_set_default_size(GTK_WINDOW(appdata.window), 500, 300);
2220  #endif  #endif
2221    
2222    #if MAEMO_VERSION_MAJOR == 5
2223    gtk_window_set_title(GTK_WINDOW(appdata.window), "GPXView");    gtk_window_set_title(GTK_WINDOW(appdata.window), "GPXView");
2224    #endif
2225    
2226    g_signal_connect(G_OBJECT(appdata.window), "destroy",    g_signal_connect(G_OBJECT(appdata.window), "destroy",
2227                     G_CALLBACK(on_window_destroy), &appdata);                     G_CALLBACK(on_window_destroy), &appdata);
2228    

Legend:
Removed from v.5  
changed lines
  Added in v.20