Convert most of a module into a vl-genblob.
(vl-module->genblob x) → genblob
Certain fields of a vl-module aren't also fields of a vl-genblob, for instance, a genblob doesn't have warnings, a name, location information, etc.
But aside from these fields, most of a module can be extracted and turned into a genblob for easy processing. After processing the blob, the updated fields can be reinstalled into the module using vl-genblob->module.
Function:
(defun vl-module->genblob (x) (declare (xargs :guard (vl-module-p x))) (let ((__function__ 'vl-module->genblob)) (declare (ignorable __function__)) (b* (((vl-module x))) (make-vl-genblob :name x.name :generates x.generates :ports x.ports :portdecls x.portdecls :assigns x.assigns :aliases x.aliases :vardecls x.vardecls :paramdecls x.paramdecls :fundecls x.fundecls :taskdecls x.taskdecls :modinsts x.modinsts :gateinsts x.gateinsts :alwayses x.alwayses :initials x.initials :imports x.imports :genvars x.genvars))))
Theorem:
(defthm vl-genblob-p-of-vl-module->genblob (b* ((genblob (vl-module->genblob x))) (vl-genblob-p genblob)) :rule-classes :rewrite)
Theorem:
(defthm vl-module->genblob-of-vl-module-fix-x (equal (vl-module->genblob (vl-module-fix x)) (vl-module->genblob x)))
Theorem:
(defthm vl-module->genblob-vl-module-equiv-congruence-on-x (implies (vl-module-equiv x x-equiv) (equal (vl-module->genblob x) (vl-module->genblob x-equiv))) :rule-classes :congruence)