Diff of /trunk/src/main.c

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

revision 143 by harbaum, Tue Mar 24 13:22:57 2009 UTC revision 156 by harbaum, Wed Apr 1 12:47:35 2009 UTC
# Line 314  cb_menu_zoomout(GtkMenuItem *item, appda Line 314  cb_menu_zoomout(GtkMenuItem *item, appda
314    
315  static void  static void
316  cb_menu_track_import(GtkMenuItem *item, appdata_t *appdata) {  cb_menu_track_import(GtkMenuItem *item, appdata_t *appdata) {
317      g_assert(appdata->settings);
318    
319    /* open a file selector */    /* open a file selector */
320    GtkWidget *dialog;    GtkWidget *dialog;
# Line 330  cb_menu_track_import(GtkMenuItem *item, Line 331  cb_menu_track_import(GtkMenuItem *item,
331                          NULL);                          NULL);
332  #endif  #endif
333    
334    /* use path if one is present */    if(appdata->settings->track_path) {
335    if(appdata->track.import_path)      if(!g_file_test(appdata->settings->track_path, G_FILE_TEST_EXISTS)) {
336      gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog),        char *last_sep = strrchr(appdata->settings->track_path, '/');
337                                          appdata->track.import_path);        if(last_sep) {
338            *last_sep = 0;  // seperate path from file
339    
340            /* the user just created a new document */
341            gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog),
342                                        appdata->settings->track_path);
343            gtk_file_chooser_set_current_name(GTK_FILE_CHOOSER(dialog),
344                                              last_sep+1);
345    
346            /* restore full filename */
347            *last_sep = '/';
348          }
349        } else
350          gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(dialog),
351                                        appdata->settings->track_path);
352      }
353    
354    gtk_widget_show_all (GTK_WIDGET(dialog));    gtk_widget_show_all (GTK_WIDGET(dialog));
355    if (gtk_dialog_run (GTK_DIALOG(dialog)) == GTK_FM_OK) {    if (gtk_dialog_run (GTK_DIALOG(dialog)) == GTK_FM_OK) {
356      char *filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));      char *filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
357    
358      /* load a track */      /* load a track */
359      track_do(appdata, TRACK_IMPORT, filename);      appdata->track.track = track_import(appdata, filename);
360      if(appdata->track.track) {      if(appdata->track.track) {
361          if(appdata->settings->track_path) g_free(appdata->settings->track_path);
362        /* save path if gpx was successfully loaded */        appdata->settings->track_path = g_strdup(filename);
       char *r = strrchr(filename, '/');  
   
       /* there is a delimiter, use everything left of it as path */  
       if(r) {  
         *r = 0;  
         if(appdata->track.import_path) g_free(appdata->track.import_path);  
         appdata->track.import_path = g_strdup(filename);  
         /* restore path ... just in case ... */  
         *r = '/';  
       }  
363      }      }
364      g_free (filename);      g_free (filename);
365    }    }
# Line 362  cb_menu_track_import(GtkMenuItem *item, Line 368  cb_menu_track_import(GtkMenuItem *item,
368  }  }
369    
370  static void  static void
371  cb_menu_track_gps(GtkMenuItem *item, gpointer data) {  cb_menu_track_enable_gps(GtkMenuItem *item, gpointer data) {
372    appdata_t *appdata = (appdata_t*)data;    appdata_t *appdata = (appdata_t*)data;
373    
374    if(gtk_check_menu_item_get_active(    if(gtk_check_menu_item_get_active(
375      GTK_CHECK_MENU_ITEM(appdata->track.menu_item_gps))) {      GTK_CHECK_MENU_ITEM(appdata->track.menu_item_enable_gps))) {
376      track_do(appdata, TRACK_GPS, NULL);      track_enable_gps(appdata, TRUE);
377    } else {    } else
378      track_do(appdata, TRACK_NONE, NULL);      track_enable_gps(appdata, FALSE);
   }  
379  }  }
380    
381    
382  static void  static void
383  cb_menu_track_export(GtkMenuItem *item, gpointer data) {  cb_menu_track_follow_gps(GtkMenuItem *item, gpointer data) {
384    appdata_t *appdata = (appdata_t*)data;    appdata_t *appdata = (appdata_t*)data;
385    messagef(GTK_WIDGET(appdata->window), _("NIY"),  
386             _("Track export is not yet supported."));    if(gtk_check_menu_item_get_active(
387        GTK_CHECK_MENU_ITEM(appdata->track.menu_item_follow_gps))) {
388        appdata->settings->follow_gps = TRUE;
389      } else
390        appdata->settings->follow_gps = FALSE;
391  }  }
392    
393    
394    static void
395    cb_menu_track_export(GtkMenuItem *item, appdata_t *appdata) {
396      g_assert(appdata->settings);
397    
398      /* open a file selector */
399      GtkWidget *dialog;
400    
401    #ifdef USE_HILDON
402      dialog = hildon_file_chooser_dialog_new(GTK_WINDOW(appdata->window),
403                                              GTK_FILE_CHOOSER_ACTION_SAVE);
404    #else
405      dialog = gtk_file_chooser_dialog_new(_("Export track file"),
406                                           GTK_WINDOW(appdata->window),
407                                           GTK_FILE_CHOOSER_ACTION_SAVE,
408                                           GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
409                                           GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT,
410                                           NULL);
411    #endif
412    
413      printf("set filename <%s>\n", appdata->settings->track_path);
414    
415      if(appdata->settings->track_path) {
416        if(!g_file_test(appdata->settings->track_path, G_FILE_TEST_EXISTS)) {
417          char *last_sep = strrchr(appdata->settings->track_path, '/');
418          if(last_sep) {
419            *last_sep = 0;  // seperate path from file
420    
421            /* the user just created a new document */
422            gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog),
423                                                appdata->settings->track_path);
424            gtk_file_chooser_set_current_name(GTK_FILE_CHOOSER(dialog),
425                                              last_sep+1);
426    
427            /* restore full filename */
428            *last_sep = '/';
429          }
430        } else
431          gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(dialog),
432                                        appdata->settings->track_path);
433      }
434    
435      if(gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_FM_OK) {
436        gchar *filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
437        if(filename) {
438          printf("export to %s\n", filename);
439    
440          if(!g_file_test(filename, G_FILE_TEST_EXISTS) ||
441             yes_no_f(dialog, appdata, MISC_AGAIN_ID_EXPORT_OVERWRITE,
442                      MISC_AGAIN_FLAG_DONT_SAVE_NO,
443                      "Overwrite existing file",
444                      "The file already exists. "
445                      "Do you really want to replace it?")) {
446            if(appdata->settings->track_path)
447              g_free(appdata->settings->track_path);
448            appdata->settings->track_path = g_strdup(filename);
449    
450            track_export(appdata, filename);
451          }
452        }
453      }
454    
455      gtk_widget_destroy (dialog);
456    }
457    
458    
459  static void  static void
460  cb_menu_track_clear(GtkMenuItem *item, gpointer data) {  cb_menu_track_clear(GtkMenuItem *item, gpointer data) {
461    appdata_t *appdata = (appdata_t*)data;    appdata_t *appdata = (appdata_t*)data;
462    track_do(appdata, TRACK_NONE, NULL);    track_clear(appdata, appdata->track.track);
463      appdata->track.track = NULL;
464  }  }
465    
466    
# Line 431  menu_append_new_item(appdata_t *appdata, Line 508  menu_append_new_item(appdata_t *appdata,
508                       const gchar *accel_path,                       const gchar *accel_path,
509                       guint accel_key,      // from gdk/gdkkeysyms.h                       guint accel_key,      // from gdk/gdkkeysyms.h
510                       GdkModifierType accel_mods, // e.g. GDK_CONTROL_MASK                       GdkModifierType accel_mods, // e.g. GDK_CONTROL_MASK
511                         gboolean enabled,
512                       gboolean is_check, gboolean check_status)                       gboolean is_check, gboolean check_status)
513  {  {
514    GtkWidget *item = NULL;    GtkWidget *item = NULL;
# Line 486  menu_append_new_item(appdata_t *appdata, Line 564  menu_append_new_item(appdata_t *appdata,
564  #endif  #endif
565    
566    gtk_menu_shell_append(GTK_MENU_SHELL(menu_shell), GTK_WIDGET(item));    gtk_menu_shell_append(GTK_MENU_SHELL(menu_shell), GTK_WIDGET(item));
567    if (is_check) {    gtk_widget_set_sensitive(GTK_WIDGET(item), enabled);
568      if (is_check)
569      gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), check_status);      gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), check_status);
570    }  
571    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(activate_cb),    g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(activate_cb),
572                     appdata);                     appdata);
573    return item;    return item;
# Line 521  void menu_create(appdata_t *appdata) { Line 600  void menu_create(appdata_t *appdata) {
600    menu_append_new_item(    menu_append_new_item(
601      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_project_open), _("_Open..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_project_open), _("_Open..."),
602      GTK_STOCK_OPEN, "<OSM2Go-Main>/Project/Open",      GTK_STOCK_OPEN, "<OSM2Go-Main>/Project/Open",
603      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
604    );    );
605    
606    appdata->menu_item_project_close = menu_append_new_item(    appdata->menu_item_project_close = menu_append_new_item(
607      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_project_close), _("_Close"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_project_close), _("_Close"),
608      GTK_STOCK_CLOSE, "<OSM2Go-Main>/Project/Close",      GTK_STOCK_CLOSE, "<OSM2Go-Main>/Project/Close",
609      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
610    );    );
611    
612    /* --------------- view menu ------------------- */    /* --------------- view menu ------------------- */
# Line 545  void menu_create(appdata_t *appdata) { Line 624  void menu_create(appdata_t *appdata) {
624    appdata->menu_item_view_fullscreen = menu_append_new_item(    appdata->menu_item_view_fullscreen = menu_append_new_item(
625      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_fullscreen), _("_Fullscreen"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_fullscreen), _("_Fullscreen"),
626      GTK_STOCK_FULLSCREEN, "<OSM2Go-Main>/View/Fullscreen",      GTK_STOCK_FULLSCREEN, "<OSM2Go-Main>/View/Fullscreen",
627      0, 0, TRUE, FALSE      0, 0, TRUE, TRUE, FALSE
628    );    );
629    
630    menu_append_new_item(    menu_append_new_item(
631      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_zoomin), _("Zoom _in"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_zoomin), _("Zoom _in"),
632      GTK_STOCK_ZOOM_IN, "<OSM2Go-Main>/View/ZoomIn",      GTK_STOCK_ZOOM_IN, "<OSM2Go-Main>/View/ZoomIn",
633      GDK_comma, GDK_CONTROL_MASK, FALSE, FALSE      GDK_comma, GDK_CONTROL_MASK, TRUE, FALSE, FALSE
634    );    );
635    
636    menu_append_new_item(    menu_append_new_item(
637      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_zoomout), _("Zoom _out"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_zoomout), _("Zoom _out"),
638      GTK_STOCK_ZOOM_OUT, "<OSM2Go-Main>/View/ZoomOut",      GTK_STOCK_ZOOM_OUT, "<OSM2Go-Main>/View/ZoomOut",
639      GDK_period, GDK_CONTROL_MASK, FALSE, FALSE      GDK_period, GDK_CONTROL_MASK, TRUE, FALSE, FALSE
640    );    );
641    
642    /* -------------------- OSM submenu -------------------- */    /* -------------------- OSM submenu -------------------- */
# Line 571  void menu_create(appdata_t *appdata) { Line 650  void menu_create(appdata_t *appdata) {
650    appdata->menu_item_osm_upload = menu_append_new_item(    appdata->menu_item_osm_upload = menu_append_new_item(
651      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_upload), _("_Upload..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_upload), _("_Upload..."),
652      "upload.16", "<OSM2Go-Main>/OSM/Upload",      "upload.16", "<OSM2Go-Main>/OSM/Upload",
653      GDK_u, GDK_SHIFT_MASK|GDK_CONTROL_MASK, FALSE, FALSE      GDK_u, GDK_SHIFT_MASK|GDK_CONTROL_MASK, TRUE, FALSE, FALSE
654    );    );
655    
656    menu_append_new_item(    menu_append_new_item(
657      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_download), _("_Download..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_download), _("_Download..."),
658      "download.16", "<OSM2Go-Main>/OSM/Download",      "download.16", "<OSM2Go-Main>/OSM/Download",
659      GDK_d, GDK_SHIFT_MASK|GDK_CONTROL_MASK, FALSE, FALSE      GDK_d, GDK_SHIFT_MASK|GDK_CONTROL_MASK, TRUE, FALSE, FALSE
660    );    );
661    
662    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());
# Line 586  void menu_create(appdata_t *appdata) { Line 665  void menu_create(appdata_t *appdata) {
665      appdata->menu_item_osm_undo = menu_append_new_item(      appdata->menu_item_osm_undo = menu_append_new_item(
666                 appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_undo), _("_Undo"),                 appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_undo), _("_Undo"),
667                 GTK_STOCK_UNDO, "<OSM2Go-Main>/OSM/Undo",                 GTK_STOCK_UNDO, "<OSM2Go-Main>/OSM/Undo",
668                 GDK_z, GDK_CONTROL_MASK, FALSE, FALSE                 GDK_z, GDK_CONTROL_MASK, TRUE, FALSE, FALSE
669                 );                 );
670    } else    } else
671      printf("set environment variable OSM2GO_UNDO_TEST to enable undo framework tests\n");      printf("set environment variable OSM2GO_UNDO_TEST to enable undo framework tests\n");
# Line 594  void menu_create(appdata_t *appdata) { Line 673  void menu_create(appdata_t *appdata) {
673    appdata->menu_item_osm_save_changes = menu_append_new_item(    appdata->menu_item_osm_save_changes = menu_append_new_item(
674      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_save_changes), _("_Save local changes"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_save_changes), _("_Save local changes"),
675      GTK_STOCK_SAVE, "<OSM2Go-Main>/OSM/SaveChanges",      GTK_STOCK_SAVE, "<OSM2Go-Main>/OSM/SaveChanges",
676      GDK_s, GDK_SHIFT_MASK|GDK_CONTROL_MASK, FALSE, FALSE      GDK_s, GDK_SHIFT_MASK|GDK_CONTROL_MASK, TRUE, FALSE, FALSE
677    );    );
678    
679    appdata->menu_item_osm_undo_changes = menu_append_new_item(    appdata->menu_item_osm_undo_changes = menu_append_new_item(
680      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_undo_changes), _("Disca_rd local changes..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_undo_changes), _("Disca_rd local changes..."),
681      GTK_STOCK_DELETE, "<OSM2Go-Main>/OSM/DiscardChanges",      GTK_STOCK_DELETE, "<OSM2Go-Main>/OSM/DiscardChanges",
682      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
683    );    );
684    
685    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());
686    appdata->menu_item_osm_relations = menu_append_new_item(    appdata->menu_item_osm_relations = menu_append_new_item(
687      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_osm_relations), _("_Relations..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_osm_relations), _("_Relations..."),
688      NULL, "<OSM2Go-Main>/OSM/Relations",      NULL, "<OSM2Go-Main>/OSM/Relations",
689      GDK_r, GDK_SHIFT_MASK|GDK_CONTROL_MASK, FALSE, FALSE      GDK_r, GDK_SHIFT_MASK|GDK_CONTROL_MASK, TRUE, FALSE, FALSE
690    );    );
691    
692    /* -------------------- wms submenu -------------------- */    /* -------------------- wms submenu -------------------- */
# Line 621  void menu_create(appdata_t *appdata) { Line 700  void menu_create(appdata_t *appdata) {
700    menu_append_new_item(    menu_append_new_item(
701      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_import), _("_Import..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_import), _("_Import..."),
702      GTK_STOCK_INDEX, "<OSM2Go-Main>/WMS/Import",      GTK_STOCK_INDEX, "<OSM2Go-Main>/WMS/Import",
703      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
704    );    );
705    
706    appdata->menu_item_wms_clear = menu_append_new_item(    appdata->menu_item_wms_clear = menu_append_new_item(
707      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_clear), _("_Clear"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_clear), _("_Clear"),
708      GTK_STOCK_CLEAR, "<OSM2Go-Main>/WMS/Clear",      GTK_STOCK_CLEAR, "<OSM2Go-Main>/WMS/Clear",
709      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
710    );    );
711    gtk_widget_set_sensitive(appdata->menu_item_wms_clear, FALSE);    gtk_widget_set_sensitive(appdata->menu_item_wms_clear, FALSE);
712    
713    appdata->menu_item_wms_adjust = menu_append_new_item(    appdata->menu_item_wms_adjust = menu_append_new_item(
714      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_adjust), _("_Adjust"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_wms_adjust), _("_Adjust"),
715      NULL, "<OSM2Go-Main>/WMS/Adjust",      NULL, "<OSM2Go-Main>/WMS/Adjust",
716      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
717    );    );
718    gtk_widget_set_sensitive(appdata->menu_item_wms_adjust, FALSE);    gtk_widget_set_sensitive(appdata->menu_item_wms_adjust, FALSE);
719    
# Line 649  void menu_create(appdata_t *appdata) { Line 728  void menu_create(appdata_t *appdata) {
728    appdata->menu_item_map_hide_sel = menu_append_new_item(    appdata->menu_item_map_hide_sel = menu_append_new_item(
729      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_hide_sel), _("_Hide selected"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_hide_sel), _("_Hide selected"),
730      GTK_STOCK_REMOVE, "<OSM2Go-Main>/Map/HideSelected",      GTK_STOCK_REMOVE, "<OSM2Go-Main>/Map/HideSelected",
731      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
732    );    );
733    gtk_widget_set_sensitive(appdata->menu_item_map_hide_sel, FALSE);    gtk_widget_set_sensitive(appdata->menu_item_map_hide_sel, FALSE);
734    
735    appdata->menu_item_map_show_all = menu_append_new_item(    appdata->menu_item_map_show_all = menu_append_new_item(
736      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_show_all), _("_Show all"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_show_all), _("_Show all"),
737      GTK_STOCK_ADD, "<OSM2Go-Main>/Map/ShowAll",      GTK_STOCK_ADD, "<OSM2Go-Main>/Map/ShowAll",
738      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
739    );    );
740    gtk_widget_set_sensitive(appdata->menu_item_map_show_all, FALSE);    gtk_widget_set_sensitive(appdata->menu_item_map_show_all, FALSE);
741    
# Line 665  void menu_create(appdata_t *appdata) { Line 744  void menu_create(appdata_t *appdata) {
744    menu_append_new_item(    menu_append_new_item(
745      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_style), _("St_yle..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_style), _("St_yle..."),
746      GTK_STOCK_SELECT_COLOR, "<OSM2Go-Main>/Map/Style",      GTK_STOCK_SELECT_COLOR, "<OSM2Go-Main>/Map/Style",
747      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
748    );    );
749    
750    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());
# Line 674  void menu_create(appdata_t *appdata) { Line 753  void menu_create(appdata_t *appdata) {
753    menu_append_new_item(    menu_append_new_item(
754      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_redraw), _("_Redraw"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_redraw), _("_Redraw"),
755      NULL, "<OSM2Go-Main>/Map/Redraw",      NULL, "<OSM2Go-Main>/Map/Redraw",
756      GDK_r, GDK_CONTROL_MASK, FALSE, FALSE      GDK_r, GDK_CONTROL_MASK, TRUE, FALSE, FALSE
757    );    );
758    
759    appdata->menu_item_map_no_icons = menu_append_new_item(    appdata->menu_item_map_no_icons = menu_append_new_item(
760      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_no_icons), _("No _icons"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_no_icons), _("No _icons"),
761      NULL, "<OSM2Go-Main>/Map/NoIcons",      NULL, "<OSM2Go-Main>/Map/NoIcons",
762      0, 0, TRUE, appdata->settings->no_icons      0, 0, TRUE, TRUE, appdata->settings->no_icons
763    );    );
764    
765    appdata->menu_item_map_no_antialias = menu_append_new_item(    appdata->menu_item_map_no_antialias = menu_append_new_item(
766      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_no_antialias),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_map_no_antialias),
767      _("No _antialias"),      _("No _antialias"),
768      NULL, "<OSM2Go-Main>/Map/NoAntialias",      NULL, "<OSM2Go-Main>/Map/NoAntialias",
769      0, 0, TRUE, appdata->settings->no_antialias      0, 0, TRUE, TRUE, appdata->settings->no_antialias
770    );    );
771    
772    /* -------------------- track submenu -------------------- */    /* -------------------- track submenu -------------------- */
# Line 701  void menu_create(appdata_t *appdata) { Line 780  void menu_create(appdata_t *appdata) {
780    appdata->track.menu_item_import = menu_append_new_item(    appdata->track.menu_item_import = menu_append_new_item(
781      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_import), _("_Import..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_import), _("_Import..."),
782      NULL, "<OSM2Go-Main>/Track/Import",      NULL, "<OSM2Go-Main>/Track/Import",
783      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
784    );    );
785    
786    appdata->track.menu_item_export = menu_append_new_item(    appdata->track.menu_item_export = menu_append_new_item(
787      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_export), _("_Export..."),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_export), _("_Export..."),
788      NULL, "<OSM2Go-Main>/Track/Export",      NULL, "<OSM2Go-Main>/Track/Export",
789      0, 0, FALSE, FALSE      0, 0, FALSE, FALSE, FALSE
790    );    );
791    
792    appdata->track.menu_item_clear = menu_append_new_item(    appdata->track.menu_item_clear = menu_append_new_item(
793      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_clear), _("_Clear"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_clear), _("_Clear"),
794      GTK_STOCK_CLEAR, "<OSM2Go-Main>/Track/Clear",      GTK_STOCK_CLEAR, "<OSM2Go-Main>/Track/Clear",
795      0, 0, FALSE, FALSE      0, 0, FALSE, FALSE, FALSE
796    );    );
797    
798    
799    appdata->track.menu_item_gps = menu_append_new_item(    appdata->track.menu_item_enable_gps = menu_append_new_item(
800      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_gps), _("_GPS"),      appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_enable_gps),_("_GPS enable"),
801      NULL, "<OSM2Go-Main>/Track/GPS",      NULL, "<OSM2Go-Main>/Track/GPS",
802      GDK_g, GDK_CONTROL_MASK|GDK_SHIFT_MASK, TRUE, FALSE      GDK_g, GDK_CONTROL_MASK|GDK_SHIFT_MASK, TRUE, TRUE,
803        appdata->settings->enable_gps
804      );
805    
806      appdata->track.menu_item_follow_gps = menu_append_new_item(
807        appdata, submenu, GTK_SIGNAL_FUNC(cb_menu_track_follow_gps), _("GPS follow"),
808        NULL, "<OSM2Go-Main>/Track/Follow",
809        0, 0, appdata->settings->enable_gps, TRUE,
810        appdata->settings->follow_gps
811    );    );
812    
813    /* ------------------------------------------------------- */    /* ------------------------------------------------------- */
# Line 731  void menu_create(appdata_t *appdata) { Line 818  void menu_create(appdata_t *appdata) {
818    menu_append_new_item(    menu_append_new_item(
819      appdata, about_quit_items_menu, GTK_SIGNAL_FUNC(cb_menu_about), _("_About..."),      appdata, about_quit_items_menu, GTK_SIGNAL_FUNC(cb_menu_about), _("_About..."),
820      GTK_STOCK_ABOUT, "<OSM2Go-Main>/About",      GTK_STOCK_ABOUT, "<OSM2Go-Main>/About",
821      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
822    );    );
823    
824    menu_append_new_item(    menu_append_new_item(
825      appdata, about_quit_items_menu, GTK_SIGNAL_FUNC(cb_menu_quit), _("_Quit"),      appdata, about_quit_items_menu, GTK_SIGNAL_FUNC(cb_menu_quit), _("_Quit"),
826      GTK_STOCK_QUIT, "<OSM2Go-Main>/Quit",      GTK_STOCK_QUIT, "<OSM2Go-Main>/Quit",
827      0, 0, FALSE, FALSE      0, 0, TRUE, FALSE, FALSE
828    );    );
829    
830    gtk_window_add_accel_group(GTK_WINDOW(appdata->window), accel_grp);    gtk_window_add_accel_group(GTK_WINDOW(appdata->window), accel_grp);
# Line 996  int main(int argc, char *argv[]) { Line 1083  int main(int argc, char *argv[]) {
1083    
1084    main_ui_enable(&appdata);    main_ui_enable(&appdata);
1085    
1086      /* start GPS if enabled by config */
1087      if(appdata.settings && appdata.settings->enable_gps)
1088        track_enable_gps(&appdata, TRUE);
1089    
1090    /* ------------ jump into main loop ---------------- */    /* ------------ jump into main loop ---------------- */
1091    
1092    gtk_main();    gtk_main();
# Line 1004  int main(int argc, char *argv[]) { Line 1095  int main(int argc, char *argv[]) {
1095    
1096    track_save(appdata.project, appdata.track.track);    track_save(appdata.project, appdata.track.track);
1097    track_clear(&appdata, appdata.track.track);    track_clear(&appdata, appdata.track.track);
1098      appdata.track.track = NULL;
1099    
1100    /* save a diff if there are dirty entries */    /* save a diff if there are dirty entries */
1101    diff_save(appdata.project, appdata.osm);    diff_save(appdata.project, appdata.osm);

Legend:
Removed from v.143  
changed lines
  Added in v.156