Blame SOURCES/expect-5.45-match-gt-numchars-segfault.patch

26470e
diff -up expect5.45/expect.c.orig expect5.45/expect.c
26470e
--- expect5.45/expect.c.orig	2012-02-06 14:15:13.469490744 +0100
26470e
+++ expect5.45/expect.c	2012-02-06 14:16:23.596837896 +0100
26470e
@@ -2363,7 +2363,12 @@ expMatchProcess(
26470e
 
26470e
 	/* "!e" means no case matched - transfer by default */
26470e
 	if (!e || e->transfer) {
26470e
-	    int remainder = numchars-match;
26470e
+	    int remainder;
26470e
+	    if (match > numchars) {
26470e
+		match = numchars;
26470e
+		eo->matchlen = match;
26470e
+	    }
26470e
+	    remainder = numchars-match;
26470e
 	    /* delete matched chars from input buffer */
26470e
 	    esPtr->printed -= match;
26470e
 	    if (numchars != 0) {