Mercurial > hg > xemacs-beta
annotate tests/mule/match.el @ 5908:6174848f3e6c
Use parse_integer() in read_atom(); support bases with ratios like integers
src/ChangeLog addition:
2015-05-08 Aidan Kehoe <kehoea@parhasard.net>
* data.c (init_errors_once_early):
Move the Qunsupported_type here from numbers.c, so it's available
when the majority of our types are not supported.
* general-slots.h: Add it here, too.
* number.c: Remove the definition of Qunsupported_type from here.
* lread.c (read_atom):
Check if the first character could reflect a rational, if so, call
parse_integer(), don't check the syntax of the other
characters. This allows us to accept the non-ASCII digit
characters too.
If that worked partially, but not completely, and the next char is
a slash, try to parse as a ratio.
If that fails, try isfloat_string(), but only if the first
character could plausibly be part of a float.
Otherwise, treat as a symbol.
* lread.c (read_rational):
Rename from read_integer. Handle ratios with the same radix
specification as was used for integers.
* lread.c (read1):
Rename read_integer in this function. Support the Common Lisp
#NNNrMMM syntax for parsing a number MMM of arbitrary radix NNN.
man/ChangeLog addition:
2015-05-08 Aidan Kehoe <kehoea@parhasard.net>
* lispref/numbers.texi (Numbers):
Describe the newly-supported arbitrary-base syntax for rationals
(integers and ratios). Describe that ratios can take the same base
specification as integers, something also new.
tests/ChangeLog addition:
2015-05-08 Aidan Kehoe <kehoea@parhasard.net>
* automated/lisp-reader-tests.el:
Check the arbitrary-base integer reader syntax support, just
added. Check the reader base support for ratios, just added.
Check the non-ASCII-digit support in the reader, just added.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Sat, 09 May 2015 00:40:57 +0100 |
parents | 308d34e9f07d |
children |
rev | line source |
---|---|
70 | 1 ;;; Testsuite for Mule string-matching - used to crash! |
2 | |
3 ;; Copyright (C) 1996 Sun Microsystems. | |
4 | |
5 ;; This file is part of XEmacs. | |
6 | |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
7 ;; XEmacs is free software: you can redistribute it and/or modify it |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
8 ;; under the terms of the GNU General Public License as published by the |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
9 ;; Free Software Foundation, either version 3 of the License, or (at your |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
10 ;; option) any later version. |
70 | 11 |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
12 ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
13 ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
14 ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
15 ;; for more details. |
70 | 16 |
17 ;; You should have received a copy of the GNU General Public License | |
5402
308d34e9f07d
Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents:
70
diff
changeset
|
18 ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>. |
70 | 19 |
20 ;;; Just load the file to run the test. | |
21 | |
22 (defmacro test-match (result regexp string) | |
23 `(save-excursion | |
24 (assert (eq ,result (string-match ,regexp ,string))) | |
25 (let ((buf (get-buffer-create "*testsuite*")) | |
26 (random-text "foo$(BEl5~(B")) | |
27 (set-buffer buf) | |
28 (erase-buffer) | |
29 (insert random-text) | |
30 (insert ,string) | |
31 (goto-char (point-min)) | |
32 (forward-char (length random-text)) | |
33 (assert (eq (progn (re-search-forward ,regexp) (match-beginning 0)) | |
34 (+ 1 ,result (length random-text)))) | |
35 ))) | |
36 | |
37 (when (featurep 'mule) | |
38 (test-match 0 "a" "a") | |
39 (test-match 0 "[^a]" "$(B4A;z(B") | |
40 (test-match 2 "[^a]$(B;z(B" "ab$(B4A;z(B") | |
41 (test-match 1 "[^a]" "ab$(B4A;z(B") | |
42 (test-match 0 "[^a]" "$(B4A(Bb$(B4A;z(Bb") | |
43 (test-match 6 "[a]" "b$(B4A(Bb$(B4A;z(Bba") | |
44 (test-match 2 "[a]" "b$(B4A(Bab$(B4A;z(Bba") | |
45 (test-match 1 "[$(B4A(Ba]" "b$(B4A(Bab$(B4A;z(Bba") | |
46 (test-match 1 "[a$(B4A(B]" "b$(B4A(Bab$(B4A;z(Bba") | |
47 (test-match 0 "[^$(B4A(Ba]" "b$(B4A(Bab$(B4A;z(Bba") | |
48 (test-match 5 "$(B4A(B[^$(B4A(Ba]" "a$(B4A(Bab$(B4A4A;z(Bba") | |
49 ) | |
50 |