Get the kind (tag) of a primitive-type structure.
(primitive-type-kind x) → kind
Function:
(defun primitive-type-kind$inline (x) (declare (xargs :guard (primitive-typep x))) (let ((__function__ 'primitive-type-kind)) (declare (ignorable __function__)) (mbe :logic (cond ((or (atom x) (eq (car x) :boolean)) :boolean) ((eq (car x) :char) :char) ((eq (car x) :byte) :byte) ((eq (car x) :short) :short) ((eq (car x) :int) :int) ((eq (car x) :long) :long) ((eq (car x) :float) :float) (t :double)) :exec (car x))))
Theorem:
(defthm primitive-type-kind-possibilities (or (equal (primitive-type-kind x) :boolean) (equal (primitive-type-kind x) :char) (equal (primitive-type-kind x) :byte) (equal (primitive-type-kind x) :short) (equal (primitive-type-kind x) :int) (equal (primitive-type-kind x) :long) (equal (primitive-type-kind x) :float) (equal (primitive-type-kind x) :double)) :rule-classes ((:forward-chaining :trigger-terms ((primitive-type-kind x)))))