Get a host-Lisp specific string describing what kind of Common Lisp implementation this is.
In the logic this function reads from the ACL2 oracle. In the
execution, we call the Common Lisp function
Note that the Common Lisp
Function:
(defun lisp-type-fn (state) (declare (xargs :stobjs (state))) (declare (xargs :guard t)) (let ((__function__ 'lisp-type)) (declare (ignorable __function__)) (b* (((mv err val state) (read-acl2-oracle state)) (description (if (and (not err) (stringp val)) val ""))) (mv description state))))
Theorem:
(defthm stringp-of-lisp-type.description (b* (((mv ?description acl2::?state) (lisp-type-fn state))) (stringp description)) :rule-classes :type-prescription)
Theorem:
(defthm state-p1-of-lisp-type.state (implies (force (state-p1 state)) (b* (((mv ?description acl2::?state) (lisp-type-fn state))) (state-p1 state))) :rule-classes :rewrite)