diff options
-rw-r--r-- | save-html.c | 126 |
1 files changed, 99 insertions, 27 deletions
diff --git a/save-html.c b/save-html.c index a9b48fcc7..e2222b3f6 100644 --- a/save-html.c +++ b/save-html.c @@ -76,8 +76,12 @@ void put_HTML_airtemp(struct membuffer *b, struct dive *dive, const char *pre, c const char *unit; double value; + if (!dive->airtemp.mkelvin) { + put_format(b, "%s--%s", pre, post); + return; + } value = get_temp_units(dive->airtemp.mkelvin, &unit); - put_format(b, "%s%.1f %s%s",pre, value, unit, post); + put_format(b, "%s%.1f %s%s", pre, value, unit, post); } void put_HTML_watertemp(struct membuffer *b, struct dive *dive, const char *pre, const char *post) @@ -85,8 +89,12 @@ void put_HTML_watertemp(struct membuffer *b, struct dive *dive, const char *pre, const char *unit; double value; + if (!dive->watertemp.mkelvin) { + put_format(b, "%s--%s", pre, post); + return; + } value = get_temp_units(dive->watertemp.mkelvin, &unit); - put_format(b, "%s%.1f %s%s",pre, value, unit, post); + put_format(b, "%s%.1f %s%s", pre, value, unit, post); } void put_HTML_tags(struct membuffer *b, struct dive *dive, const char *pre, const char *post) @@ -100,40 +108,104 @@ void put_HTML_tags(struct membuffer *b, struct dive *dive, const char *pre, cons put_string(b, post); } -void write_dives(struct membuffer *b,bool selected_only) +void write_one_dive(struct membuffer *b, struct dive *dive, int *dive_no) { - int i, dive_no = 0; + put_string(b, "{"); + put_format(b, "\"number\":%d,", *dive_no); + put_format(b, "\"subsurface_number\":%d,", dive->number); + put_HTML_date(b, dive, "\"date\":\"", "\","); + put_HTML_time(b, dive, "\"time\":\"", "\","); + put_format(b, "\"location\":\"%s\",", dive->location); + put_format(b, "\"rating\":%d,", dive->rating); + put_format(b, "\"visibility\":%d,", dive->visibility); + put_string(b, "\"temperature\":{"); + put_HTML_airtemp(b, dive, "\"air\":\"", "\","); + put_HTML_watertemp(b, dive, "\"water\":\"", "\","); + put_string(b, " },"); + put_format(b, "\"buddy\":\"%s\",", dive->buddy); + put_format(b, "\"divemaster\":\"%s\",", dive->divemaster); + put_format(b, "\"suit\":\"%s\",", dive->suit); + put_HTML_tags(b, dive, "\"tags\":\"", "\","); + put_HTML_notes(b, dive ,"\"notes\":\"" ,"\","); + put_string(b, "},\n"); + (*dive_no)++; +} + +void write_no_trip (struct membuffer *b, int *dive_no) +{ + int i; struct dive *dive; + put_format(b, "{"); + put_format(b, "\"name\":\"Other\","); + put_format(b, "\"dives\":["); + for_each_dive(i, dive) { - if (selected_only) { + if (!dive->divetrip) + write_one_dive(b, dive, dive_no); + } + put_format(b, "]},\n\n"); +} + +void write_trip (struct membuffer *b, dive_trip_t *trip, int *dive_no) +{ + int i; + struct dive *dive; + + put_format(b, "{"); + put_format(b, "\"name\":\"%s\",",trip->location); + put_format(b, "\"dives\":["); + + for (dive = trip->dives; dive != NULL; dive = dive->next){ + write_one_dive(b, dive, dive_no); + } + + put_format(b, "]},\n\n"); +} + +void write_trips(struct membuffer *b,bool selected_only) +{ + int i, dive_no = 0; + struct dive *dive; + dive_trip_t *trip; + + for (trip = dive_trip_list; trip != NULL; trip = trip->next) + trip->index = 0; + + if (selected_only) { + put_format(b, "{"); + put_format(b, "\"name\":\"Other\","); + put_format(b, "\"dives\":["); + + for_each_dive(i, dive) { if (!dive->selected) continue; + write_one_dive(b, dive, &dive_no); } - put_string(b, "{"); - put_format(b, "\"number\":%d,", dive_no); - put_HTML_date(b, dive, "\"date\":\"", "\","); - put_HTML_time(b, dive, "\"time\":\"", "\","); - put_format(b, "\"location\":\"%s\",", dive->location); - put_format(b, "\"rating\":%d,", dive->rating); - put_format(b, "\"visibility\":%d,", dive->visibility); - put_string(b, "\"temperature\":{"); - put_HTML_airtemp(b, dive, "\"air\":\"", "\","); - put_HTML_watertemp(b, dive, "\"water\":\"", "\","); - put_string(b, " },"); - put_format(b, "\"buddy\":\"%s\",", dive->buddy); - put_format(b, "\"divemaster\":\"%s\",", dive->divemaster); - put_format(b, "\"suit\":\"%s\",", dive->suit); - put_HTML_tags(b, dive, "\"tags\":\"", "\","); - put_HTML_notes(b, dive ,"\"notes\":\"" ,"\","); - put_string(b, "},\n"); - dive_no++; + put_format(b, "]},\n\n"); + } else { + + for_each_dive(i, dive) { + + trip = dive->divetrip; + + /*Continue if the dive have no trips or we have seen this trip before*/ + if (!trip || trip->index) + continue; + + /* We haven't seen this trip before - save it and all dives */ + trip->index = 1; + write_trip(b, trip, &dive_no); + } + + /*Save all remaining trips into Others*/ + write_no_trip(b, &dive_no); } } -void export_dives(struct membuffer *b,bool selected_only){ - put_string(b, "items=["); - write_dives(b, selected_only); +void export_list(struct membuffer *b,bool selected_only){ + put_string(b, "trips=["); + write_trips(b, selected_only); put_string(b, "]"); } @@ -142,7 +214,7 @@ void export_HTML(const char *file_name, const bool selected_only) FILE *f; struct membuffer buf = { 0 }; - export_dives(&buf, selected_only); + export_list(&buf, selected_only); f = fopen(file_name, "w+"); if (!f) |