diff options
| author | Noam Postavsky | 2016-08-05 19:59:52 -0400 |
|---|---|---|
| committer | Noam Postavsky | 2017-02-20 16:53:14 -0500 |
| commit | 2f53c0c468561313dd9840e28371436c669153c2 (patch) | |
| tree | ef484c162c9f9bfa5e44766f92fca83c2946bd35 /test | |
| parent | 57a8346edfbaa7a4002f2ed8cad041588dfcdd9c (diff) | |
| download | emacs-2f53c0c468561313dd9840e28371436c669153c2.tar.gz emacs-2f53c0c468561313dd9840e28371436c669153c2.zip | |
Simplify cl-get using `plist-member'
* lisp/emacs-lisp/cl-extra.el (cl-get, cl-getf, cl--set-getf): Use
`plist-member' instead of explicit loop.
* test/lisp/emacs-lisp/cl-extra-tests.el: New tests.
Diffstat (limited to 'test')
| -rw-r--r-- | test/lisp/emacs-lisp/cl-extra-tests.el | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/test/lisp/emacs-lisp/cl-extra-tests.el b/test/lisp/emacs-lisp/cl-extra-tests.el new file mode 100644 index 00000000000..3e2388acc6f --- /dev/null +++ b/test/lisp/emacs-lisp/cl-extra-tests.el | |||
| @@ -0,0 +1,38 @@ | |||
| 1 | ;;; cl-extra-tests.el --- tests for emacs-lisp/cl-extra.el -*- lexical-binding:t -*- | ||
| 2 | |||
| 3 | ;; Copyright (C) 2013-2017 Free Software Foundation, Inc. | ||
| 4 | |||
| 5 | ;; This file is part of GNU Emacs. | ||
| 6 | |||
| 7 | ;; This program is free software: you can redistribute it and/or | ||
| 8 | ;; modify it under the terms of the GNU General Public License as | ||
| 9 | ;; published by the Free Software Foundation, either version 3 of the | ||
| 10 | ;; License, or (at your option) any later version. | ||
| 11 | ;; | ||
| 12 | ;; This program is distributed in the hope that it will be useful, but | ||
| 13 | ;; WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 14 | ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 15 | ;; General Public License for more details. | ||
| 16 | ;; | ||
| 17 | ;; You should have received a copy of the GNU General Public License | ||
| 18 | ;; along with this program. If not, see `http://www.gnu.org/licenses/'. | ||
| 19 | |||
| 20 | ;;; Code: | ||
| 21 | |||
| 22 | (require 'cl-lib) | ||
| 23 | (require 'ert) | ||
| 24 | |||
| 25 | (ert-deftest cl-get () | ||
| 26 | (put 'cl-get-test 'x 1) | ||
| 27 | (put 'cl-get-test 'y nil) | ||
| 28 | (should (eq (cl-get 'cl-get-test 'x) 1)) | ||
| 29 | (should (eq (cl-get 'cl-get-test 'y :none) nil)) | ||
| 30 | (should (eq (cl-get 'cl-get-test 'z :none) :none))) | ||
| 31 | |||
| 32 | (ert-deftest cl-getf () | ||
| 33 | (let ((plist '(x 1 y nil))) | ||
| 34 | (should (eq (cl-getf plist 'x) 1)) | ||
| 35 | (should (eq (cl-getf plist 'y :none) nil)) | ||
| 36 | (should (eq (cl-getf plist 'z :none) :none)))) | ||
| 37 | |||
| 38 | ;;; cl-extra-tests.el ends here | ||