Parse a group
(parse-alt-rest-comp input) → (mv error? tree? rest-input)
The linear rules below are used in the guard verification proof.
Function:
(defun parse-alt-rest-comp (input) (declare (xargs :guard (nat-listp input))) (seq input (trees1 := (parse-*cwsp input)) (tree-slash := (parse-ichar #\/ input)) (trees2 := (parse-*cwsp input)) (tree-conc := (parse-concatenation input)) (return (make-tree-nonleaf :rulename? nil :branches (list trees1 (list tree-slash) trees2 (list tree-conc))))))
Theorem:
(defthm len-of-parse-alt-rest-comp-linear-1 (<= (len (mv-nth 2 (parse-alt-rest-comp input))) (len input)) :rule-classes :linear)
Theorem:
(defthm len-of-parse-alt-rest-comp-linear-2 (implies (not (mv-nth 0 (parse-alt-rest-comp input))) (< (len (mv-nth 2 (parse-alt-rest-comp input))) (len input))) :rule-classes :linear)