source: trunk/j/src/org/armedbear/lisp/subtypep.lisp @ 5275

Last change on this file since 5275 was 5275, checked in by piso, 17 years ago

Work in progress.

File size: 14.7 KB
Line 
1;;; subtypep.lisp
2;;;
3;;; Copyright (C) 2003 Peter Graves
4;;; $Id: subtypep.lisp,v 1.34 2003-12-27 21:29:28 piso Exp $
5;;;
6;;; This program is free software; you can redistribute it and/or
7;;; modify it under the terms of the GNU General Public License
8;;; as published by the Free Software Foundation; either version 2
9;;; of the License, or (at your option) any later version.
10;;;
11;;; This program is distributed in the hope that it will be useful,
12;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
13;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14;;; GNU General Public License for more details.
15;;;
16;;; You should have received a copy of the GNU General Public License
17;;; along with this program; if not, write to the Free Software
18;;; Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19
20;;; Adapted from GCL.
21
22(in-package "SYSTEM")
23
24(defparameter *known-types* (make-hash-table))
25
26(dolist (i '((ARITHMETIC-ERROR ERROR)
27             (ARRAY)
28             (BASE-STRING SIMPLE-STRING)
29             (BIGNUM INTEGER)
30             (BIT INTEGER)
31             (BIT-VECTOR VECTOR)
32             (BOOLEAN SYMBOL)
33             (BUILT-IN-CLASS CLASS)
34             (CELL-ERROR ERROR)
35             (CHARACTER)
36             (CLASS STANDARD-OBJECT)
37             (COMPILED-FUNCTION FUNCTION)
38             (COMPLEX NUMBER)
39             (CONDITION)
40             (CONS LIST)
41             (CONTROL-ERROR ERROR)
42             (DIVISION-BY-ZERO ARITHMETIC-ERROR)
43             (END-OF-FILE STREAM-ERROR)
44             (ERROR SERIOUS-CONDITION)
45             (EXTENDED-CHAR CHARACTER NIL)
46             (FILE-ERROR ERROR)
47             (FIXNUM INTEGER)
48             (FLOAT REAL)
49             (FLOATING-POINT-INEXACT ARITHMETIC-ERROR)
50             (FLOATING-POINT-INVALID-OPERATION ARITHMETIC-ERROR)
51             (FLOATING-POINT-OVERFLOW ARITHMETIC-ERROR)
52             (FLOATING-POINT-UNDERFLOW ARITHMETIC-ERROR)
53             (FUNCTION)
54             (GENERIC-FUNCTION FUNCTION)
55             (HASH-TABLE)
56             (INTEGER RATIONAL)
57             (KEYWORD SYMBOL)
58             (LIST SEQUENCE)
59             (NULL SYMBOL LIST)
60             (NUMBER)
61             (PACKAGE)
62             (PACKAGE-ERROR ERROR)
63             (PARSE-ERROR ERROR)
64             (PATHNAME)
65             (PRINT-NOT-READABLE ERROR)
66             (PROGRAM-ERROR ERROR)
67             (RANDOM-STATE)
68             (RATIO RATIONAL)
69             (RATIONAL REAL)
70             (READER-ERROR PARSE-ERROR STREAM-ERROR)
71             (READTABLE)
72             (REAL NUMBER)
73             (RESTART)
74             (SERIOUS-CONDITION CONDITION)
75             (SIMPLE-ARRAY ARRAY)
76             (SIMPLE-BASE-STRING SIMPLE-STRING BASE-STRING)
77             (SIMPLE-BIT-VECTOR BIT-VECTOR SIMPLE-ARRAY)
78             (SIMPLE-CONDITION CONDITION)
79             (SIMPLE-ERROR SIMPLE-CONDITION ERROR)
80             (SIMPLE-STRING STRING SIMPLE-ARRAY)
81             (SIMPLE-TYPE-ERROR SIMPLE-CONDITION TYPE-ERROR)
82             (SIMPLE-VECTOR VECTOR SIMPLE-ARRAY)
83             (SIMPLE-WARNING SIMPLE-CONDITION WARNING)
84             (STANDARD-CHAR CHARACTER)
85             (STANDARD-CLASS CLASS)
86             (STANDARD-GENERIC-FUNCTION GENERIC-FUNCTION)
87             (STANDARD-OBJECT)
88             (STORAGE-CONDITION SERIOUS-CONDITION)
89             (STREAM)
90             (STREAM-ERROR ERROR)
91             (STRING VECTOR)
92             (STRUCTURE-CLASS CLASS STANDARD-OBJECT)
93             (STYLE-WARNING WARNING)
94             (SYMBOL)
95             (TWO-WAY-STREAM STREAM)
96             (TYPE-ERROR ERROR)
97             (UNBOUND-SLOT CELL-ERROR)
98             (UNBOUND-VARIABLE CELL-ERROR)
99             (UNDEFINED-FUNCTION CELL-ERROR)
100             (VECTOR ARRAY SEQUENCE)
101             (WARNING CONDITION)
102             ))
103  (setf (gethash (car i) *known-types*) (cdr i)))
104
105(defun supertypes (type)
106  (values (gethash type *known-types*)))
107
108(defun known-type-p (type)
109  (multiple-value-bind (value present-p) (gethash type *known-types*)
110    present-p))
111
112(defun subtypep-normalize-type (type)
113  (when (symbolp type)
114    (case type
115      (CONS
116       (return-from subtypep-normalize-type '(cons t t)))
117      (FIXNUM
118       (return-from subtypep-normalize-type
119                    '(integer #.most-negative-fixnum #.most-positive-fixnum)))
120      (BASE-CHAR
121       (return-from subtypep-normalize-type 'character))
122      ((SHORT-FLOAT SINGLE-FLOAT DOUBLE-FLOAT LONG-FLOAT)
123       (return-from subtypep-normalize-type 'float))
124      (t
125       (unless (get type 'deftype-definition)
126         (return-from subtypep-normalize-type type)))))
127  ;; Fall through...
128  (let (tp i)
129    (loop
130      (if (consp type)
131          (setq tp (car type) i (cdr type))
132          (setq tp type i nil))
133      (if (and (symbolp tp) (get tp 'deftype-definition))
134          (setq type (apply (get tp 'deftype-definition) i))
135          (return)))
136    (case tp
137      (CONS
138       (let* ((len (length i))
139              (car-typespec (if (> len 0) (car i) t))
140              (cdr-typespec (if (> len 1) (cadr i) t)))
141         (unless (and car-typespec cdr-typespec)
142           (return-from subtypep-normalize-type nil))
143         (when (eq car-typespec '*)
144           (setf car-typespec t))
145         (when (eq cdr-typespec '*)
146           (setf cdr-typespec t))
147         (setf i (list car-typespec cdr-typespec))))
148      ((ARRAY SIMPLE-ARRAY)
149       (when (and i (eq (car i) nil)) ; Element type is NIL.
150         (if (eq tp 'simple-array)
151             (setq tp 'simple-string)
152             (setq tp 'string))
153         (when (cadr i) ; rank/dimensions
154           (cond ((and (consp (cadr i)) (= (length (cadr i)) 1))
155                  (if (eq (caadr i) '*)
156                      (setq i nil)
157                      (setq i (cadr i))))
158                 ((eql (cadr i) 1)
159                  (setq i nil))
160                 (t
161                  (error "invalid type specifier ~S" type))))))
162      ((SHORT-FLOAT SINGLE-FLOAT DOUBLE-FLOAT LONG-FLOAT)
163       (setq tp 'float)))
164    (if i (cons tp i) tp)))
165
166(defun sub-interval-p (i1 i2)
167  (let (low1 high1 low2 high2)
168    (if (null i1)
169        (setq low1 '* high1 '*)
170        (if (null (cdr i1))
171            (setq low1 (car i1) high1 '*)
172            (setq low1 (car i1) high1 (cadr i1))))
173    (if (null i2)
174        (setq low2 '* high2 '*)
175        (if (null (cdr i2))
176            (setq low2 (car i2) high2 '*)
177            (setq low2 (car i2) high2 (cadr i2))))
178    (when (and (consp low1) (integerp (car low1)))
179      (setq low1 (1+ (car low1))))
180    (when (and (consp low2) (integerp (car low2)))
181      (setq low2 (1+ (car low2))))
182    (when (and (consp high1) (integerp (car high1)))
183      (setq high1 (1- (car high1))))
184    (when (and (consp high2) (integerp (car high2)))
185      (setq high2 (1- (car high2))))
186    (cond ((eq low1 '*)
187     (unless (eq low2 '*)
188             (return-from sub-interval-p nil)))
189          ((eq low2 '*))
190    ((consp low1)
191     (if (consp low2)
192         (when (< (car low1) (car low2))
193         (return-from sub-interval-p nil))
194         (when (< (car low1) low2)
195         (return-from sub-interval-p nil))))
196    ((if (consp low2)
197         (when (<= low1 (car low2))
198         (return-from sub-interval-p nil))
199         (when (< low1 low2)
200         (return-from sub-interval-p nil)))))
201    (cond ((eq high1 '*)
202     (unless (eq high2 '*)
203             (return-from sub-interval-p nil)))
204          ((eq high2 '*))
205    ((consp high1)
206     (if (consp high2)
207         (when (> (car high1) (car high2))
208         (return-from sub-interval-p nil))
209         (when (> (car high1) high2)
210         (return-from sub-interval-p nil))))
211    ((if (consp high2)
212         (when (>= high1 (car high2))
213         (return-from sub-interval-p nil))
214         (when (> high1 high2)
215         (return-from sub-interval-p nil)))))
216    (return-from sub-interval-p t)))
217
218(defun simple-subtypep (type1 type2)
219  (multiple-value-bind (type1-supertypes type1-known-p) (gethash type1 *known-types*)
220    (if type1-known-p
221        (if (memq type2 type1-supertypes)
222            t
223            (dolist (supertype type1-supertypes)
224              (when (simple-subtypep supertype type2)
225                (return t))))
226        nil)))
227
228(defun subtypep (type1 type2)
229  (when (or (eq type1 type2)
230            (null type1)
231            (eq type2 t)
232            (eq type2 #.(find-class t)))
233    (return-from subtypep (values t t)))
234  (when (and (atom type1) (atom type2))
235    (let* ((classp-1 (classp type1))
236           (classp-2 (classp type2))
237           class1 class2)
238      (when (and (setf class1 (if classp-1
239                                  type1
240                                  (and (symbolp type1) (find-class type1 nil))))
241                 (setf class2 (if classp-2
242                                  type2
243                                  (and (symbolp type2) (find-class type2 nil)))))
244        (return-from subtypep
245                     (if (member class2 (class-precedence-list class1))
246                         (values t t)
247                         (values nil t))))
248      (when (or classp-1 classp-2)
249        (return-from subtypep (values nil t)))))
250  (setq type1 (subtypep-normalize-type type1)
251        type2 (subtypep-normalize-type type2))
252  (when (eq type1 type2)
253    (return-from subtypep (values t t)))
254  (let (t1 t2 i1 i2)
255    (if (atom type1)
256        (setq t1 type1 i1 nil)
257        (setq t1 (car type1) i1 (cdr type1)))
258    (if (atom type2)
259        (setq t2 type2 i2 nil)
260        (setq t2 (car type2) i2 (cdr type2)))
261    (cond ((eq t1 'atom)
262           (return-from subtypep (values (eq t2 t) t)))
263          ((eq t2 'atom)
264           (return-from subtypep (cond ((memq t1 '(cons list)) (values nil t))
265                                       ((known-type-p t1) (values t t))
266                                       (t (values nil nil)))))
267          ((eq t1 'member)
268           (dolist (e i1)
269             (unless (typep e type2) (return-from subtypep (values nil t))))
270           (return-from subtypep (values t t)))
271          ((eq t1 'eql)
272           (case t2
273             (EQL
274              (return-from subtypep (values (eql (car i1) (car i2)) t)))
275             (SATISFIES
276              (return-from subtypep (values (funcall (car i2) (car i1)) t)))
277             (t
278              (return-from subtypep (values (typep (car i1) type2) t)))))
279          ((eq t1 'or)
280           (dolist (tt i1)
281             (multiple-value-bind (tv flag) (subtypep tt type2)
282               (unless tv (return-from subtypep (values tv flag)))))
283           (return-from subtypep (values t t)))
284          ((eq t1 'and)
285           (dolist (tt i1)
286             (let ((tv (subtypep tt type2)))
287               (when tv (return-from subtypep (values t t)))))
288           (return-from subtypep (values nil nil)))
289          ((eq t1 'cons)
290           (case t2
291             ((LIST SEQUENCE)
292              (return-from subtypep (values t t)))
293             (CONS
294              (when (and (subtypep (car i1) (car i2))
295                         (subtypep (cadr i1) (cadr i2)))
296                (return-from subtypep (values t t)))))
297           (return-from subtypep (values nil (known-type-p t2))))
298          ((eq t2 'or)
299           (dolist (tt i2)
300             (let ((tv (subtypep type1 tt)))
301               (when tv (return-from subtypep (values t t)))))
302           (return-from subtypep (values nil nil)))
303          ((eq t2 'and)
304           (dolist (tt i2)
305             (multiple-value-bind (tv flag) (subtypep type1 tt)
306               (unless tv (return-from subtypep (values tv flag)))))
307           (return-from subtypep (values t t)))
308          ((null (or i1 i2))
309           (return-from subtypep (values (simple-subtypep t1 t2) t)))
310          ((classp t2)
311           (cond ((eq t2 (find-class t1 nil))
312                  (values t t))
313                 ((and (eq t2 #.(find-class 'array))
314                       (memq t1 '(array simple-array vector simple-vector string
315                                  simple-string simple-base-string bit-vector
316                                  simple-bit-vector)))
317                  (values t t))
318                 ((and (eq t2 #.(find-class 'bit-vector))
319                       (eq t1 'simple-bit-vector))
320                  (values t t))))
321          ((eq t2 'sequence)
322           (cond ((memq t1 '(null cons list))
323                  (values t t))
324                 ((memq t1 '(array simple-array))
325                  (if (and (cdr i1) (consp (cadr i1)) (null (cdadr i1)))
326                      (values t t)
327                      (values nil t)))
328                 (t (values nil (known-type-p t1)))))
329          ((eq t2 'vector)
330           (if (eq t1 'base-string)
331               (if (eq (car i2) 'base-char)
332                   (values t t)
333                   (values nil t))
334               (values nil (known-type-p t2))))
335          ((eq t2 'simple-string)
336           (if (memq t1 '(simple-string simple-base-string))
337               (if (or (null i2) (eq (car i2) '*))
338                   (values t t)
339                   (values nil t))
340               (values nil (known-type-p t2))))
341          ((eq t2 'base-string)
342           (if (eq t1 'vector)
343               (if (eq (car i1) 'base-char)
344                   (values t t)
345                   (values nil t))
346               (values nil (known-type-p t2))))
347          ((eq t2 'string)
348           (if (eq t1 'vector)
349               (if (eq (car i1) 'character)
350                   (values t t)
351                   (values nil t))
352               (values nil (known-type-p t2))))
353          ((eq t1 'float)
354           (if (memq t2 '(float real number))
355               (values (sub-interval-p i1 i2) t)
356               (values nil (known-type-p t2))))
357          ((eq t1 'integer)
358           (cond ((memq t2 '(integer rational real number))
359                  (values (sub-interval-p i1 i2) t))
360                 ((eq t2 'bignum)
361                  (values
362                   (or (sub-interval-p i1 (list '* (list most-negative-fixnum)))
363                       (sub-interval-p i1 (list (list most-positive-fixnum) '*)))
364                   t))
365                 (t
366                   (values nil (known-type-p t2)))))
367          ((eq t1 'rational)
368           (if (memq t2 '(rational real number))
369               (values (sub-interval-p i1 i2) t)
370               (values nil (known-type-p t2))))
371          ((eq t1 'real)
372           (if (memq t2 '(real number))
373               (values (sub-interval-p i1 i2) t)
374               (values nil (known-type-p t2))))
375          ((memq t1 '(string simple-string base-string
376                      simple-base-string))
377           (cond ((eq t2 'string)
378                  (if (or (null i2) (eq (car i2) '*))
379                      (values t t)
380                      (values nil t)))
381                 (t
382                  (values nil (known-type-p t2)))))
383          (t
384           (values nil nil)))))
385
386(when (fboundp 'jvm::jvm-compile)
387  (mapcar #'jvm::jvm-compile '(subtypep-normalize-type
388                               sub-interval-p
389                               simple-subtypep
390                               subtypep)))
Note: See TracBrowser for help on using the repository browser.