Blame SOURCES/cscope-4-Avoid-double-free-via-double-fclose-in-changestring.patch

0d6b98
From f632c3fd86fce2c495a290dd70f5f09e3e7e7a28 Mon Sep 17 00:00:00 2001
0d6b98
From: Hans-Bernhard Broeker <HBBroeker@T-Online.de>
0d6b98
Date: Sat, 13 Apr 2019 14:52:35 +0200
0d6b98
Subject: [PATCH 5/9] Avoid double-free via double fclose in changestring.
0d6b98
0d6b98
Mark closed FILE* by setting it to NULL, and check for that.
0d6b98
0d6b98
Signed-off-by: Vladis Dronov <vdronov@redhat.com>
0d6b98
---
0d6b98
 src/command.c | 5 ++++-
0d6b98
 1 file changed, 4 insertions(+), 1 deletion(-)
0d6b98
0d6b98
diff --git a/src/command.c b/src/command.c
0d6b98
index 8740b11..dcb5278 100644
0d6b98
--- a/src/command.c
0d6b98
+++ b/src/command.c
0d6b98
@@ -786,6 +786,7 @@ changestring(void)
0d6b98
     }
0d6b98
     fprintf(script, "w\nq\n!\n");	/* write and quit */
0d6b98
     fclose(script);
0d6b98
+    script = NULL;
0d6b98
 
0d6b98
     /* if any line was marked */
0d6b98
     if (anymarked == YES) {
0d6b98
@@ -803,7 +804,9 @@ changestring(void)
0d6b98
     }
0d6b98
     changing = NO;
0d6b98
     mousemenu();
0d6b98
-    fclose(script);
0d6b98
+    if (script != NULL) {
0d6b98
+	fclose(script);
0d6b98
+    }
0d6b98
     free(change);
0d6b98
     return(anymarked);
0d6b98
 }
0d6b98
-- 
0d6b98
2.26.2
0d6b98