This is occasionally useful for avoiding case-splitting in theorems.
Function:
(defun binary-and* (x y) (declare (xargs :guard t)) (if x y nil))
Function:
(defun and*-macro (x) (declare (xargs :guard t)) (cond ((atom x) t) ((atom (cdr x)) (car x)) (t (cons 'binary-and* (cons (car x) (cons (and*-macro (cdr x)) 'nil))))))