changeset 112:a57fd3390ee4

[gaim-migrate @ 122] Fixed the bug where if there is more than one word either being removed or inserted, remaining checks hold. E.g. if there is a rule that 'm' gets replaced with 'your roommate' (this is actually is one of my rules), and another rule is 'u' -> 'you', typing "m u" used to be "your roommate u", but is now "your roommate you" (don't ask, it's a stupid example, but it has implications). committer: Tailor Script <tailor@pidgin.im>
author Eric Warmenhoven <eric@warmenhoven.org>
date Fri, 14 Apr 2000 06:02:26 +0000 (2000-04-14)
parents d927bb34e2c6
children 52bfcdc72dcc
files plugins/spellchk.c
diffstat 1 files changed, 12 insertions(+), 9 deletions(-) [+]
line wrap: on
line diff
--- a/plugins/spellchk.c	Thu Apr 13 08:05:57 2000 +0000
+++ b/plugins/spellchk.c	Fri Apr 14 06:02:26 2000 +0000
@@ -6,9 +6,7 @@
  * 	? I think i did everything i want to with it.
  *
  * BUGS:
- * 	If you have a numeric replacement, and is preceded by numeric text,
- * 	it doesn't catch it. I don't know why. Probably because it's not
- * 	designed to work with numbers.
+ * 	? I think i fixed them all.
  */
 #define GAIM_PLUGINS
 #include "gaim.h"
@@ -50,9 +48,12 @@
 			struct replace_words *r;
 			r = (struct replace_words *)(w->data);
 			tmp = have_word(*message, word);
-			if (!strcmp(have_word(*message, word), r->bad))
+			if (!strcmp(have_word(*message, word), r->bad)) {
 				substitute(message, word, strlen(r->bad),
 						r->good);
+				l += num_words(r->good) - num_words(r->bad);
+				i += num_words(r->good) - num_words(r->bad);
+			}
 			free(tmp);
 			w = w->next;
 		}
@@ -167,10 +168,10 @@
 				state = 2;
 			break;
 		case 1: /* inside word */
-			if (isspace(m[pos]) || m[pos] == '\'' || m[pos] == '.')
+			if (m[pos] == '<')
+				state = 2;
+			else if (!isalnum(m[pos]))
 				state = 0;
-			else if (m[pos] == '<')
-				state = 2;
 			break;
 		case 2: /* inside HTML tag */
 			if (m[pos] == '>')
@@ -196,7 +197,9 @@
 				state = 2;
 			break;
 		case 1:
-			if (isspace(m[pos]) || m[pos] == '\'' || m[pos] == '.')
+			if (m[pos] == '<')
+				state = 2;
+			else if (!isalnum(m[pos]))
 				state = 0;
 			break;
 		case 2:
@@ -209,7 +212,7 @@
 }
 
 char *have_word(char *m, int pos) {
-	char *tmp = strpbrk(&m[pos], "' \t\f\r\n.");
+	char *tmp = strpbrk(&m[pos], "' \t\f\r\n.?!-,");
 	int len = (int)(tmp - &m[pos]);
 
 	if (tmp == NULL) {