(vl-create-unparameterized-class x name final-paramdecls elabindex ledger &key (config 'config)) → (mv new-class keylist new-elabindex ledger)
Function:
(defun vl-create-unparameterized-class-fn (x name final-paramdecls elabindex ledger config) (declare (xargs :stobjs (elabindex))) (declare (xargs :guard (and (vl-class-p x) (stringp name) (vl-paramdecllist-p final-paramdecls) (vl-unparam-ledger-p ledger) (vl-simpconfig-p config)))) (let ((__function__ 'vl-create-unparameterized-class)) (declare (ignorable __function__)) (b* ((name (string-fix name)) (x (change-vl-class x :name name :paramdecls final-paramdecls)) ((vl-class x)) (warnings x.warnings) (blob (vl-class->genblob x)) ((wmv warnings keylist new-blob elabindex ledger :ctx name) (vl-genblob-resolve blob elabindex ledger nil)) (class (vl-genblob->class new-blob x)) (class (change-vl-class class :warnings warnings))) (mv class keylist elabindex ledger))))
Theorem:
(defthm vl-class-p-of-vl-create-unparameterized-class.new-class (b* (((mv ?new-class ?keylist ?new-elabindex ?ledger) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config))) (vl-class-p new-class)) :rule-classes :rewrite)
Theorem:
(defthm vl-unparam-instkeylist-p-of-vl-create-unparameterized-class.keylist (b* (((mv ?new-class ?keylist ?new-elabindex ?ledger) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config))) (vl-unparam-instkeylist-p keylist)) :rule-classes :rewrite)
Theorem:
(defthm vl-unparam-ledger-p-of-vl-create-unparameterized-class.ledger (b* (((mv ?new-class ?keylist ?new-elabindex ?ledger) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config))) (vl-unparam-ledger-p ledger)) :rule-classes :rewrite)
Theorem:
(defthm vl-create-unparameterized-class-fn-of-vl-class-fix-x (equal (vl-create-unparameterized-class-fn (vl-class-fix x) name final-paramdecls elabindex ledger config) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config)))
Theorem:
(defthm vl-create-unparameterized-class-fn-vl-class-equiv-congruence-on-x (implies (vl-class-equiv x x-equiv) (equal (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config) (vl-create-unparameterized-class-fn x-equiv name final-paramdecls elabindex ledger config))) :rule-classes :congruence)
Theorem:
(defthm vl-create-unparameterized-class-fn-of-str-fix-name (equal (vl-create-unparameterized-class-fn x (str-fix name) final-paramdecls elabindex ledger config) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config)))
Theorem:
(defthm vl-create-unparameterized-class-fn-streqv-congruence-on-name (implies (streqv name name-equiv) (equal (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config) (vl-create-unparameterized-class-fn x name-equiv final-paramdecls elabindex ledger config))) :rule-classes :congruence)
Theorem:
(defthm vl-create-unparameterized-class-fn-of-vl-paramdecllist-fix-final-paramdecls (equal (vl-create-unparameterized-class-fn x name (vl-paramdecllist-fix final-paramdecls) elabindex ledger config) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config)))
Theorem:
(defthm vl-create-unparameterized-class-fn-vl-paramdecllist-equiv-congruence-on-final-paramdecls (implies (vl-paramdecllist-equiv final-paramdecls final-paramdecls-equiv) (equal (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config) (vl-create-unparameterized-class-fn x name final-paramdecls-equiv elabindex ledger config))) :rule-classes :congruence)
Theorem:
(defthm vl-create-unparameterized-class-fn-of-vl-unparam-ledger-fix-ledger (equal (vl-create-unparameterized-class-fn x name final-paramdecls elabindex (vl-unparam-ledger-fix ledger) config) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config)))
Theorem:
(defthm vl-create-unparameterized-class-fn-vl-unparam-ledger-equiv-congruence-on-ledger (implies (vl-unparam-ledger-equiv ledger ledger-equiv) (equal (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger-equiv config))) :rule-classes :congruence)
Theorem:
(defthm vl-create-unparameterized-class-fn-of-vl-simpconfig-fix-config (equal (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger (vl-simpconfig-fix config)) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config)))
Theorem:
(defthm vl-create-unparameterized-class-fn-vl-simpconfig-equiv-congruence-on-config (implies (vl-simpconfig-equiv config config-equiv) (equal (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config) (vl-create-unparameterized-class-fn x name final-paramdecls elabindex ledger config-equiv))) :rule-classes :congruence)