Mercurial > hg > xemacs-beta
view tests/gtk/event-stream-tests.el @ 5552:85210c453a97
Fix performance regression in refactored syntax cache setup.
More doc improvements.
* syntax.h (enum syntax_source):
New. Specify whether syntax is from property or buffer.
(struct syntax_cache):
Use enum syntax_source source, instead of no_syntax_table_prop
and use_code.
Improve comments.
(SOURCE_IS_TABLE):
New predicate.
(SYNTAX_CODE_FROM_CACHE):
Use it instead of use_code, and adjust logic.
* syntax.c (syntax_cache_table_was_changed):
Check cache->source (cache->no_syntax_table_prop is gone).
(reset_syntax_cache_range):
All information about OBJECT and BUFFER is in CACHE already.
Also reset markers in OBJECT if it is a buffer.
Rename INFINITE to VALID_EVERYWHERE.
(init_syntax_cache):
Initialize source (cache->no_syntax_table_prop is gone).
Maybe initialize start and end to null markers.
Initialize cache range with reset_syntax_cache_range.
(update_syntax_cache):
Use source instead of no_syntax_table_prop and use_code.
(setup_syntax_cache):
Add header comment. Improve other comments.
Make calls to reset_syntax_cache_range and init_syntax_cache match
their prototypes.
(init_buffer_syntax_cache):
Use init_syntax_cache to do the work.
(signal_syntax_cache_extent_changed):
Make call to reset_syntax_cache_range match its prototype.
Improve local variable naming.
author | Stephen J. Turnbull <stephen@xemacs.org> |
---|---|
date | Tue, 23 Aug 2011 04:41:45 +0900 |
parents | 4dee0387b9de |
children |
line wrap: on
line source
;; event-stream-tests.el --- test the GTK event stream ;; ;; Copyright 2000, 2001 William Perry ;; Seems to be based on the comment at the end of src/event-stream.c. ;; ;; This file is part of XEmacs. ;; XEmacs is free software: you can redistribute it and/or modify it ;; under the terms of the GNU General Public License as published by the ;; Free Software Foundation, either version 3 of the License, or (at your ;; option) any later version. ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ;; for more details. ;; You should have received a copy of the GNU General Public License ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>. ;also do this: make two frames, one viewing "*scratch*", the other "foo". ;in *scratch*, type (sit-for 20)^J ;wait a couple of seconds, move cursor to foo, type "a" ;a should be inserted in foo. Cursor highlighting should not change in ;the meantime. ;do it with sleep-for. move cursor into foo, then back into *scratch* ;before typing. ;repeat also with (accept-process-output nil 20) ;make sure ^G aborts sit-for, sleep-for and accept-process-output: (defun tst () (list (condition-case c (sleep-for 20) (quit c)) (read-char))) (tst)^Ja^G ==> ((quit) 97) with no signal (tst)^J^Ga ==> ((quit) 97) with no signal (tst)^Jabc^G ==> ((quit) 97) with no signal, and "bc" inserted in buffer ; with sit-for only do the 2nd test. ; Do all 3 tests with (accept-process-output nil 20) /* Additional test cases for accept-process-output, sleep-for, sit-for. Be sure you do all of the above checking for C-g and focus, too! ; Make sure that timer handlers are run during, not after sit-for: (defun timer-check () (add-timeout 2 #'(lambda (ignore) (message "timer ran")) nil) (sit-for 5) (message "after sit-for")) ; The first message should appear after 2 seconds, and the final message ; 3 seconds after that. ; repeat above test with (sleep-for 5) and (accept-process-output nil 5) ; Make sure that process filters are run during, not after sit-for. (defun fubar () (message "sit-for = %s" (sit-for 30))) (add-hook 'post-command-hook 'fubar) ; Now type M-x shell RET ; wait for the shell prompt then send: ls RET ; the output of ls should fill immediately, and not wait 30 seconds. ; repeat above test with (sleep-for 30) and (accept-process-output nil 30) ; Make sure that recursive invocations return immediately: (defmacro test-diff-time (start end) `(+ (* (- (car ,end) (car ,start)) 65536.0) (- (cadr ,end) (cadr ,start)) (/ (- (caddr ,end) (caddr ,start)) 1000000.0))) (defun testee (ignore) (sit-for 10)) (defun test-them () (let ((start (current-time)) end) (add-timeout 2 'testee nil) (sit-for 5) (add-timeout 2 'testee nil) (sleep-for 5) (add-timeout 2 'testee nil) (accept-process-output nil 5) (setq end (current-time)) (test-diff-time start end))) (test-them) should sit for 15 seconds.