79767e
From 0bd3f2aa9bd75263901e1f57a6cd9c4015084408 Mon Sep 17 00:00:00 2001
79767e
From: Kamil Dudka <kdudka@redhat.com>
79767e
Date: Tue, 6 Nov 2018 12:32:04 +0100
79767e
Subject: [PATCH] lynx: fix bugs detected by static analysis
79767e
79767e
---
79767e
 WWW/Library/Implementation/HTGopher.c |  1 +
79767e
 samples/lynxdump                      |  1 +
79767e
 src/LYBookmark.c                      |  2 ++
79767e
 src/LYDownload.c                      |  1 +
79767e
 src/LYLeaks.c                         | 24 ++++--------------------
79767e
 5 files changed, 9 insertions(+), 20 deletions(-)
79767e
79767e
diff --git a/WWW/Library/Implementation/HTGopher.c b/WWW/Library/Implementation/HTGopher.c
79767e
index a9ad41e..36ff592 100644
79767e
--- a/WWW/Library/Implementation/HTGopher.c
79767e
+++ b/WWW/Library/Implementation/HTGopher.c
79767e
@@ -1651,6 +1651,7 @@ static int HTLoadCSO(const char *arg,
79767e
 	(*Target->isa->put_block) (Target, buf, (int) strlen(buf));
79767e
 	(*Target->isa->_free) (Target);
79767e
 	free_CSOfields();
79767e
+	BStrFree(command);
79767e
 	return HT_LOADED;
79767e
     }
79767e
     /*
79767e
diff --git a/samples/lynxdump b/samples/lynxdump
79767e
index f79be2f..a0e9ae2 100755
79767e
--- a/samples/lynxdump
79767e
+++ b/samples/lynxdump
79767e
@@ -12,4 +12,5 @@ if test $HOME/.lynxrc ; then
79767e
 fi
79767e
 echo 'keypad_mode=NUMBERS_AS_ARROWS' >> $MYTMP/.lynxrc
79767e
 HOME=$MYTMP; export HOME
79767e
+umask $oldmask
79767e
 lynx -justify -dump -force_html -with_backspaces -nolist $*
79767e
diff --git a/src/LYBookmark.c b/src/LYBookmark.c
79767e
index c3116ef..6464d96 100644
79767e
--- a/src/LYBookmark.c
79767e
+++ b/src/LYBookmark.c
79767e
@@ -303,6 +303,7 @@ void save_bookmark_link(const char *address,
79767e
 	    LYMBM_statusline(CANCELLED);
79767e
 	    LYSleepMsg();
79767e
 	    FREE(bookmark_URL);
79767e
+	    BStrFree(tmp_data);
79767e
 	    return;
79767e
 	}
79767e
     } while (!havevisible(string_data->str));
79767e
@@ -347,6 +348,7 @@ void save_bookmark_link(const char *address,
79767e
 	LYSleepAlert();
79767e
 	FREE(Title);
79767e
 	FREE(bookmark_URL);
79767e
+	BStrFree(tmp_data);
79767e
 	return;
79767e
     }
79767e
 
79767e
diff --git a/src/LYDownload.c b/src/LYDownload.c
79767e
index cf1ea98..9cf712d 100644
79767e
--- a/src/LYDownload.c
79767e
+++ b/src/LYDownload.c
79767e
@@ -456,6 +456,7 @@ void LYDownload(char *line)
79767e
   cleanup:
79767e
     FREE(Line);
79767e
     BStrFree(buffer);
79767e
+    BStrFree(command);
79767e
     return;
79767e
 }
79767e
 
79767e
diff --git a/src/LYLeaks.c b/src/LYLeaks.c
79767e
index 2f2de28..8c236ff 100644
79767e
--- a/src/LYLeaks.c
79767e
+++ b/src/LYLeaks.c
79767e
@@ -1090,26 +1090,10 @@ static char *LYLeakSAVsprintf(char **dest,
79767e
 		mark_realloced(ALp_old, *dest, strlen(*dest) + 1, cp_File, ssi_Line);
79767e
 		return (*dest);
79767e
 	    }
79767e
-	    if (vp_realloced == vp_oldAlloced) {
79767e
-		ALp_new->SL_memory.cp_FileName = old_cp_File;
79767e
-		ALp_new->SL_memory.ssi_LineNumber = old_ssi_Line;
79767e
-		ALp_new->SL_realloc.cp_FileName = cp_File;
79767e
-		ALp_new->SL_realloc.ssi_LineNumber = ssi_Line;
79767e
-		return (*dest);
79767e
-	    }
79767e
-	    /* Look up again, list may have changed! - kw */
79767e
-	    ALp_old = FindInList(vp_oldAlloced);
79767e
-	    if (ALp_old == NULL) {
79767e
-		ALp_new->SL_memory.cp_FileName = old_cp_File;
79767e
-		ALp_new->SL_memory.ssi_LineNumber = old_ssi_Line;
79767e
-		ALp_new->SL_realloc.cp_FileName = cp_File;
79767e
-		ALp_new->SL_realloc.ssi_LineNumber = ssi_Line;
79767e
-	    } else {
79767e
-		ALp_new->SL_memory.cp_FileName = old_cp_File;
79767e
-		ALp_new->SL_memory.ssi_LineNumber = old_ssi_Line;
79767e
-		ALp_new->SL_realloc.cp_FileName = cp_File;
79767e
-		ALp_new->SL_realloc.ssi_LineNumber = ssi_Line;
79767e
-	    }
79767e
+	    ALp_new->SL_memory.cp_FileName = old_cp_File;
79767e
+	    ALp_new->SL_memory.ssi_LineNumber = old_ssi_Line;
79767e
+	    ALp_new->SL_realloc.cp_FileName = cp_File;
79767e
+	    ALp_new->SL_realloc.ssi_LineNumber = ssi_Line;
79767e
 	}
79767e
 	return (*dest);
79767e
     }
79767e
-- 
79767e
2.17.2
79767e