BSD 4_4 release
[unix-history] / usr / src / lib / libedit / search.c
index dec34ef..4ff9c61 100644 (file)
@@ -1,28 +1,59 @@
 /*-
 /*-
- * Copyright (c) 1992 The Regents of the University of California.
- * All rights reserved.
+ * Copyright (c) 1992, 1993
+ *     The Regents of the University of California.  All rights reserved.
  *
  * This code is derived from software contributed to Berkeley by
  * Christos Zoulas of Cornell University.
  *
  *
  * This code is derived from software contributed to Berkeley by
  * Christos Zoulas of Cornell University.
  *
- * %sccs.include.redist.c%
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *     This product includes software developed by the University of
+ *     California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
  */
 
  */
 
-#ifndef lint
-static char sccsid[] = "@(#)search.c   5.1 (Berkeley) %G%";
-#endif /* not lint */
+#if !defined(lint) && !defined(SCCSID)
+static char sccsid[] = "@(#)search.c   8.1 (Berkeley) 6/4/93";
+#endif /* not lint && not SCCSID */
 
 /*
 
 /*
- * el.search.c: History and character search functions
+ * search.c: History and character search functions
  */
 #include "sys.h"
 #include <stdlib.h>
  */
 #include "sys.h"
 #include <stdlib.h>
-#ifndef sun
+#ifdef REGEXP
 #include <regexp.h>
 #endif
 #include "el.h"
 
 #include <regexp.h>
 #endif
 #include "el.h"
 
-private int el_match   __P((const char *, const char *));
+/*
+ * Adjust cursor in vi mode to include the character under it
+ */
+#define EL_CURSOR(el) \
+    ((el)->el_line.cursor + (((el)->el_map.type == MAP_VI) && \
+                           ((el)->el_map.current == (el)->el_map.alt)))
 
 /* search_init():
  *     Initialize the search stuff
 
 /* search_init():
  *     Initialize the search stuff
@@ -51,7 +82,7 @@ search_end(el)
     el->el_search.patbuf = NULL;
 }
 
     el->el_search.patbuf = NULL;
 }
 
-#ifndef sun
+#ifdef REGEXP
 /* regerror():
  *     Handle regular expression errors
  */
 /* regerror():
  *     Handle regular expression errors
  */
@@ -66,12 +97,12 @@ regerror(msg)
 /* el_match():
  *     Return if string matches pattern
  */
 /* el_match():
  *     Return if string matches pattern
  */
-private int
+protected int
 el_match(str, pat)
     const char *str;
     const char *pat;
 {
 el_match(str, pat)
     const char *str;
     const char *pat;
 {
-#ifdef sun
+#ifndef REGEXP
     extern char *re_comp __P((const char *));
     extern int re_exec __P((const char *));
 #else
     extern char *re_comp __P((const char *));
     extern int re_exec __P((const char *));
 #else
@@ -81,13 +112,13 @@ el_match(str, pat)
 
     if (strstr(str, pat) != NULL)
        return 1;
 
     if (strstr(str, pat) != NULL)
        return 1;
-#ifdef sun
+#ifndef REGEXP
     if (re_comp(pat) != NULL)
        return 0;
     else
     return re_exec(str) == 1;
 #else
     if (re_comp(pat) != NULL)
        return 0;
     else
     return re_exec(str) == 1;
 #else
-    if ((re = regcomp(pat)) == NULL) {
+    if ((re = regcomp(pat)) != NULL) {
        rv = regexec(re, str);
        free((ptr_t) re);
     }
        rv = regexec(re, str);
        free((ptr_t) re);
     }
@@ -125,7 +156,7 @@ c_setpat(el)
 {
     if (el->el_state.lastcmd != ED_SEARCH_PREV_HISTORY && 
        el->el_state.lastcmd != ED_SEARCH_NEXT_HISTORY) {
 {
     if (el->el_state.lastcmd != ED_SEARCH_PREV_HISTORY && 
        el->el_state.lastcmd != ED_SEARCH_NEXT_HISTORY) {
-       el->el_search.patlen = el->el_line.cursor - el->el_line.buffer;
+       el->el_search.patlen = EL_CURSOR(el) - el->el_line.buffer;
        if (el->el_search.patlen >= EL_BUFSIZ) 
            el->el_search.patlen = EL_BUFSIZ -1;
        if (el->el_search.patlen >= 0)  {
        if (el->el_search.patlen >= EL_BUFSIZ) 
            el->el_search.patlen = EL_BUFSIZ -1;
        if (el->el_search.patlen >= 0)  {
@@ -141,7 +172,7 @@ c_setpat(el)
     (void) fprintf(el->el_errfile, "patlen = %d\n", el->el_search.patlen);
     (void) fprintf(el->el_errfile, "patbuf = \"%s\"\n", el->el_search.patbuf);
     (void) fprintf(el->el_errfile, "cursor %d lastchar %d\n", 
     (void) fprintf(el->el_errfile, "patlen = %d\n", el->el_search.patlen);
     (void) fprintf(el->el_errfile, "patbuf = \"%s\"\n", el->el_search.patbuf);
     (void) fprintf(el->el_errfile, "cursor %d lastchar %d\n", 
-                  el->el_line.cursor - el->el_line.buffer, 
+                  EL_CURSOR(el) - el->el_line.buffer, 
                   el->el_line.lastchar - el->el_line.buffer);
 #endif
 }
                   el->el_line.lastchar - el->el_line.buffer);
 #endif
 }
@@ -391,7 +422,7 @@ cv_search(el, dir)
 
     c_insert(el, 2);   /* prompt + '\n' */
     *el->el_line.cursor++ = '\n';
 
     c_insert(el, 2);   /* prompt + '\n' */
     *el->el_line.cursor++ = '\n';
-    *el->el_line.cursor++ = dir == ED_SEARCH_PREV_HISTORY ? '?' : '/';
+    *el->el_line.cursor++ = dir == ED_SEARCH_PREV_HISTORY ? '/' : '?';
     re_refresh(el);
 
 #ifdef ANCHOR
     re_refresh(el);
 
 #ifdef ANCHOR