Cause an error if a symbol cannot be the name of a new event.
(ensure-symbol-new-event-name symb description error-erp error-val ctx state) → (mv erp val state)
The symbol must not be in the main Lisp package, must not be a keyword, and must not be already in use.
Function:
(defun ensure-symbol-new-event-name (symb description error-erp error-val ctx state) (declare (xargs :stobjs (state))) (declare (xargs :guard (and (symbolp symb) (msgp description)))) (b* (((when (equal (symbol-package-name symb) *main-lisp-package-name*)) (er-soft+ ctx error-erp error-val "~@0 must not be in the main Lisp package." description)) ((when (keywordp symb)) (er-soft+ ctx error-erp error-val "~@0 must not be a keyword." description)) ((when (logical-namep symb (w state))) (er-soft+ ctx error-erp error-val "~@0 is already in use." description))) (value nil)))
Theorem:
(defthm return-type-of-ensure-symbol-new-event-name.erp (b* (((mv ?erp ?val ?state) (ensure-symbol-new-event-name symb description error-erp error-val ctx state))) (implies erp (equal erp error-erp))) :rule-classes :rewrite)
Theorem:
(defthm return-type-of-ensure-symbol-new-event-name.val (b* (((mv ?erp ?val ?state) (ensure-symbol-new-event-name symb description error-erp error-val ctx state))) (and (implies erp (equal val error-val)) (implies (and (not erp) error-erp) (not val)))) :rule-classes :rewrite)