Check if an ABNF tree is a leaf tree whose natural numbers case-insensitively match a string of ACL2 characters.
(check-tree-ichars tree chars) → pass
Function:
(defun check-tree-ichars (tree chars) (declare (xargs :guard (and (abnf::treep tree) (stringp chars)))) (let ((__function__ 'check-tree-ichars)) (declare (ignorable __function__)) (b* (((okf nats) (check-tree-leafterm tree))) (if (abnf::nats-match-insensitive-chars-p nats (acl2::explode chars)) :pass (reserrf (list :required :ichars (str-fix chars) :found (tree-info-for-error tree)))))))
Theorem:
(defthm pass-resultp-of-check-tree-ichars (b* ((pass (check-tree-ichars tree chars))) (pass-resultp pass)) :rule-classes :rewrite)
Theorem:
(defthm check-tree-ichars-of-tree-fix-tree (equal (check-tree-ichars (abnf::tree-fix tree) chars) (check-tree-ichars tree chars)))
Theorem:
(defthm check-tree-ichars-tree-equiv-congruence-on-tree (implies (abnf::tree-equiv tree tree-equiv) (equal (check-tree-ichars tree chars) (check-tree-ichars tree-equiv chars))) :rule-classes :congruence)
Theorem:
(defthm check-tree-ichars-of-str-fix-chars (equal (check-tree-ichars tree (str-fix chars)) (check-tree-ichars tree chars)))
Theorem:
(defthm check-tree-ichars-streqv-congruence-on-chars (implies (acl2::streqv chars chars-equiv) (equal (check-tree-ichars tree chars) (check-tree-ichars tree chars-equiv))) :rule-classes :congruence)