Get the kind (tag) of a message structure.
(message-kind x) → kind
Function:
(defun message-kind$inline (x) (declare (xargs :guard (messagep x))) (let ((__function__ 'message-kind)) (declare (ignorable __function__)) (mbe :logic (cond ((or (atom x) (eq (car x) :proposal)) :proposal) ((eq (car x) :endorsement) :endorsement) (t :certificate)) :exec (car x))))
Theorem:
(defthm message-kind-possibilities (or (equal (message-kind x) :proposal) (equal (message-kind x) :endorsement) (equal (message-kind x) :certificate)) :rule-classes ((:forward-chaining :trigger-terms ((message-kind x)))))