X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=main.c;h=9aaa5d1f42ca61b384fb37740a7ebbbefe9472dc;hb=e7491d3bf50ad31bbee38abc9da823c9cbdb9cd1;hp=26d2eee220bcbdcc8b4d4096aeadee336a025178;hpb=dbdd42b31f73ad8e8117d5b2a5b4ac4e061bf202;p=ext%2Fsubsurface.git diff --git a/main.c b/main.c index 26d2eee..9aaa5d1 100644 --- a/main.c +++ b/main.c @@ -4,16 +4,11 @@ #include #include -#include - #include "dive.h" #include "divelist.h" -GConfClient *gconf; struct units output_units; -#define GCONF_NAME(x) "/apps/subsurface/" #x - /* random helper functions, used here or elsewhere */ static int sortfn(const void *_a, const void *_b) { @@ -97,6 +92,11 @@ static void try_to_renumber(struct dive *last, int preexisting) } } +/* + * track whether we switched to importing dives + */ +static gboolean imported = FALSE; + /* * This doesn't really report anything at all. We just sort the * dives, the GUI does the reporting @@ -162,10 +162,17 @@ static void parse_argument(const char *arg) if (strcmp(arg,"--import") == 0) { /* mark the dives so far as the base, * everything after is imported */ - report_dives(TRUE); + report_dives(FALSE); + imported = TRUE; return; } /* fallthrough */ + case 'p': + /* ignore process serial number argument when run as native macosx app */ + if (strncmp(arg, "-psn_", 5) == 0) { + return; + } + /* fallthrough */ default: fprintf(stderr, "Bad argument '%s'\n", arg); exit(1); @@ -186,6 +193,7 @@ void update_dive(struct dive *new_dive) if (new_dive) { show_dive_info(new_dive); show_dive_equipment(new_dive); + show_dive_stats(new_dive); } buffered_dive = new_dive; } @@ -197,6 +205,7 @@ void renumber_dives(int nr) for (i = 0; i < dive_table.nr; i++) { struct dive *dive = dive_table.dives[i]; dive->number = nr + i; + flush_divelist(dive); } mark_divelist_changed(TRUE); } @@ -209,7 +218,7 @@ int main(int argc, char **argv) parse_xml_init(); - init_ui(argc, argv); + init_ui(&argc, &argv); for (i = 1; i < argc; i++) { const char *a = argv[i]; @@ -229,7 +238,7 @@ int main(int argc, char **argv) } } - report_dives(FALSE); + report_dives(imported); run_ui(); return 0;