Tail recursive implementation.
(vl-lex-main-exec echars nrev st warnings) → (mv successp nrev warnings)
Function:
(defun vl-lex-main-exec (echars nrev st warnings) (declare (xargs :stobjs (nrev))) (declare (xargs :guard (and (vl-echarlist-p echars) (vl-tokenlist-p (nrev-copy nrev)) (vl-lexstate-p st) (vl-warninglist-p warnings)))) (let ((__function__ 'vl-lex-main-exec)) (declare (ignorable __function__)) (b* ((nrev (nrev-fix nrev)) ((when (atom echars)) (mv t nrev (ok))) ((mv tok remainder warnings) (vl-lex-token echars st warnings)) ((when tok) (let ((nrev (nrev-push tok nrev))) (vl-lex-main-exec remainder nrev st warnings))) (- (cw "About to cause an error.~%")) (prev-chars (nrev-copy nrev)) (prev-chop (nthcdr (nfix (- (length prev-chars) 30)) prev-chars)) (prev-str (vl-echarlist->string (vl-tokenlist->etext prev-chop)))) (mv (cw "Lexer error (~s0): unable to identify a valid token.~%~ [[ Previous ]]: ~s1~%~ [[ Remaining ]]: ~s2~%" (vl-location-string (vl-echar->loc (car echars))) prev-str (vl-echarlist->string (first-n (min 30 (len echars)) echars))) nrev warnings))))
Theorem:
(defthm vl-warninglist-p-of-vl-lex-main-exec.warnings (b* (((mv ?successp acl2::?nrev ?warnings) (vl-lex-main-exec echars nrev st warnings))) (vl-warninglist-p warnings)) :rule-classes :rewrite)