mirror of
git://git.sv.gnu.org/emacs.git
synced 2025-12-06 06:20:55 -08:00
Have 'cl-case' warn about suspicious cases
* lisp/emacs-lisp/cl-macs.el (cl-case): Warn if the user passes a nil key list (which would never match). Warn about quoted symbols that should probably be unquoted. * test/lisp/emacs-lisp/cl-macs-tests.el (cl-case-warning): New unit test (bug#51368).
This commit is contained in:
parent
6d8f5161ea
commit
fffa53ff1a
2 changed files with 47 additions and 0 deletions
|
|
@ -25,6 +25,8 @@
|
|||
(require 'cl-macs)
|
||||
(require 'edebug)
|
||||
(require 'ert)
|
||||
(require 'ert-x)
|
||||
(require 'pcase)
|
||||
|
||||
|
||||
;;;; cl-loop tests -- many adapted from Steele's CLtL2
|
||||
|
|
@ -758,4 +760,34 @@ collection clause."
|
|||
(should (equal (cdr error)
|
||||
'("Misplaced t or `otherwise' clause")))))))
|
||||
|
||||
(ert-deftest cl-case-warning ()
|
||||
"Test that `cl-case' and `cl-ecase' warn about suspicious
|
||||
constructs."
|
||||
(pcase-dolist (`(,case . ,message)
|
||||
`((nil . "Case nil will never match")
|
||||
('nil . ,(concat "Case 'nil will match `quote'. "
|
||||
"If that's intended, write "
|
||||
"(nil quote) instead. "
|
||||
"Otherwise, don't quote `nil'."))
|
||||
('t . ,(concat "Case 't will match `quote'. "
|
||||
"If that's intended, write "
|
||||
"(t quote) instead. "
|
||||
"Otherwise, don't quote `t'."))
|
||||
('foo . ,(concat "Case 'foo will match `quote'. "
|
||||
"If that's intended, write "
|
||||
"(foo quote) instead. "
|
||||
"Otherwise, don't quote `foo'."))
|
||||
(#'foo . ,(concat "Case #'foo will match "
|
||||
"`function'. If that's "
|
||||
"intended, write (foo function) "
|
||||
"instead. Otherwise, don't "
|
||||
"quote `foo'."))))
|
||||
(dolist (macro '(cl-case cl-ecase))
|
||||
(let ((form `(,macro val (,case 1))))
|
||||
(ert-info ((prin1-to-string form) :prefix "Form: ")
|
||||
(ert-with-message-capture messages
|
||||
(macroexpand form)
|
||||
(should (equal messages
|
||||
(concat "Warning: " message "\n")))))))))
|
||||
|
||||
;;; cl-macs-tests.el ends here
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue