summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2020-10-25 14:13:54 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-10-26 19:27:03 -0700
commit0d733747d1854614b750f1fe7afc26c75f5ecfe8 (patch)
tree2fff80ae0afb028c65e87029046143b63f2a8ec5
parent77195ccb88aab66a5d138ca1e09324e482f897ac (diff)
downloadsubsurface-0d733747d1854614b750f1fe7afc26c75f5ecfe8.tar.gz
cleanup: fix resource leak
Fixes CID 362078 Fixes CID 362081 Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--core/datatrak.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/core/datatrak.c b/core/datatrak.c
index 01a16210a..e1a62f582 100644
--- a/core/datatrak.c
+++ b/core/datatrak.c
@@ -602,9 +602,11 @@ static int wlog_header_parser (struct memblock *mem)
}
}
+#define NOTES_LENGTH 256
+#define SUIT_LENGTH 26
static void wlog_compl_parser(struct memblock *wl_mem, struct dive *dt_dive, int dcount)
{
- int strlong = 256, tmp = 0, offset = 12 + (dcount * 850),
+ int tmp = 0, offset = 12 + (dcount * 850),
pos_weight = offset + 256,
pos_viz = offset + 258,
pos_tank_init = offset + 266,
@@ -616,9 +618,10 @@ static void wlog_compl_parser(struct memblock *wl_mem, struct dive *dt_dive, int
* Extended notes string. Fixed length 256 bytes. 0 padded if not complete
*/
if (*(runner + offset)) {
- wlog_notes = calloc(strlong + 1, 1);
- wlog_notes = memcpy(wlog_notes, runner + offset, 256);
- wlog_notes = to_utf8((unsigned char *) wlog_notes);
+ char wlog_notes_temp[NOTES_LENGTH + 1];
+ wlog_notes_temp[NOTES_LENGTH] = 0;
+ (void)memcpy(wlog_notes_temp, runner + offset, NOTES_LENGTH);
+ wlog_notes = to_utf8((unsigned char *) wlog_notes_temp);
}
if (dt_dive->notes && wlog_notes) {
buffer = calloc (strlen(dt_dive->notes) + strlen(wlog_notes) + 1, 1);
@@ -664,11 +667,11 @@ static void wlog_compl_parser(struct memblock *wl_mem, struct dive *dt_dive, int
* Dive suit, fixed length of 26 bytes, zero padded if shorter.
* Expected to be preferred by the user if he did the work of setting it.
*/
- strlong = 26;
if (*(runner + pos_suit)) {
- wlog_suit = calloc(strlong, 1);
- wlog_suit = memcpy(wlog_suit, runner + pos_suit, strlong);
- wlog_suit = to_utf8((unsigned char *) wlog_suit);
+ char wlog_suit_temp[SUIT_LENGTH + 1];
+ wlog_suit_temp[SUIT_LENGTH] = 0;
+ (void)memcpy(wlog_suit_temp, runner + pos_suit, SUIT_LENGTH);
+ wlog_suit = to_utf8((unsigned char *) wlog_suit_temp);
}
if (wlog_suit)
dt_dive->suit = copy_string(wlog_suit);