summaryrefslogtreecommitdiffstats
path: root/package/busybox/patches
diff options
context:
space:
mode:
authormbm <mbm@3c298f89-4303-0410-b956-a3cf2f4a3e73>2008-10-29 13:46:28 +0000
committermbm <mbm@3c298f89-4303-0410-b956-a3cf2f4a3e73>2008-10-29 13:46:28 +0000
commit9c8c85d98138af025371616e75b47d44fc63d1e5 (patch)
tree35d6f797b086e5f3a5d633c7aa3d2804615dc278 /package/busybox/patches
parentb9edc428634ee2ab2025a9da6283787056ca212d (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
Diffstat (limited to 'package/busybox/patches')
-rw-r--r--package/busybox/patches/480-vi_search.patch35
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;