CLCS
Function

every, some, notevery, notany

every predicate &rest sequences^+ ⇒ generalized-boolean

some predicate &rest sequences^+ ⇒ result

notevery predicate &rest sequences^+ ⇒ generalized-boolean

notany predicate &rest sequences^+ ⇒ generalized-boolean

Arguments and Values

predicatea designator for a function of as many arguments as there are sequences.
sequencea sequence.
resultan object.
generalized-booleana generalized boolean.

Description

every, some, notevery, and notany test elements of sequences for satisfaction of a given predicate. The first argument to predicate is an element of the first sequence; each succeeding argument is an element of a succeeding sequence.

Predicate is first applied to the elements with index 0 in each of the sequences, and possibly then to the elements with index 1, and so on, until a termination criterion is met or the end of the shortest of the sequences is reached.

every returns false as soon as any invocation of predicate returns false. If the end of a sequence is reached, every returns true. Thus, every returns true if and only if every invocation of predicate returns true.

some returns the first non-nil value which is returned by an invocation of predicate. If the end of a sequence is reached without any invocation of the predicate returning true, some returns false. Thus, some returns true if and only if some invocation of predicate returns true.

notany returns false as soon as any invocation of predicate returns true. If the end of a sequence is reached, notany returns true. Thus, notany returns true if and only if it is not the case that any invocation of predicate returns true.

notevery returns true as soon as any invocation of predicate returns false. If the end of a sequence is reached, notevery returns false. Thus, notevery returns true if and only if it is not the case that every invocation of predicate returns true.

Examples

 (every #'characterp "abc") ⇒  true
 (some #'= '(1 2 3 4 5) '(5 4 3 2 1)) ⇒  true
 (notevery #'< '(1 2 3 4) '(5 6 7 8) '(9 10 11 12)) ⇒  false
 (notany #'> '(1 2 3 4) '(5 6 7 8) '(9 10 11 12)) ⇒  true 

Exceptional Situations

Should signal type-error if its first argument is neither a symbol nor a function or if any subsequent argument is not a proper sequence.

Other exceptional situations are possible, depending on the nature of the predicate.

Notes

 (notany predicate {sequence}*) ≡ (not (some predicate {sequence}*))
 (notevery predicate {sequence}*) ≡ (not (every predicate {sequence}*))