Function: comp--simple-cstr-to-type-spec
comp--simple-cstr-to-type-spec is a byte-compiled function defined in
comp-cstr.el.gz.
Signature
(comp--simple-cstr-to-type-spec CSTR)
Documentation
Given a non comp-cstr-f CSTR return its type specifier.
Source Code
;; Defined in /usr/src/emacs/lisp/emacs-lisp/comp-cstr.el.gz
(defun comp--simple-cstr-to-type-spec (cstr)
"Given a non comp-cstr-f CSTR return its type specifier."
(let ((valset (comp-cstr-valset cstr))
(typeset (comp-cstr-typeset cstr))
(range (comp-cstr-range cstr))
(negated (comp-cstr-neg cstr)))
(when valset
(when (memq nil valset)
(if (memq t valset)
(progn
;; t and nil are values, convert into `boolean'.
(push 'boolean typeset)
(setf valset (remove t (remove nil valset))))
;; Only nil is a value, convert it into a `null' type specifier.
(setf valset (remove nil valset))
(push 'null typeset))))
;; Form proper integer type specifiers.
(setf range (cl-loop for (l . h) in range
for low = (if (integerp l) l '*)
for high = (if (integerp h) h '*)
if (and (eq low '*) (eq high '*))
collect 'integer
else
collect `(integer ,low , high))
valset (cl-remove-duplicates valset))
;; Form the final type specifier.
(let* ((types-ints (append typeset range))
(res (cond
((and types-ints valset)
`((member ,@valset) ,@types-ints))
(types-ints types-ints)
(valset `(member ,@valset))
(t
;; Empty type specifier
nil)))
(final
(pcase res
((or `(member . ,rest)
`(integer ,(pred comp-star-or-num-p)
,(pred comp-star-or-num-p)))
(if rest
res
(car res)))
((pred atom) res)
(`(,_first . ,rest)
(if rest
`(or ,@res)
(car res))))))
(if negated
`(not ,final)
final))))