Attempts to eat a
(parse-break-statement tokens) → (mv result-ast tokens-after-statement)
Function:
(defun parse-break-statement (tokens) (declare (xargs :guard (abnf::tree-listp tokens))) (let ((__function__ 'parse-break-statement)) (declare (ignorable __function__)) (b* (((mv statement-or-nil tokens-after-statement) (parse-keyword "break" tokens))) (if (or (not (statementp statement-or-nil)) (reserrp tokens-after-statement)) (mv (reserrf "no break statement here") (abnf::tree-list-fix tokens)) (mv statement-or-nil (abnf::tree-list-fix tokens-after-statement))))))
Theorem:
(defthm statement-resultp-of-parse-break-statement.result-ast (b* (((mv ?result-ast ?tokens-after-statement) (parse-break-statement tokens))) (statement-resultp result-ast)) :rule-classes :rewrite)
Theorem:
(defthm tree-listp-of-parse-break-statement.tokens-after-statement (b* (((mv ?result-ast ?tokens-after-statement) (parse-break-statement tokens))) (abnf::tree-listp tokens-after-statement)) :rule-classes :rewrite)
Theorem:
(defthm len-of-parse-break-statement-< (b* (((mv ?result-ast ?tokens-after-statement) (parse-break-statement tokens))) (implies (not (reserrp result-ast)) (< (len tokens-after-statement) (len tokens)))) :rule-classes :linear)