aboutsummaryrefslogtreecommitdiffstats
path: root/src/search.c
diff options
context:
space:
mode:
authorStefan Monnier2006-10-03 13:47:26 +0000
committerStefan Monnier2006-10-03 13:47:26 +0000
commit54dd3310afa4bacd201ce9e126be49ede6aa3a36 (patch)
tree37a3e759f01471ae7529b6a88bad594d060f3ca8 /src/search.c
parentec40e71f22d2ccb626286622c5217ec282cf05c3 (diff)
downloademacs-54dd3310afa4bacd201ce9e126be49ede6aa3a36.tar.gz
emacs-54dd3310afa4bacd201ce9e126be49ede6aa3a36.zip
(compile_pattern): Only check `cp->syntax_table' if needed.
(compile_pattern_1): Remember `used_syntax' in `cp->syntax_table'. (clear_regexp_cache): Only flush those regexps which depend on a syntax-table.
Diffstat (limited to 'src/search.c')
-rw-r--r--src/search.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/search.c b/src/search.c
index 5f9f321067a..7c3151b76b8 100644
--- a/src/search.c
+++ b/src/search.c
@@ -216,7 +216,8 @@ shrink_regexp_cache ()
216 } 216 }
217} 217}
218 218
219/* Clear the regexp cache. 219/* Clear the regexp cache w.r.t. a particular syntax table,
220 because it was changed.
220 There is no danger of memory leak here because re_compile_pattern 221 There is no danger of memory leak here because re_compile_pattern
221 automagically manages the memory in each re_pattern_buffer struct, 222 automagically manages the memory in each re_pattern_buffer struct,
222 based on its `allocated' and `buffer' values. */ 223 based on its `allocated' and `buffer' values. */
@@ -226,7 +227,11 @@ clear_regexp_cache ()
226 int i; 227 int i;
227 228
228 for (i = 0; i < REGEXP_CACHE_SIZE; ++i) 229 for (i = 0; i < REGEXP_CACHE_SIZE; ++i)
229 searchbufs[i].regexp = Qnil; 230 /* It's tempting to compare with the syntax-table we've actually changd,
231 but it's not sufficient because char-table inheritance mewans that
232 modifying one syntax-table can change others at the same time. */
233 if (!EQ (searchbufs[i].syntax_table, Qt))
234 searchbufs[i].regexp = Qnil;
230} 235}
231 236
232/* Compile a regexp if necessary, but first check to see if there's one in 237/* Compile a regexp if necessary, but first check to see if there's one in