Gather the names of all design elements that transitively depend on particular descriptions.
(vl-dependent-elements-transitive subs design) → superiors
Function:
(defun vl-dependent-elements-transitive (subs design) (declare (xargs :guard (and (string-listp subs) (vl-design-p design)))) (let ((__function__ 'vl-dependent-elements-transitive)) (declare (ignorable __function__)) (depgraph::transdeps (string-list-fix subs) (vl-design-upgraph design))))
Theorem:
(defthm return-type-of-vl-dependent-elements-transitive (b* ((superiors (vl-dependent-elements-transitive subs design))) (and (string-listp superiors) (setp superiors))) :rule-classes :rewrite)
Theorem:
(defthm vl-dependent-elements-transitive-of-string-list-fix-subs (equal (vl-dependent-elements-transitive (string-list-fix subs) design) (vl-dependent-elements-transitive subs design)))
Theorem:
(defthm vl-dependent-elements-transitive-string-list-equiv-congruence-on-subs (implies (str::string-list-equiv subs subs-equiv) (equal (vl-dependent-elements-transitive subs design) (vl-dependent-elements-transitive subs-equiv design))) :rule-classes :congruence)
Theorem:
(defthm vl-dependent-elements-transitive-of-vl-design-fix-design (equal (vl-dependent-elements-transitive subs (vl-design-fix design)) (vl-dependent-elements-transitive subs design)))
Theorem:
(defthm vl-dependent-elements-transitive-vl-design-equiv-congruence-on-design (implies (vl-design-equiv design design-equiv) (equal (vl-dependent-elements-transitive subs design) (vl-dependent-elements-transitive subs design-equiv))) :rule-classes :congruence)