From: Lars Ingebrigtsen Date: Fri, 16 Sep 2022 10:29:54 +0000 (+0200) Subject: Add new predicate list-of-strings-p X-Git-Tag: emacs-29.0.90~1856^2~461 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=7d39453fd64e355526291b0ca5672e838de5fb58;p=emacs.git Add new predicate list-of-strings-p * lisp/subr.el (list-of-strings-p): New function. --- diff --git a/lisp/subr.el b/lisp/subr.el index bfc2e207b2c..e8e8f1584b4 100644 --- a/lisp/subr.el +++ b/lisp/subr.el @@ -4026,6 +4026,11 @@ system's shell." Otherwise, return nil." (or (stringp object) (null object))) +(defun list-of-strings-p (object) + "Return t if OBJECT is nil or a list of strings." + (and (listp object) + (seq-every-p #'stringp object))) + (defun booleanp (object) "Return t if OBJECT is one of the two canonical boolean values: t or nil. Otherwise, return nil." diff --git a/test/lisp/subr-tests.el b/test/lisp/subr-tests.el index 30117132101..38966cea585 100644 --- a/test/lisp/subr-tests.el +++ b/test/lisp/subr-tests.el @@ -1158,5 +1158,12 @@ final or penultimate step during initialization.")) (should (equal (butlast l n) (subr-tests--butlast-ref l n)))))) +(ert-deftest test-list-of-strings-p () + (should-not (list-of-strings-p 1)) + (should (list-of-strings-p nil)) + (should (list-of-strings-p '("a" "b"))) + (should-not (list-of-strings-p ["a" "b"])) + (should-not (list-of-strings-p '("a" nil "b")))) + (provide 'subr-tests) ;;; subr-tests.el ends here