(parse-demo-bundle getopt::longnames args getopt::acc getopt::seen) → (mv getopt::errmsg getopt::acc getopt::seen rest)
Function:
(defun parse-demo-bundle (getopt::longnames args getopt::acc getopt::seen) (declare (xargs :guard (and (string-listp getopt::longnames) (string-listp args) (demo-p getopt::acc) (string-listp getopt::seen)))) (let ((acl2::__function__ 'parse-demo-bundle)) (declare (ignorable acl2::__function__)) (b* (((when (atom getopt::longnames)) (mv nil getopt::acc getopt::seen args)) ((mv getopt::err getopt::acc rest) (parse-demo-long (car getopt::longnames) nil args getopt::acc getopt::seen)) ((when getopt::err) (mv getopt::err getopt::acc getopt::seen rest)) (getopt::seen (cons (car getopt::longnames) getopt::seen))) (parse-demo-bundle (cdr getopt::longnames) rest getopt::acc getopt::seen))))
Theorem:
(defthm demo-p-of-parse-demo-bundle.acc (implies (force (demo-p getopt::acc)) (b* (((mv getopt::?errmsg getopt::?acc getopt::?seen common-lisp::?rest) (parse-demo-bundle getopt::longnames args getopt::acc getopt::seen))) (demo-p getopt::acc))) :rule-classes :rewrite)
Theorem:
(defthm string-listp-of-parse-demo-bundle.seen (implies (and (force (string-listp getopt::longnames)) (force (string-listp getopt::seen))) (b* (((mv getopt::?errmsg getopt::?acc getopt::?seen common-lisp::?rest) (parse-demo-bundle getopt::longnames args getopt::acc getopt::seen))) (string-listp getopt::seen))) :rule-classes :rewrite)
Theorem:
(defthm string-listp-of-parse-demo-bundle.rest (implies (force (string-listp args)) (b* (((mv getopt::?errmsg getopt::?acc getopt::?seen common-lisp::?rest) (parse-demo-bundle getopt::longnames args getopt::acc getopt::seen))) (string-listp rest))) :rule-classes :rewrite)
Theorem:
(defthm parse-demo-bundle-makes-progress (<= (len (mv-nth 3 (parse-demo-bundle getopt::longnames args getopt::acc getopt::seen))) (len args)) :rule-classes ((:rewrite) (:linear)))