Gather the names of every module and interface ever instanced in a module list or used in an interface port.
(vl-modulelist-everinstanced x) → names
The returned list typically will contain a lot of duplicates. This is fairly expensive, requiring a cons for every single module instance. We optimize it to avoid the construction of intermediate lists and to use nrev.
Function:
(defun vl-modulelist-everinstanced (x) (declare (xargs :guard (vl-modulelist-p x))) (let ((__function__ 'vl-modulelist-everinstanced)) (declare (ignorable __function__)) (mbe :logic (b* (((when (atom x)) nil) (modinsts1 (vl-module->flatten-modinsts (car x))) (ifports1 (vl-module->ifports (car x)))) (append (vl-modinstlist->modnames modinsts1) (vl-interfaceportlist->ifnames ifports1) (vl-modulelist-everinstanced (cdr x)))) :exec (if (atom x) nil (with-local-nrev (vl-modulelist-everinstanced-nrev x nrev))))))
Theorem:
(defthm string-listp-of-vl-modulelist-everinstanced (b* ((names (vl-modulelist-everinstanced x))) (string-listp names)) :rule-classes :rewrite)
Theorem:
(defthm vl-modulelist-everinstanced-nrev-removal (equal (vl-modulelist-everinstanced-nrev x nrev) (append nrev (vl-modulelist-everinstanced x))))
Theorem:
(defthm vl-modulelist-everinstanced-of-vl-modulelist-fix-x (equal (vl-modulelist-everinstanced (vl-modulelist-fix x)) (vl-modulelist-everinstanced x)))
Theorem:
(defthm vl-modulelist-everinstanced-vl-modulelist-equiv-congruence-on-x (implies (vl-modulelist-equiv x x-equiv) (equal (vl-modulelist-everinstanced x) (vl-modulelist-everinstanced x-equiv))) :rule-classes :congruence)