Check if the given token is present and has the given rule name as root.
(check-token-root rulename token) → tree
If the check is successful, return the token. Using this function ensures that we get a CST tree or reserr.
Function:
(defun check-token-root (rulename token) (declare (xargs :guard (and (stringp rulename) (abnf::tree-optionp token)))) (let ((__function__ 'check-token-root)) (declare (ignorable __function__)) (abnf::tree-option-case token :some (if (token-rootp rulename token.val) token.val (reserrf (list :required (str-fix rulename) :found token.val))) :none (reserrf (list :required (str-fix rulename) :found nil)))))
Theorem:
(defthm tree-resultp-of-check-token-root (b* ((tree (check-token-root rulename token))) (abnf::tree-resultp tree)) :rule-classes :rewrite)
Theorem:
(defthm check-token-root-of-str-fix-rulename (equal (check-token-root (str-fix rulename) token) (check-token-root rulename token)))
Theorem:
(defthm check-token-root-streqv-congruence-on-rulename (implies (acl2::streqv rulename rulename-equiv) (equal (check-token-root rulename token) (check-token-root rulename-equiv token))) :rule-classes :congruence)
Theorem:
(defthm check-token-root-of-tree-option-fix-token (equal (check-token-root rulename (abnf::tree-option-fix token)) (check-token-root rulename token)))
Theorem:
(defthm check-token-root-tree-option-equiv-congruence-on-token (implies (abnf::tree-option-equiv token token-equiv) (equal (check-token-root rulename token) (check-token-root rulename token-equiv))) :rule-classes :congruence)