Collect any leading hex digit characters from the start of a character list.
(take-leading-hex-digit-chars x) → head
Function:
(defun take-leading-hex-digit-chars (x) (declare (xargs :guard t)) (let ((acl2::__function__ 'take-leading-hex-digit-chars)) (declare (ignorable acl2::__function__)) (cond ((atom x) nil) ((hex-digit-char-p (car x)) (cons (car x) (take-leading-hex-digit-chars (cdr x)))) (t nil))))
Theorem:
(defthm character-listp-of-take-leading-hex-digit-chars (implies (character-listp x) (b* ((head (take-leading-hex-digit-chars x))) (character-listp head))) :rule-classes :rewrite)
Theorem:
(defthm charlisteqv-implies-equal-take-leading-hex-digit-chars-1 (implies (charlisteqv x x-equiv) (equal (take-leading-hex-digit-chars x) (take-leading-hex-digit-chars x-equiv))) :rule-classes (:congruence))
Theorem:
(defthm icharlisteqv-implies-icharlisteqv-take-leading-hex-digit-chars-1 (implies (icharlisteqv x x-equiv) (icharlisteqv (take-leading-hex-digit-chars x) (take-leading-hex-digit-chars x-equiv))) :rule-classes (:congruence))
Theorem:
(defthm hex-digit-char-list*p-of-take-leading-hex-digit-chars (hex-digit-char-list*p (take-leading-hex-digit-chars x)))
Theorem:
(defthm bound-of-len-of-take-leading-hex-digit-chars (<= (len (take-leading-hex-digit-chars x)) (len x)) :rule-classes :linear)
Theorem:
(defthm equal-of-take-leading-hex-digit-chars-and-length (equal (equal (len (take-leading-hex-digit-chars x)) (len x)) (hex-digit-char-list*p x)))
Theorem:
(defthm take-leading-hex-digit-chars-when-hex-digit-char-list*p (implies (hex-digit-char-list*p x) (equal (take-leading-hex-digit-chars x) (list-fix x))))
Theorem:
(defthm consp-of-take-leading-hex-digit-chars (equal (consp (take-leading-hex-digit-chars x)) (hex-digit-char-p (car x))))