Convert the first character of a character list to lower case.
(downcase-first-charlist x) → downcased
Function:
(defun downcase-first-charlist (x) (declare (xargs :guard (character-listp x))) (let ((acl2::__function__ 'downcase-first-charlist)) (declare (ignorable acl2::__function__)) (mbe :logic (if (atom x) nil (cons (downcase-char (car x)) (make-character-list (cdr x)))) :exec (cond ((atom x) nil) ((up-alpha-p (car x)) (cons (downcase-char (car x)) (cdr x))) (t x)))))
Theorem:
(defthm character-listp-of-downcase-first-charlist (b* ((downcased (downcase-first-charlist x))) (character-listp downcased)) :rule-classes :rewrite)
Theorem:
(defthm charlisteqv-implies-equal-downcase-first-charlist-1 (implies (charlisteqv x x-equiv) (equal (downcase-first-charlist x) (downcase-first-charlist x-equiv))) :rule-classes (:congruence))
Theorem:
(defthm icharlisteqv-implies-icharlisteqv-downcase-first-charlist-1 (implies (icharlisteqv x x-equiv) (icharlisteqv (downcase-first-charlist x) (downcase-first-charlist x-equiv))) :rule-classes (:congruence))
Theorem:
(defthm downcase-first-charlist-when-atom (implies (atom x) (equal (downcase-first-charlist x) nil)))
Theorem:
(defthm len-of-downcase-first-charlist (equal (len (downcase-first-charlist x)) (len x)))
Theorem:
(defthm consp-of-downcase-first-charlist (equal (consp (downcase-first-charlist x)) (consp x)))
Theorem:
(defthm downcase-first-charlist-under-iff (iff (downcase-first-charlist x) (consp x)))