X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcode%2Fpred.lisp;h=3402e204a0f12d9af8f29d8206085f594d830e60;hb=cd13034f9415f64cdaa05893a4ac5ff1e95c97bd;hp=dd6ccb2dd196a2641784873307fbfecb44ed7a3b;hpb=22b819c0cd0ca0ea5be52ba280b9e9e0b8e86210;p=sbcl.git diff --git a/src/code/pred.lisp b/src/code/pred.lisp index dd6ccb2..3402e20 100644 --- a/src/code/pred.lisp +++ b/src/code/pred.lisp @@ -47,6 +47,7 @@ (def-type-predicate-wrapper arrayp) (def-type-predicate-wrapper atom) (def-type-predicate-wrapper base-char-p) + (def-type-predicate-wrapper base-string-p) (def-type-predicate-wrapper bignump) (def-type-predicate-wrapper bit-vector-p) (def-type-predicate-wrapper characterp) @@ -79,6 +80,7 @@ (def-type-predicate-wrapper short-float-p) (def-type-predicate-wrapper sb!kernel:simple-array-p) (def-type-predicate-wrapper simple-bit-vector-p) + (def-type-predicate-wrapper simple-base-string-p) (def-type-predicate-wrapper simple-string-p) (def-type-predicate-wrapper simple-vector-p) (def-type-predicate-wrapper single-float-p) @@ -90,6 +92,7 @@ (def-type-predicate-wrapper vectorp) (def-type-predicate-wrapper unsigned-byte-32-p) (def-type-predicate-wrapper signed-byte-32-p) + (def-type-predicate-wrapper simple-array-nil-p) (def-type-predicate-wrapper simple-array-unsigned-byte-2-p) (def-type-predicate-wrapper simple-array-unsigned-byte-4-p) (def-type-predicate-wrapper simple-array-unsigned-byte-8-p) @@ -113,19 +116,35 @@ (defun type-of (object) #!+sb-doc "Return the type of OBJECT." - (if (typep object '(or function array complex)) - (type-specifier (ctype-of object)) - (let* ((classoid (layout-classoid (layout-of object))) - (name (classoid-name classoid))) - (if (typep object 'instance) - (case name - (sb!alien-internals:alien-value - `(sb!alien:alien - ,(sb!alien-internals:unparse-alien-type - (sb!alien-internals:alien-value-type object)))) - (t - (classoid-proper-name classoid))) - name)))) + (typecase object + (fixnum + (cond + ((<= 0 object 1) 'bit) + ((< object 0) 'fixnum) + (t '(integer 0 #.sb!xc:most-positive-fixnum)))) + (integer + (if (>= object 0) + '(integer #.(1+ sb!xc:most-positive-fixnum)) + 'bignum)) + (standard-char 'standard-char) + ((member t) 'boolean) + (keyword 'keyword) + ((or array complex) (type-specifier (ctype-of object))) + (t + (let* ((classoid (layout-classoid (layout-of object))) + (name (classoid-name classoid))) + (if (typep object 'instance) + (case name + (sb!alien-internals:alien-value + `(sb!alien:alien + ,(sb!alien-internals:unparse-alien-type + (sb!alien-internals:alien-value-type object)))) + (t + (let ((pname (classoid-proper-name classoid))) + (if (classoid-p pname) + (classoid-pcl-class pname) + pname)))) + name))))) ;;;; equality predicates