summaryrefslogtreecommitdiff
path: root/usr.bin/mg/grep.c
diff options
context:
space:
mode:
authorChad Loder <cloder@cvs.openbsd.org>2005-06-03 23:39:56 +0000
committerChad Loder <cloder@cvs.openbsd.org>2005-06-03 23:39:56 +0000
commitcc08a0235632a2598ccdda1a7fc939726372e593 (patch)
tree84146cd5a9da6cb6156567b49014b92516820bb4 /usr.bin/mg/grep.c
parent3d1b886fd7509f4c2c852864c532a5fc668a7ed0 (diff)
Make M-x gid tokenize C identifiers correctly. Problem reported by mjc.
Testing and OK mjc
Diffstat (limited to 'usr.bin/mg/grep.c')
-rw-r--r--usr.bin/mg/grep.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/usr.bin/mg/grep.c b/usr.bin/mg/grep.c
index 44fc2a4d937..8149856fc15 100644
--- a/usr.bin/mg/grep.c
+++ b/usr.bin/mg/grep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: grep.c,v 1.14 2005/05/25 20:15:18 jason Exp $ */
+/* $OpenBSD: grep.c,v 1.15 2005/06/03 23:39:55 cloder Exp $ */
/*
* Copyright (c) 2001 Artur Grabowski <art@openbsd.org>. All rights reserved.
*
@@ -136,23 +136,26 @@ gid(int f, int n)
/* catch ([^\s(){}]+)[\s(){}]* */
i = curwp->w_doto;
- /* Skip delimiters we are currently on */
- while (i > 0 && ((c = lgetc(curwp->w_dotp, i)) == '(' || c == ')' ||
- c == '{' || c == '}' || isspace(c)))
+ /* Skip backwards over delimiters we are currently on */
+ while (i > 0) {
+ c = lgetc(curwp->w_dotp, i);
+ if (isalnum(c) || c == '_')
+ break;
+
i--;
+ }
+
/* Skip the symbol itself */
for (; i > 0; i--) {
c = lgetc(curwp->w_dotp, i - 1);
- if (isspace(c) || c == '(' || c == ')' ||
- c == '{' || c == '}')
+ if (!isalnum(c) && c != '_')
break;
}
/* Fill the symbol in prompt[] */
for (j = 0; j < sizeof(prompt) - 1 && i < llength(curwp->w_dotp);
j++, i++) {
c = lgetc(curwp->w_dotp, i);
- if (isspace(c) || c == '(' || c == ')' ||
- c == '{' || c == '}')
+ if (!isalnum(c) && c != '_')
break;
prompt[j] = c;
}