Diff of /trunk/src/main.c

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

revision 54 by harbaum, Fri Feb 6 12:06:30 2009 UTC revision 76 by harbaum, Fri Feb 13 12:02:26 2009 UTC
# Line 56  static void main_ui_enable(appdata_t *ap Line 56  static void main_ui_enable(appdata_t *ap
56    /* disable all menu entries related to map */    /* disable all menu entries related to map */
57    gtk_widget_set_sensitive(appdata->menu_osm, project_valid);    gtk_widget_set_sensitive(appdata->menu_osm, project_valid);
58    gtk_widget_set_sensitive(appdata->menu_item_osm_upload, osm_valid);    gtk_widget_set_sensitive(appdata->menu_item_osm_upload, osm_valid);
59    gtk_widget_set_sensitive(appdata->menu_item_osm_diff, osm_valid);    if(appdata->menu_item_osm_undo)
60        gtk_widget_set_sensitive(appdata->menu_item_osm_undo, osm_valid);
61      gtk_widget_set_sensitive(appdata->menu_item_osm_save_changes, osm_valid);
62    gtk_widget_set_sensitive(appdata->menu_item_osm_undo_changes, osm_valid);    gtk_widget_set_sensitive(appdata->menu_item_osm_undo_changes, osm_valid);
63    gtk_widget_set_sensitive(appdata->track.menu_track, osm_valid);    gtk_widget_set_sensitive(appdata->track.menu_track, osm_valid);
64    gtk_widget_set_sensitive(appdata->menu_view, osm_valid);    gtk_widget_set_sensitive(appdata->menu_view, osm_valid);
# Line 70  static void main_ui_enable(appdata_t *ap Line 72  static void main_ui_enable(appdata_t *ap
72    
73  /******************** begin of menu *********************/  /******************** begin of menu *********************/
74    
 #if 0 // simplify menu  
 static struct {  
   enum { MENU_END, MENU_ITEM, MENU_SUB, MENU_SUB_END, MENU_SEP }  type;  
   
   char *title;  
   GCallback c_handler;  
 } menu[] = {  
   { MENU_SUB, "_OSM", NULL },  
   
   { MENU_END,  NULL, NULL },  
 };  
 #endif  
   
75  static void  static void
76  cb_menu_project_open(GtkWidget *window, gpointer data) {  cb_menu_project_open(GtkWidget *window, gpointer data) {
77    appdata_t *appdata = (appdata_t*)data;    appdata_t *appdata = (appdata_t*)data;
# Line 257  cb_menu_map_no_antialias(GtkWidget *widg Line 246  cb_menu_map_no_antialias(GtkWidget *widg
246  }  }
247    
248  static void  static void
249    cb_menu_undo(GtkWidget *widget, gpointer data) {
250      appdata_t *appdata = (appdata_t*)data;
251    
252      undo(appdata);
253    
254      // the banner will be displayed from within undo with more details
255    }
256    
257    static void
258  cb_menu_save_changes(GtkWidget *widget, gpointer data) {  cb_menu_save_changes(GtkWidget *widget, gpointer data) {
259    appdata_t *appdata = (appdata_t*)data;    appdata_t *appdata = (appdata_t*)data;
260    
# Line 270  cb_menu_undo_changes(GtkWidget *widget, Line 268  cb_menu_undo_changes(GtkWidget *widget,
268    
269    if(!yes_no_f(GTK_WIDGET(appdata->window), NULL, 0, 0,    if(!yes_no_f(GTK_WIDGET(appdata->window), NULL, 0, 0,
270                 _("Discard local changes?"),                 _("Discard local changes?"),
271                 _("Throw away all the changes you've not uploaded yet? This can't be undone.")))                 _("Throw away all the changes you've not "
272                     "uploaded yet? This can't be undone.")))
273      return;      return;
274    
275    banner_busy_start(appdata, 1, _("Redrawing..."));    banner_busy_start(appdata, 1, _("Redrawing..."));
# Line 285  cb_menu_undo_changes(GtkWidget *widget, Line 284  cb_menu_undo_changes(GtkWidget *widget,
284  }  }
285    
286  static void  static void
287    cb_menu_osm_relations(GtkWidget *widget, gpointer data) {
288      relation_list((appdata_t*)data);
289    }
290    
291    static void
292  cb_menu_fullscreen(GtkWidget *widget, gpointer data) {  cb_menu_fullscreen(GtkWidget *widget, gpointer data) {
293    appdata_t *appdata = (appdata_t *)data;    appdata_t *appdata = (appdata_t *)data;
294    
# Line 384  cb_menu_track_clear(GtkWidget *window, g Line 388  cb_menu_track_clear(GtkWidget *window, g
388    track_do(appdata, TRACK_NONE, NULL);    track_do(appdata, TRACK_NONE, NULL);
389  }  }
390    
391    
392    
393    
394    /*
395     *  Platform-specific UI tweaks.
396     */
397    
398    
399  #ifndef USE_HILDON  #ifndef USE_HILDON
400  #ifdef PORTRAIT  #ifdef PORTRAIT
401  #define MAIN_MENU_NEW gtk_menu_new  
402    // Portrait mode, for openmoko-like systems
403    #define uispecific_main_menu_new gtk_menu_new
404    
405  #else  #else
406  #define MAIN_MENU_NEW gtk_menu_bar_new  
407  #define MAIN_MENU_IS_MENU_BAR  // Regular desktop builds
408    #define uispecific_main_menu_new gtk_menu_bar_new
409    #define UISPECIFIC_MAIN_MENU_IS_MENU_BAR
410    #define UISPECIFIC_MENU_HAS_ICONS
411    #define UISPECIFIC_MENU_HAS_ACCELS
412    
413  #endif //PORTRAIT  #endif //PORTRAIT
414  #else //USE_HILDON  #else//USE_HILDON
415  #define MAIN_MENU_NEW gtk_menu_new  
416    // Maemo/Hildon builds
417    #define uispecific_main_menu_new gtk_menu_new
418    
419    #endif
420    
421    
422    
423    // Half-arsed slapdash common menu item constructor. Let's use GtkBuilder
424    // instead so we have some flexibility.
425    
426    static GtkWidget *
427    menu_append_new_item(appdata_t *appdata,
428                         GtkWidget *menu_shell,
429                         GtkSignalFunc activate_cb,
430                         char *label,
431                         const gchar *stock_id, // overridden by label, accels
432                         const gchar *accel_path,
433                         guint accel_key,      // from gdk/gdkkeysyms.h
434                         GdkModifierType accel_mods, // e.g. GDK_CONTROL_MASK
435                         gboolean is_check, gboolean check_status)
436    {
437      GtkWidget *item = NULL;
438      GtkStockItem stock_item;
439      gboolean stock_item_known = FALSE;
440      if (stock_id != NULL) {
441        stock_item_known = gtk_stock_lookup(stock_id, &stock_item);
442      }
443    
444      // Icons
445    #ifndef UISPECIFIC_MENU_HAS_ICONS
446      item = is_check ? gtk_check_menu_item_new_with_mnemonic (label)
447                      : gtk_menu_item_new_with_mnemonic       (label);
448    #else
449      if (is_check || !stock_item_known) {
450        item = is_check ? gtk_check_menu_item_new_with_mnemonic (label)
451                        : gtk_menu_item_new_with_mnemonic       (label);
452      }
453      else {
454        item = gtk_image_menu_item_new_with_mnemonic(label);
455        GtkWidget *stock_image = gtk_image_new_from_stock(stock_id, GTK_ICON_SIZE_MENU);
456        gtk_image_menu_item_set_image(GTK_IMAGE_MENU_ITEM(item), stock_image);
457      }
458    #endif
459    
460    #ifdef UISPECIFIC_MENU_HAS_ACCELS
461      // Accelerators
462      // Default
463      if (accel_path != NULL) {
464        gtk_menu_item_set_accel_path(GTK_MENU_ITEM(item), accel_path);
465        if (accel_key != 0) {
466          gtk_accel_map_add_entry( accel_path, accel_key, accel_mods );
467        }
468        else if (stock_item_known) {
469          gtk_accel_map_add_entry( accel_path, stock_item.keyval,
470                                   stock_item.modifier );
471        }
472      }
473  #endif  #endif
474    
475      gtk_menu_shell_append(GTK_MENU_SHELL(menu_shell), GTK_WIDGET(item));
476      if (is_check) {
477        gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), check_status);
478      }
479      g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(activate_cb),
480                       appdata);
481      return item;
482    }
483    
484    
485  void menu_create(appdata_t *appdata) {  void menu_create(appdata_t *appdata) {
486    GtkWidget *menu, *item, *submenu;    GtkWidget *menu, *item, *submenu;
487    GtkWidget *about_quit_items_menu;    GtkWidget *about_quit_items_menu;
488    menu = MAIN_MENU_NEW();  
489      if (g_module_supported()) {
490        printf("*** can use GModule: consider using GtkUIManager / GtkBuilder\n");
491      }
492    
493      menu = uispecific_main_menu_new();
494    about_quit_items_menu = menu;    about_quit_items_menu = menu;
495    
496    /* -------------------- Project submenu -------------------- */    /* -------------------- Project submenu -------------------- */
497    
498    item = gtk_menu_item_new_with_label( _("Project") );    GtkAccelGroup *accel_grp = gtk_accel_group_new();
499      item = gtk_menu_item_new_with_mnemonic( _("_Project") );
500    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);
501    submenu = gtk_menu_new();    submenu = gtk_menu_new();
502      gtk_menu_set_accel_group(GTK_MENU(submenu), accel_grp);
503    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
504  #ifdef MAIN_MENU_IS_MENU_BAR  #ifdef UISPECIFIC_MAIN_MENU_IS_MENU_BAR
505    about_quit_items_menu = submenu;    about_quit_items_menu = submenu;
506  #endif  #endif
507    
508    item = gtk_menu_item_new_with_label( _("Open...") );    menu_append_new_item(
509    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_project_open), _("_Open..."),
510    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_project_open),      GTK_STOCK_OPEN, "<OSM2Go-Main>/Project/Open",
511                     appdata);      0, 0, FALSE, FALSE
512      );
513    appdata->menu_item_project_close = item =  
514      gtk_menu_item_new_with_label( _("Close") );    appdata->menu_item_project_close = menu_append_new_item(
515    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_project_close), _("_Close"),
516    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_project_close),      GTK_STOCK_CLOSE, "<OSM2Go-Main>/Project/Close",
517                     appdata);      0, 0, FALSE, FALSE
518      );
519    
520    /* --------------- view menu ------------------- */    /* --------------- view menu ------------------- */
521    
522  #ifndef MAIN_MENU_IS_MENU_BAR  #ifndef UISPECIFIC_MENU_IS_MENU_BAR
523    gtk_menu_shell_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new());    gtk_menu_shell_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new());
524  #endif  #endif
525    
526    appdata->menu_view = item =    appdata->menu_view = item = gtk_menu_item_new_with_mnemonic( _("_View") );
     gtk_menu_item_new_with_label( _("View") );  
527    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);
528    submenu = gtk_menu_new();    submenu = gtk_menu_new();
529      gtk_menu_set_accel_group(GTK_MENU(submenu), accel_grp);
530    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
531    
532    appdata->menu_item_view_fullscreen =    appdata->menu_item_view_fullscreen = menu_append_new_item(
533      item = gtk_check_menu_item_new_with_label( _("Fullscreen") );      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_fullscreen), _("_Fullscreen"),
534    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      GTK_STOCK_FULLSCREEN, "<OSM2Go-Main>/View/Fullscreen",
535    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_fullscreen),      0, 0, TRUE, FALSE
536                     appdata);    );
537    
538    item = gtk_menu_item_new_with_label( _("Zoom +" ));    menu_append_new_item(
539    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_zoomin), _("Zoom _in"),
540    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_zoomin), appdata);      GTK_STOCK_ZOOM_IN, "<OSM2Go-Main>/View/ZoomIn",
541        GDK_comma, GDK_CONTROL_MASK, FALSE, FALSE
542    item = gtk_menu_item_new_with_label( _("Zoom -") );    );
543    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);  
544    g_signal_connect(item, "activate",    menu_append_new_item(
545                     GTK_SIGNAL_FUNC(cb_menu_zoomout), appdata);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_zoomout), _("Zoom _out"),
546        GTK_STOCK_ZOOM_OUT, "<OSM2Go-Main>/View/ZoomOut",
547        GDK_period, GDK_CONTROL_MASK, FALSE, FALSE
548      );
549    
550    /* -------------------- OSM submenu -------------------- */    /* -------------------- OSM submenu -------------------- */
551    
552    appdata->menu_osm = item = gtk_menu_item_new_with_label( _("OSM") );    appdata->menu_osm = item = gtk_menu_item_new_with_mnemonic( _("_OSM") );
553    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);
554    submenu = gtk_menu_new();    submenu = gtk_menu_new();
555      gtk_menu_set_accel_group(GTK_MENU(submenu), accel_grp);
556    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
557    
558    appdata->menu_item_osm_upload = item =    appdata->menu_item_osm_upload = menu_append_new_item(
559      gtk_menu_item_new_with_label( _("Upload...") );      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_upload), _("_Upload..."),
560    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      NULL, "<OSM2Go-Main>/OSM/Upload",
561    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_upload), appdata);      GDK_u, GDK_SHIFT_MASK|GDK_CONTROL_MASK, FALSE, FALSE
562      );
563    item = gtk_menu_item_new_with_label( _("Download...") );  
564    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);    menu_append_new_item(
565    g_signal_connect(item, "activate",      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_download), _("_Download..."),
566                     GTK_SIGNAL_FUNC(cb_menu_download), appdata);      NULL, "<OSM2Go-Main>/OSM/Download",
567        GDK_d, GDK_SHIFT_MASK|GDK_CONTROL_MASK, FALSE, FALSE
568      );
569    
570    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), gtk_separator_menu_item_new());    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), gtk_separator_menu_item_new());
571    
572    appdata->menu_item_osm_diff = item =    if(getenv("OSM2GO_UNDO_TEST")) {
573      gtk_menu_item_new_with_label( _("Save local changes") );      appdata->menu_item_osm_undo = menu_append_new_item(
574    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);                 appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_undo), _("_Undo"),
575    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_save_changes),                 GTK_STOCK_UNDO, "<OSM2Go-Main>/OSM/Undo",
576                     appdata);                 GDK_z, GDK_CONTROL_MASK, FALSE, FALSE
577                   );
578      } else
579        printf("set environment variable OSM2GO_UNDO_TEST to enable undo framework tests\n");
580    
581      appdata->menu_item_osm_save_changes = menu_append_new_item(
582        appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_save_changes), _("_Save local changes"),
583        GTK_STOCK_SAVE, "<OSM2Go-Main>/OSM/SaveChanges",
584        GDK_s, GDK_SHIFT_MASK|GDK_CONTROL_MASK, FALSE, FALSE
585      );
586    
587      appdata->menu_item_osm_undo_changes = menu_append_new_item(
588        appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_undo_changes), _("Disca_rd local changes..."),
589        GTK_STOCK_DELETE, "<OSM2Go-Main>/OSM/DiscardChanges",
590        0, 0, FALSE, FALSE
591      );
592    
593    appdata->menu_item_osm_undo_changes = item =    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), gtk_separator_menu_item_new());
594      gtk_menu_item_new_with_label( _("Discard local changes...") );    appdata->menu_item_osm_relations = menu_append_new_item(
595    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_osm_relations), _("_Relations..."),
596    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_undo_changes),      NULL, "<OSM2Go-Main>/OSM/Relations",
597                     appdata);      GDK_r, GDK_SHIFT_MASK|GDK_CONTROL_MASK, FALSE, FALSE
598      );
599    
600    /* -------------------- wms submenu -------------------- */    /* -------------------- wms submenu -------------------- */
601    
602    appdata->menu_wms = item = gtk_menu_item_new_with_label( _("WMS") );    appdata->menu_wms = item = gtk_menu_item_new_with_mnemonic( _("_WMS") );
603    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);
604    submenu = gtk_menu_new();    submenu = gtk_menu_new();
605      gtk_menu_set_accel_group(GTK_MENU(submenu), accel_grp);
606    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
607    
608    item = gtk_menu_item_new_with_label( _("Import...") );    menu_append_new_item(
609    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_import), _("_Import..."),
610    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_wms_import),      GTK_STOCK_INDEX, "<OSM2Go-Main>/WMS/Import",
611                     appdata);      0, 0, FALSE, FALSE
612      );
613    appdata->menu_item_wms_clear = item =  
614      gtk_menu_item_new_with_label( _("Clear") );    appdata->menu_item_wms_clear = menu_append_new_item(
615    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_clear), _("_Clear"),
616    gtk_widget_set_sensitive(item, FALSE);      GTK_STOCK_CLEAR, "<OSM2Go-Main>/WMS/Clear",
617    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_wms_clear),      0, 0, FALSE, FALSE
618                     appdata);    );
619      gtk_widget_set_sensitive(appdata->menu_item_wms_clear, FALSE);
620    appdata->menu_item_wms_adjust = item =  
621      gtk_menu_item_new_with_label( _("Adjust") );    appdata->menu_item_wms_adjust = menu_append_new_item(
622    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_adjust), _("_Adjust"),
623    gtk_widget_set_sensitive(item, FALSE);      NULL, "<OSM2Go-Main>/WMS/Adjust",
624    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_wms_adjust),      0, 0, FALSE, FALSE
625                     appdata);    );
626      gtk_widget_set_sensitive(appdata->menu_item_wms_adjust, FALSE);
627    
628    /* -------------------- map submenu -------------------- */    /* -------------------- map submenu -------------------- */
629    
630    appdata->menu_map = item = gtk_menu_item_new_with_label( _("Map") );    appdata->menu_map = item = gtk_menu_item_new_with_mnemonic( _("_Map") );
631    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);
632    submenu = gtk_menu_new();    submenu = gtk_menu_new();
633      gtk_menu_set_accel_group(GTK_MENU(submenu), accel_grp);
634    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
635    
636    appdata->menu_item_map_hide_sel = item =    appdata->menu_item_map_hide_sel = menu_append_new_item(
637      gtk_menu_item_new_with_label( _("Hide selected") );      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_hide_sel), _("_Hide selected"),
638    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      GTK_STOCK_REMOVE, "<OSM2Go-Main>/Map/HideSelected",
639    gtk_widget_set_sensitive(item, FALSE);      0, 0, FALSE, FALSE
640    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_map_hide_sel),    );
641                     appdata);    gtk_widget_set_sensitive(appdata->menu_item_map_hide_sel, FALSE);
642    
643    appdata->menu_item_map_show_all = item =    appdata->menu_item_map_show_all = menu_append_new_item(
644      gtk_menu_item_new_with_label( _("Show all") );      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_show_all), _("_Show all"),
645    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      GTK_STOCK_ADD, "<OSM2Go-Main>/Map/ShowAll",
646    gtk_widget_set_sensitive(item, FALSE);      0, 0, FALSE, FALSE
647    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_map_show_all),    );
648                     appdata);    gtk_widget_set_sensitive(appdata->menu_item_map_show_all, FALSE);
649    
650    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), gtk_separator_menu_item_new());    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), gtk_separator_menu_item_new());
651    
652    item = gtk_menu_item_new_with_label( _("Style...") );    menu_append_new_item(
653    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_style), _("St_yle..."),
654    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_style), appdata);      GTK_STOCK_SELECT_COLOR, "<OSM2Go-Main>/Map/Style",
655        0, 0, FALSE, FALSE
656      );
657    
658    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), gtk_separator_menu_item_new());    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), gtk_separator_menu_item_new());
659    
660    /* switches mainly intended for testing/debugging */    /* switches mainly intended for testing/debugging */
661    item = gtk_menu_item_new_with_label( _("Redraw") );    menu_append_new_item(
662    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_redraw), _("_Redraw"),
663    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_redraw), appdata);      NULL, "<OSM2Go-Main>/Map/Redraw",
664        GDK_r, GDK_CONTROL_MASK, FALSE, FALSE
665    appdata->menu_item_map_no_icons =    );
666      item = gtk_check_menu_item_new_with_label( _("No Icons") );  
667    gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item),    appdata->menu_item_map_no_icons = menu_append_new_item(
668                                   appdata->settings->no_icons);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_no_icons), _("No _icons"),
669    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      NULL, "<OSM2Go-Main>/Map/NoIcons",
670    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_map_no_icons),      0, 0, TRUE, appdata->settings->no_icons
671                     appdata);    );
672    
673    appdata->menu_item_map_no_antialias =    appdata->menu_item_map_no_antialias = menu_append_new_item(
674      item = gtk_check_menu_item_new_with_label( _("No Antialias") );      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_no_antialias),
675    gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item),      _("No _antialias"),
676                                   appdata->settings->no_antialias);      NULL, "<OSM2Go-Main>/Map/NoAntialias",
677    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      0, 0, TRUE, appdata->settings->no_antialias
678    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_map_no_antialias),    );
                    appdata);  
679    
680    /* -------------------- track submenu -------------------- */    /* -------------------- track submenu -------------------- */
681    
682    appdata->track.menu_track = item = gtk_menu_item_new_with_label(_("Track"));    appdata->track.menu_track = item = gtk_menu_item_new_with_mnemonic(_("_Track"));
683    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);    gtk_menu_shell_append(GTK_MENU_SHELL(menu), item);
684    submenu = gtk_menu_new();    submenu = gtk_menu_new();
685      gtk_menu_set_accel_group(GTK_MENU(submenu), accel_grp);
686    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu);
687    
688    appdata->track.menu_item_import =    appdata->track.menu_item_import = menu_append_new_item(
689      item = gtk_menu_item_new_with_label( _("Import...") );      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_import), _("_Import..."),
690    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      NULL, "<OSM2Go-Main>/Track/Import",
691    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_track_import),      0, 0, FALSE, FALSE
692                     appdata);    );
693    
694    appdata->track.menu_item_export =    appdata->track.menu_item_export = menu_append_new_item(
695      item = gtk_menu_item_new_with_label( _("Export...") );      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_export), _("_Export..."),
696    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      NULL, "<OSM2Go-Main>/Track/Export",
697    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_track_export),      0, 0, FALSE, FALSE
698                     appdata);    );
699    
700    appdata->track.menu_item_clear =    appdata->track.menu_item_clear = menu_append_new_item(
701      item = gtk_menu_item_new_with_label( _("Clear") );      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_clear), _("_Clear"),
702    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      GTK_STOCK_CLEAR, "<OSM2Go-Main>/Track/Clear",
703    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_track_clear),      0, 0, FALSE, FALSE
704                     appdata);    );
705    
706    appdata->track.menu_item_gps =  
707      item = gtk_check_menu_item_new_with_label( _("GPS") );    appdata->track.menu_item_gps = menu_append_new_item(
708    gtk_menu_shell_append(GTK_MENU_SHELL(submenu), item);      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_gps), _("_GPS"),
709    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_track_gps),      NULL, "<OSM2Go-Main>/Track/GPS",
710                     appdata);      GDK_g, GDK_CONTROL_MASK|GDK_SHIFT_MASK, TRUE, FALSE
711      );
712    
713    /* ------------------------------------------------------- */    /* ------------------------------------------------------- */
714    
715    gtk_menu_shell_append(GTK_MENU_SHELL(about_quit_items_menu),    gtk_menu_shell_append(GTK_MENU_SHELL(about_quit_items_menu),
716                          gtk_separator_menu_item_new());                          gtk_separator_menu_item_new());
717    
718    item = gtk_menu_item_new_with_label( _("About...") );    menu_append_new_item(
719    gtk_menu_shell_append(GTK_MENU_SHELL(about_quit_items_menu), item);      appdata, about_quit_items_menu, GTK_SIGNAL_FUNC(cb_menu_about), _("_About..."),
720    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_about), appdata);      GTK_STOCK_ABOUT, "<OSM2Go-Main>/About",
721        0, 0, FALSE, FALSE
722    item = gtk_menu_item_new_with_label( _("Quit") );    );
723    gtk_menu_shell_append(GTK_MENU_SHELL(about_quit_items_menu), item);  
724    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_quit), appdata);    menu_append_new_item(
725        appdata, about_quit_items_menu, GTK_SIGNAL_FUNC(cb_menu_quit), _("_Quit"),
726        GTK_STOCK_QUIT, "<OSM2Go-Main>/Quit",
727        0, 0, FALSE, FALSE
728      );
729    
730      gtk_window_add_accel_group(GTK_WINDOW(appdata->window), accel_grp);
731    
732  #ifdef USE_HILDON  #ifdef USE_HILDON
733    hildon_window_set_menu(appdata->window, GTK_MENU(menu));    hildon_window_set_menu(appdata->window, GTK_MENU(menu));
734  #else  #else
735    GtkWidget *menu_bar = menu;    GtkWidget *menu_bar = menu;
736    
737  #ifndef MAIN_MENU_IS_MENU_BAR  #ifndef UISPECIFIC_MAIN_MENU_IS_MENU_BAR
738    // we need to make one first    // we need to make one first
739    menu_bar = gtk_menu_bar_new();    menu_bar = gtk_menu_bar_new();
740    
# Line 616  void menu_create(appdata_t *appdata) { Line 745  void menu_create(appdata_t *appdata) {
745    gtk_menu_item_set_submenu(GTK_MENU_ITEM (root_menu), menu);    gtk_menu_item_set_submenu(GTK_MENU_ITEM (root_menu), menu);
746    
747    gtk_widget_show(menu_bar);    gtk_widget_show(menu_bar);
748  #endif //MAIN_MENU_IS_MENU_BAR  #endif //UISPECIFIC_MAIN_MENU_IS_MENU_BAR
749    
750    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);
751    
# Line 625  void menu_create(appdata_t *appdata) { Line 754  void menu_create(appdata_t *appdata) {
754    
755  /********************* end of menu **********************/  /********************* end of menu **********************/
756    
757    #ifdef UISPECIFIC_MENU_HAS_ACCELS
758    #define ACCELS_FILE "accels"
759    
760    static void menu_accels_load(appdata_t *appdata) {
761      char *accels_file = g_strdup_printf("%s/" ACCELS_FILE,
762                                          appdata->settings->base_path);
763      gtk_accel_map_load(accels_file);
764      g_free(accels_file);
765    }
766    
767    static void menu_accels_save(appdata_t *appdata) {
768      char *accels_file = g_strdup_printf("%s" ACCELS_FILE,
769                                          appdata->settings->base_path);
770      gtk_accel_map_save(accels_file);
771      g_free(accels_file);
772    }
773    
774    #endif
775    
776    
777  void cleanup(appdata_t *appdata) {  void cleanup(appdata_t *appdata) {
778    #ifdef UISPECIFIC_MENU_HAS_ACCELS
779      menu_accels_save(appdata);
780    #endif
781    
782    settings_save(appdata->settings);    settings_save(appdata->settings);
783    
784  #ifdef USE_HILDON  #ifdef USE_HILDON
# Line 670  void cleanup(appdata_t *appdata) { Line 822  void cleanup(appdata_t *appdata) {
822    
823    project_free(appdata->project);    project_free(appdata->project);
824    
825    undo_free(appdata->undo_state);    if(appdata->menu_item_osm_undo)
826        undo_free(appdata->undo.state);
827    
828    puts("everything is gone");    puts("everything is gone");
829  }  }
# Line 780  int main(int argc, char *argv[]) { Line 933  int main(int argc, char *argv[]) {
933    
934    appdata.vbox = gtk_vbox_new(FALSE,0);    appdata.vbox = gtk_vbox_new(FALSE,0);
935    menu_create(&appdata);    menu_create(&appdata);
936    #ifdef UISPECIFIC_MENU_HAS_ACCELS
937      menu_accels_load(&appdata);
938    #endif
939    
940    /* ----------------------- setup main window ---------------- */    /* ----------------------- setup main window ---------------- */
941    
# Line 842  int main(int argc, char *argv[]) { Line 998  int main(int argc, char *argv[]) {
998    
999    return 0;    return 0;
1000  }  }
1001    
1002    // vim:et:ts=8:sw=2:sts=2:ai

Legend:
Removed from v.54  
changed lines
  Added in v.76