Get the elems field from a initer-list.
(initer-list->elems x) → elems
This is an ordinary field accessor created by fty::defprod.
Function:
(defun initer-list->elems$inline (x) (declare (xargs :guard (initerp x))) (declare (xargs :guard (equal (initer-kind x) :list))) (let ((__function__ 'initer-list->elems)) (declare (ignorable __function__)) (mbe :logic (b* ((x (and (equal (initer-kind x) :list) x))) (desiniter-list-fix (std::da-nth 0 (cdr x)))) :exec (std::da-nth 0 (cdr x)))))
Theorem:
(defthm desiniter-listp-of-initer-list->elems (b* ((elems (initer-list->elems$inline x))) (desiniter-listp elems)) :rule-classes :rewrite)
Theorem:
(defthm initer-list->elems$inline-of-initer-fix-x (equal (initer-list->elems$inline (initer-fix x)) (initer-list->elems$inline x)))
Theorem:
(defthm initer-list->elems$inline-initer-equiv-congruence-on-x (implies (initer-equiv x x-equiv) (equal (initer-list->elems$inline x) (initer-list->elems$inline x-equiv))) :rule-classes :congruence)
Theorem:
(defthm initer-list->elems-when-wrong-kind (implies (not (equal (initer-kind x) :list)) (equal (initer-list->elems x) (desiniter-list-fix nil))))