diff options
| author | mbm <mbm@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2008-10-29 13:46:28 +0000 | 
|---|---|---|
| committer | mbm <mbm@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2008-10-29 13:46:28 +0000 | 
| commit | 9c8c85d98138af025371616e75b47d44fc63d1e5 (patch) | |
| tree | 35d6f797b086e5f3a5d633c7aa3d2804615dc278 | |
| parent | b9edc428634ee2ab2025a9da6283787056ca212d (diff) | |
fix a null pointer deref in vi's search
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@13073 3c298f89-4303-0410-b956-a3cf2f4a3e73
| -rw-r--r-- | package/busybox/patches/480-vi_search.patch | 35 | 
1 files changed, 35 insertions, 0 deletions
| diff --git a/package/busybox/patches/480-vi_search.patch b/package/busybox/patches/480-vi_search.patch new file mode 100644 index 000000000..d9fa821e4 --- /dev/null +++ b/package/busybox/patches/480-vi_search.patch @@ -0,0 +1,35 @@ +--- a/editors/vi.c ++++ b/editors/vi.c +@@ -3313,7 +3313,7 @@ + 		buf[1] = '\0'; + 		q = get_input_line(buf);	// get input line- use "status line" + 		if (q[0] && !q[1]) { +-			if (last_search_pattern[0]) ++			if (last_search_pattern) + 			    last_search_pattern[0] = c; + 			goto dc3; // if no pat re-use old pat + 		} +@@ -3329,6 +3329,10 @@ + 		if (cmdcnt-- > 1) { + 			do_cmd(c); + 		}				// repeat cnt ++		if (last_search_pattern == 0) { ++			msg = "No previous regular expression"; ++			goto dc2; ++		} + 		dir = BACK;		// assume BACKWARD search + 		p = dot - 1; + 		if (last_search_pattern[0] == '?') { +@@ -3348,10 +3352,8 @@ + 			msg = "No previous regular expression"; + 			goto dc2; + 		} +-		if (last_search_pattern[0] == '/') { +-			dir = FORWARD;	// assume FORWARD search +-			p = dot + 1; +-		} ++		dir = FORWARD;	// assume FORWARD search ++		p = dot + 1; + 		if (last_search_pattern[0] == '?') { + 			dir = BACK; + 			p = dot - 1; | 
