Lifting of nat-match-insensitive-char-p to lists.
(nats-match-insensitive-chars-p nats chars) → yes/no
Function:
(defun nats-match-insensitive-chars-p (nats chars) (declare (xargs :guard (and (nat-listp nats) (character-listp chars)))) (cond ((endp nats) (endp chars)) (t (and (consp chars) (nat-match-insensitive-char-p (car nats) (car chars)) (nats-match-insensitive-chars-p (cdr nats) (cdr chars))))))
Theorem:
(defthm booleanp-of-nats-match-insensitive-chars-p (b* ((yes/no (nats-match-insensitive-chars-p nats chars))) (booleanp yes/no)) :rule-classes :rewrite)
Theorem:
(defthm nats-match-insensitive-chars-p-when-atom-chars (implies (atom chars) (equal (nats-match-insensitive-chars-p nats chars) (not (consp nats)))))
Theorem:
(defthm nats-match-insensitive-chars-p-of-cons-chars (equal (nats-match-insensitive-chars-p nats (cons char chars)) (and (consp nats) (nat-match-insensitive-char-p (car nats) char) (nats-match-insensitive-chars-p (cdr nats) chars))))
Theorem:
(defthm nats-match-insensitive-chars-p-of-nat-list-fix-nats (equal (nats-match-insensitive-chars-p (nat-list-fix nats) chars) (nats-match-insensitive-chars-p nats chars)))
Theorem:
(defthm nats-match-insensitive-chars-p-nat-list-equiv-congruence-on-nats (implies (acl2::nat-list-equiv nats nats-equiv) (equal (nats-match-insensitive-chars-p nats chars) (nats-match-insensitive-chars-p nats-equiv chars))) :rule-classes :congruence)
Theorem:
(defthm nats-match-insensitive-chars-p-of-make-character-list-chars (equal (nats-match-insensitive-chars-p nats (make-character-list chars)) (nats-match-insensitive-chars-p nats chars)))
Theorem:
(defthm nats-match-insensitive-chars-p-charlisteqv-congruence-on-chars (implies (str::charlisteqv chars chars-equiv) (equal (nats-match-insensitive-chars-p nats chars) (nats-match-insensitive-chars-p nats chars-equiv))) :rule-classes :congruence)