diff options
author | Gehad elrobey <gehadelrobey@gmail.com> | 2014-07-13 23:36:35 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2014-07-14 21:38:22 -0700 |
commit | 6f05194b02fd8944f65f8706f8a1ca5b444a03cd (patch) | |
tree | 09d76d3510fb9795126b67c926084d47768aa790 /save-html.c | |
parent | 346f71f2624e4035b664bc93d03a835412c29ec0 (diff) | |
download | subsurface-6f05194b02fd8944f65f8706f8a1ca5b444a03cd.tar.gz |
HTML: Add dive photos to the detailed view
Dive photos are copied to the photos directory on export. The photos
section appears only if photos exist.
C++ helper functions are added to copy images to the photos directory,
Additionally the photos directory must be passed as a parameter to the
write_one_dive function to save photos to it. Some options structure may
be needed instead of passing many arguments.
Signed-off-by: Gehad elrobey <gehadelrobey@gmail.com>
Signed-off-by: Miika Turkia <miika.turkia@gmail.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'save-html.c')
-rw-r--r-- | save-html.c | 39 |
1 files changed, 26 insertions, 13 deletions
diff --git a/save-html.c b/save-html.c index 2d03bca76..324d543fb 100644 --- a/save-html.c +++ b/save-html.c @@ -11,6 +11,18 @@ void write_attribute(struct membuffer *b, const char *att_name, const char *valu put_string(b, "\","); } +void save_photos(struct membuffer *b, const char *photos_dir, struct dive *dive) +{ + struct picture *pic = dive->picture_list; + put_string(b, "\"photos\":["); + while (pic) { + put_format(b, "{\"filename\":\"%s\"},", get_file_name(pic->filename)); + copy_image_and_overwrite(pic->filename, photos_dir); + pic = pic->next; + } + put_string(b, "],"); +} + void write_dive_status(struct membuffer *b, struct dive *dive) { put_format(b, "\"sac\":\"%d\",", dive->sac); @@ -162,7 +174,7 @@ void put_HTML_tags(struct membuffer *b, struct dive *dive, const char *pre, cons } /* if exporting list_only mode, we neglect exporting the samples, bookmarks and cylinders */ -void write_one_dive(struct membuffer *b, struct dive *dive, int *dive_no, const bool list_only) +void write_one_dive(struct membuffer *b, struct dive *dive, const char *photos_dir, int *dive_no, const bool list_only) { put_string(b, "{"); put_format(b, "\"number\":%d,", *dive_no); @@ -180,6 +192,7 @@ void write_one_dive(struct membuffer *b, struct dive *dive, int *dive_no, const write_attribute(b, "divemaster", dive->divemaster); write_attribute(b, "suit", dive->suit); write_dive_status(b, dive); + save_photos(b, photos_dir, dive); put_HTML_tags(b, dive, "\"tags\":", ","); put_HTML_notes(b, dive, "\"notes\":\"", "\","); if (!list_only) { @@ -191,7 +204,7 @@ void write_one_dive(struct membuffer *b, struct dive *dive, int *dive_no, const (*dive_no)++; } -void write_no_trip(struct membuffer *b, int *dive_no, const bool list_only) +void write_no_trip(struct membuffer *b, int *dive_no, const char *photos_dir, const bool list_only) { int i; struct dive *dive; @@ -202,12 +215,12 @@ void write_no_trip(struct membuffer *b, int *dive_no, const bool list_only) for_each_dive (i, dive) { if (!dive->divetrip) - write_one_dive(b, dive, dive_no, list_only); + write_one_dive(b, dive, photos_dir, dive_no, list_only); } put_format(b, "]},\n\n"); } -void write_trip(struct membuffer *b, dive_trip_t *trip, int *dive_no, const bool list_only) +void write_trip(struct membuffer *b, dive_trip_t *trip, int *dive_no, const char *photos_dir, const bool list_only) { struct dive *dive; @@ -216,13 +229,13 @@ void write_trip(struct membuffer *b, dive_trip_t *trip, int *dive_no, const bool put_format(b, "\"dives\":["); for (dive = trip->dives; dive != NULL; dive = dive->next) { - write_one_dive(b, dive, dive_no, list_only); + write_one_dive(b, dive, photos_dir, dive_no, list_only); } put_format(b, "]},\n\n"); } -void write_trips(struct membuffer *b, bool selected_only, const bool list_only) +void write_trips(struct membuffer *b, const char *photos_dir, bool selected_only, const bool list_only) { int i, dive_no = 0; struct dive *dive; @@ -239,7 +252,7 @@ void write_trips(struct membuffer *b, bool selected_only, const bool list_only) for_each_dive (i, dive) { if (!dive->selected) continue; - write_one_dive(b, dive, &dive_no, list_only); + write_one_dive(b, dive, photos_dir, &dive_no, list_only); } put_format(b, "]},\n\n"); } else { @@ -253,27 +266,27 @@ void write_trips(struct membuffer *b, bool selected_only, const bool list_only) /* We haven't seen this trip before - save it and all dives */ trip->index = 1; - write_trip(b, trip, &dive_no, list_only); + write_trip(b, trip, &dive_no, photos_dir, list_only); } /*Save all remaining trips into Others*/ - write_no_trip(b, &dive_no, list_only); + write_no_trip(b, &dive_no, photos_dir, list_only); } } -void export_list(struct membuffer *b, bool selected_only, const bool list_only) +void export_list(struct membuffer *b, const char *photos_dir, bool selected_only, const bool list_only) { put_string(b, "trips=["); - write_trips(b, selected_only, list_only); + write_trips(b, photos_dir, selected_only, list_only); put_string(b, "]"); } -void export_HTML(const char *file_name, const bool selected_only, const bool list_only) +void export_HTML(const char *file_name, const char *photos_dir, const bool selected_only, const bool list_only) { FILE *f; struct membuffer buf = { 0 }; - export_list(&buf, selected_only, list_only); + export_list(&buf, photos_dir, selected_only, list_only); f = subsurface_fopen(file_name, "w+"); if (!f) |