mirror of
https://github.com/subsurface/subsurface.git
synced 2024-11-30 22:20:21 +00:00
Fix picture loading
Signed vs unsigned comparisons are such a pain. Since we want offsets to be +/- 30 minutes around the dive we need to allow negative offsets - but duration_t was defined as uint32_t. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
c054b18b70
commit
f297d9f91e
5 changed files with 33 additions and 6 deletions
2
dive.c
2
dive.c
|
@ -2389,7 +2389,7 @@ void dive_create_picture(struct dive *d, char *filename, int shift_time)
|
||||||
picture_load_exif_data(p, ×tamp);
|
picture_load_exif_data(p, ×tamp);
|
||||||
if (timestamp) {
|
if (timestamp) {
|
||||||
p->offset.seconds = timestamp - d->when + shift_time;
|
p->offset.seconds = timestamp - d->when + shift_time;
|
||||||
if (p->offset.seconds < -D30MIN || p->offset.seconds > d->duration.seconds + D30MIN) {
|
if (p->offset.seconds < -D30MIN || p->offset.seconds > (int)d->duration.seconds + D30MIN) {
|
||||||
// this picture doesn't belong to this dive
|
// this picture doesn't belong to this dive
|
||||||
free(p);
|
free(p);
|
||||||
return;
|
return;
|
||||||
|
|
2
dive.h
2
dive.h
|
@ -292,7 +292,7 @@ struct dive {
|
||||||
/* picture list and methods related to dive picture handling */
|
/* picture list and methods related to dive picture handling */
|
||||||
struct picture {
|
struct picture {
|
||||||
char *filename;
|
char *filename;
|
||||||
duration_t offset;
|
offset_t offset;
|
||||||
degrees_t latitude;
|
degrees_t latitude;
|
||||||
degrees_t longitude;
|
degrees_t longitude;
|
||||||
struct picture *next;
|
struct picture *next;
|
||||||
|
|
19
parse-xml.c
19
parse-xml.c
|
@ -412,6 +412,20 @@ static void sampletime(char *buffer, duration_t *time)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void offsettime(char *buffer, offset_t *time)
|
||||||
|
{
|
||||||
|
duration_t uoffset;
|
||||||
|
int sign = 1;
|
||||||
|
if (*buffer == '-') {
|
||||||
|
sign = -1;
|
||||||
|
buffer++;
|
||||||
|
}
|
||||||
|
/* yes, this could indeed fail if we have an offset > 34yrs
|
||||||
|
* - too bad */
|
||||||
|
sampletime(buffer, &uoffset);
|
||||||
|
time->seconds = sign * uoffset.seconds;
|
||||||
|
}
|
||||||
|
|
||||||
static void duration(char *buffer, duration_t *time)
|
static void duration(char *buffer, duration_t *time)
|
||||||
{
|
{
|
||||||
/* DivingLog 5.08 (and maybe other versions) appear to sometimes
|
/* DivingLog 5.08 (and maybe other versions) appear to sometimes
|
||||||
|
@ -1106,7 +1120,7 @@ static void try_to_fill_dive(struct dive *dive, const char *name, char *buf)
|
||||||
|
|
||||||
if (MATCH("filename.picture", utf8_string, &cur_picture->filename))
|
if (MATCH("filename.picture", utf8_string, &cur_picture->filename))
|
||||||
return;
|
return;
|
||||||
if (MATCH("offset.picture", sampletime, &cur_picture->offset))
|
if (MATCH("offset.picture", offsettime, &cur_picture->offset))
|
||||||
return;
|
return;
|
||||||
if (MATCH("gps.picture", gps_picture_location, cur_picture))
|
if (MATCH("gps.picture", gps_picture_location, cur_picture))
|
||||||
return;
|
return;
|
||||||
|
@ -1317,7 +1331,8 @@ static void event_end(void)
|
||||||
if (cur_event.type == 123) {
|
if (cur_event.type == 123) {
|
||||||
struct picture *pic = alloc_picture();
|
struct picture *pic = alloc_picture();
|
||||||
pic->filename = strdup(cur_event.name);
|
pic->filename = strdup(cur_event.name);
|
||||||
pic->offset = cur_event.time;
|
/* theoretically this could fail - but we didn't support multi year offsets */
|
||||||
|
pic->offset.seconds = cur_event.time.seconds;
|
||||||
dive_add_picture(cur_dive, pic);
|
dive_add_picture(cur_dive, pic);
|
||||||
} else {
|
} else {
|
||||||
add_event(dc, cur_event.time.seconds,
|
add_event(dc, cur_event.time.seconds,
|
||||||
|
|
11
save-xml.c
11
save-xml.c
|
@ -333,8 +333,15 @@ static void save_picture(struct membuffer *b, struct picture *pic)
|
||||||
put_string(b, " <picture filename='");
|
put_string(b, " <picture filename='");
|
||||||
put_string(b, pic->filename);
|
put_string(b, pic->filename);
|
||||||
put_string(b, "'");
|
put_string(b, "'");
|
||||||
if (pic->offset.seconds)
|
if (pic->offset.seconds) {
|
||||||
put_format(b, " offset='%u:%02u min'", FRACTION(pic->offset.seconds, 60));
|
int offset = pic->offset.seconds;
|
||||||
|
char sign = '+';
|
||||||
|
if (offset < 0) {
|
||||||
|
sign = '-';
|
||||||
|
offset = -offset;
|
||||||
|
}
|
||||||
|
put_format(b, " offset='%c%u:%02u min'", sign, FRACTION(offset, 60));
|
||||||
|
}
|
||||||
if (pic->latitude.udeg || pic->longitude.udeg) {
|
if (pic->latitude.udeg || pic->longitude.udeg) {
|
||||||
put_degrees(b, pic->latitude, " gps='", " ");
|
put_degrees(b, pic->latitude, " gps='", " ");
|
||||||
put_degrees(b, pic->longitude, "", "'");
|
put_degrees(b, pic->longitude, "", "'");
|
||||||
|
|
5
units.h
5
units.h
|
@ -69,6 +69,11 @@ typedef struct
|
||||||
uint32_t seconds; // durations up to 68 yrs
|
uint32_t seconds; // durations up to 68 yrs
|
||||||
} duration_t;
|
} duration_t;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
int32_t seconds; // offsets up to +/- 34 yrs
|
||||||
|
} offset_t;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
int32_t mm;
|
int32_t mm;
|
||||||
|
|
Loading…
Reference in a new issue