Get the kind (tag) of a literal-type structure.
(literal-type-kind x) → kind
Function:
(defun literal-type-kind$inline (x) (declare (xargs :guard (literal-typep x))) (let ((__function__ 'literal-type-kind)) (declare (ignorable __function__)) (mbe :logic (cond ((or (atom x) (eq (car x) :boolean)) :boolean) ((eq (car x) :unsigned) :unsigned) ((eq (car x) :signed) :signed) ((eq (car x) :field) :field) ((eq (car x) :group) :group) ((eq (car x) :scalar) :scalar) ((eq (car x) :address) :address) (t :string)) :exec (car x))))
Theorem:
(defthm literal-type-kind-possibilities (or (equal (literal-type-kind x) :boolean) (equal (literal-type-kind x) :unsigned) (equal (literal-type-kind x) :signed) (equal (literal-type-kind x) :field) (equal (literal-type-kind x) :group) (equal (literal-type-kind x) :scalar) (equal (literal-type-kind x) :address) (equal (literal-type-kind x) :string)) :rule-classes ((:forward-chaining :trigger-terms ((literal-type-kind x)))))