Collect paths that are
(directories paths &key (state 'state)) → (mv err ans new-state)
Function:
(defun directories-exec-fn (paths acc state) (declare (xargs :stobjs (state))) (declare (xargs :guard (string-listp paths))) "Tail recursive version for execution." (let ((__function__ 'directories-exec)) (declare (ignorable __function__)) (b* (((when (atom paths)) (mv nil acc state)) ((mv err directory-p state) (directory-p (car paths))) ((when err) (mv err acc state)) (acc (if directory-p (cons (car paths) acc) acc))) (directories-exec (cdr paths) acc))))
Function:
(defun directories-fn (paths state) (declare (xargs :stobjs (state))) (declare (xargs :guard (string-listp paths))) (let ((__function__ 'directories)) (declare (ignorable __function__)) (mbe :logic (b* (((when (atom paths)) (mv nil nil state)) ((mv err directory-p state) (directory-p (car paths))) ((when err) (mv err nil state)) ((mv err rest state) (directories (cdr paths))) (ans (if directory-p (cons (car paths) rest) rest))) (mv err ans state)) :exec (b* (((mv err acc state) (directories-exec paths nil))) (mv err (reverse acc) state)))))
Theorem:
(defthm string-listp-of-directories.ans (implies (string-listp paths) (b* (((mv ?err ?ans ?new-state) (directories-fn paths state))) (string-listp ans))) :rule-classes :rewrite)
Theorem:
(defthm state-p1-of-directories.new-state (implies (force (state-p1 state)) (b* (((mv ?err ?ans ?new-state) (directories-fn paths state))) (state-p1 new-state))) :rule-classes :rewrite)
Theorem:
(defthm directories-exec-removal (equal (directories-exec paths acc) (b* (((mv err ans state) (directories paths))) (mv err (revappend ans acc) state))))
Theorem:
(defthm true-listp-of-directories (true-listp (mv-nth 1 (directories paths))) :rule-classes :type-prescription)
Theorem:
(defthm w-state-of-directories (b* (((mv ?err ?ans ?new-state) (directories-fn paths state))) (equal (w new-state) (w state))))