Partition a list of vl-fundecls by name.
(vl-filter-fundecls names x) → (mv named unnamed)
The only reason to use this function is efficiency.
Logically,
Function:
(defun vl-filter-fundecls (names x) (declare (xargs :guard (and (string-listp names) (vl-fundecllist-p x)))) (let ((__function__ 'vl-filter-fundecls)) (declare (ignorable __function__)) (mbe :logic (mv (vl-keep-fundecls names x) (vl-delete-fundecls names x)) :exec (b* (((when (atom names)) (mv nil (list-fix x))) ((when (atom x)) (mv nil nil)) (fal (make-lookup-alist names)) ((local-stobjs nrev nrev2) (mv yes no nrev nrev2)) ((mv nrev nrev2) (vl-fast-filter-fundecls names fal x nrev nrev2)) (- (fast-alist-free fal)) ((mv yes nrev) (nrev-finish nrev)) ((mv no nrev2) (nrev-finish nrev2))) (mv yes no nrev nrev2)))))
Theorem:
(defthm vl-fast-filter-fundecls-removal-0 (equal (mv-nth 0 (vl-fast-filter-fundecls names fal x nrev nrev2)) (append nrev (vl-keep-fundecls names x))))
Theorem:
(defthm vl-fast-filter-fundecls-removal-1 (equal (mv-nth 1 (vl-fast-filter-fundecls names fal x nrev nrev2)) (append nrev2 (vl-delete-fundecls names x))))