summaryrefslogtreecommitdiff
path: root/usr.bin/vi/common/search.c
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>1996-06-18 09:59:13 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>1996-06-18 09:59:13 +0000
commit235b40f1bb36006b01cd45b3fe9605570b5d8a6d (patch)
tree8cd31f60d4811d7dc6eb09f47da8b226686ebf3c /usr.bin/vi/common/search.c
parentdf2140f19b8e88fbcef5748d92fcf72f447586b1 (diff)
vi fixes from bostic
Diffstat (limited to 'usr.bin/vi/common/search.c')
-rw-r--r--usr.bin/vi/common/search.c28
1 files changed, 19 insertions, 9 deletions
diff --git a/usr.bin/vi/common/search.c b/usr.bin/vi/common/search.c
index fbbaf76ab97..5823f250ff4 100644
--- a/usr.bin/vi/common/search.c
+++ b/usr.bin/vi/common/search.c
@@ -10,7 +10,7 @@
#include "config.h"
#ifndef lint
-static const char sccsid[] = "@(#)search.c 10.23 (Berkeley) 5/15/96";
+static const char sccsid[] = "@(#)search.c 10.24 (Berkeley) 5/26/96";
#endif /* not lint */
#include <sys/types.h>
@@ -248,20 +248,29 @@ f_search(sp, fm, rm, ptrn, eptrn, flags)
/*
* XXX
* Warn if the search wrapped. This message is only displayed
- * if there are no keys in the queue. The problem is that the
- * command is going to succeed, and the message isn't an error,
- * it's informational in nature. If a macro causes it to be
- * output repeatedly, e.g., the pattern only occurs once in the
- * file and wrapscan is set, you can lose, particularly if the
- * macro does something like:
+ * if we're in interactive mode and there are no keys in the
+ * queue. The problem is that the command is going to succeed,
+ * and the message isn't an error, it's merely informational.
+ * So, if we're reading the .exrc file, displaying it causes
+ * the screen to pause before entering the file, which is bad.
+ * Or, if a macro causes it to be repeatedly displayed, e.g.,
+ * the pattern only occurs once in the file and wrapscan is set,
+ * you lose, particularly if the macro does something like:
* :map K /pattern/^MjK
* Each new search will display the message and the /pattern/
* will immediately overwrite it, with strange results. The
* System V vi displays the "wrapped" message multiple times,
* but it's overwritten each time, so it's not as noticeable.
* Since we don't discard messages, it's a real problem.
+ *
+ * XXX
+ * The test for SC_SCR_EX or SC_SCR_VI feels wrong to me. I
+ * didn't originally intend for that bit to reflect that the
+ * user has "gone interactive", but that's the only solution
+ * I see.
*/
- if (wrapped && LF_ISSET(SEARCH_MSG) && !KEYS_WAITING(sp))
+ if (wrapped && LF_ISSET(SEARCH_MSG) &&
+ F_ISSET(sp, SC_SCR_EX | SC_SCR_VI) && !KEYS_WAITING(sp))
search_msg(sp, S_WRAP);
#if defined(DEBUG) && 0
@@ -403,7 +412,8 @@ b_search(sp, fm, rm, ptrn, eptrn, flags)
* XXX
* See the comment in f_search() for more information.
*/
- if (wrapped && LF_ISSET(SEARCH_MSG) && !KEYS_WAITING(sp))
+ if (wrapped && LF_ISSET(SEARCH_MSG) &&
+ F_ISSET(sp, SC_SCR_EX | SC_SCR_VI) && !KEYS_WAITING(sp))
search_msg(sp, S_WRAP);
#if defined(DEBUG) && 0