Mercurial > hg > xemacs-beta
view tests/automated/files-tests.el @ 5855:0bddb59072b6
Look for cased character classes when deciding on case-fold-search, #'isearch
lisp/ChangeLog addition:
2015-03-11 Aidan Kehoe <kehoea@parhasard.net>
* isearch-mode.el:
* isearch-mode.el (isearch-fix-case):
Use the new #'no-case-regexp-p function if treating ISEARCH-STRING
as a regular expression; otherwise, use the [[:upper:]] character
class.
* isearch-mode.el (isearch-no-upper-case-p): Removed.
* isearch-mode.el (with-caps-disable-folding): Removed.
These two haven't been used since 1998.
* occur.el (occur-1):
Use #'no-case-regexp-p here.
* replace.el (perform-replace):
Don't use #'no-upper-case-p, use #'no-case-regexp-p or
(string-match "[[:upper:]]" ...) as appropriate.
* simple.el:
* simple.el (no-upper-case-p): Removed. This did two different
things, and its secondary function (examining regular expressions)
just became much more complicated; move the regular expression
functionality to its own function, use character classes when
examining non-regular-expressions instead.
The code to look for character classes, and the design decision
that this should be done, are from GNU, thank you Stefan Monnier.
* simple.el (no-case-regexp-p): New.
Given a REGEXP, return non-nil if it has nothing to suggest an
interactive user wants a case-sensitive search.
* simple.el (with-search-caps-disable-folding):
* simple.el (with-interactive-search-caps-disable-folding):
Update both these macros to use #'no-case-regexp-p.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Wed, 11 Mar 2015 18:06:15 +0000 |
parents | 182d01410b8d |
children |
line wrap: on
line source
;; Copyright (C) 2013 Free Software Foundation, Inc. ;; Author: Mats Lidell <matsl@xemacs.org> ;; Maintainer: ;; Created: 2013 ;; Keywords: tests ;; This file is part of XEmacs. ;; XEmacs is free software: you can redistribute it and/or modify it ;; under the terms of the GNU General Public License as published by the ;; Free Software Foundation, either version 3 of the License, or (at your ;; option) any later version. ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ;; for more details. ;; You should have received a copy of the GNU General Public License ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>. ;;; Synched up with: Not in FSF. ;;; Commentary: ;; Test tag support. ;; See test-harness.el for instructions on how to run these tests. (require 'test-harness) ;; Require a newline on save (let ((test-file-name (make-temp-file "files-tests")) (require-final-newline t)) (find-file test-file-name) (erase-buffer) (insert "no newline") (Silence-Message (save-buffer 0)) (Assert (equal (buffer-string) "no newline\n")) (kill-buffer nil) (delete-file test-file-name)) ;; Don't require a newline on save (let ((test-file-name (make-temp-file "files-tests")) (require-final-newline nil)) (find-file test-file-name) (erase-buffer) (insert "no newline") (Silence-Message (save-buffer 0)) (Assert (equal (buffer-string) "no newline")) (kill-buffer nil) (delete-file test-file-name)) ;; Require a newline on visit (not on save) ;; Answer query when saving with both no and yes. (let ((test-file-name (make-temp-file "files-tests")) (require-final-newline nil)) (find-file test-file-name) (erase-buffer) (insert "no newline") (Silence-Message (save-buffer 0)) (kill-buffer nil) (let ((require-final-newline 'visit)) (find-file test-file-name) (Assert (equal (buffer-string) "no newline\n")) ;; Answer no (erase-buffer) (insert "no newline") (flet ((y-or-n-p (prompt) nil)) (Silence-Message (save-buffer 0))) (Assert (equal (buffer-string) "no newline")) ;; Answer yes (erase-buffer) (insert "no newline") (flet ((y-or-n-p (prompt) t)) (Silence-Message (save-buffer 0))) (Assert (equal (buffer-string) "no newline\n"))) (kill-buffer nil) (delete-file test-file-name)) ;; Require a newline on visit and save (let ((test-file-name (make-temp-file "files-tests")) (require-final-newline nil)) (find-file test-file-name) (erase-buffer) (insert "no newline") (Silence-Message (save-buffer 0)) (kill-buffer nil) (let ((require-final-newline 'visit-save)) (find-file test-file-name) (Assert (equal (buffer-string) "no newline\n")) (erase-buffer) (insert "no newline") (Silence-Message (save-buffer 0)) (Assert (equal (buffer-string) "no newline\n"))) (kill-buffer nil) (delete-file test-file-name)) ;; mode-require-final-newline is respected by text-mode (let ((test-file-name (make-temp-file "files-tests")) (require-final-newline nil) (mode-require-final-newline t)) (Assert (equal require-final-newline nil)) (find-file test-file-name) (erase-buffer) (text-mode) (Assert (equal require-final-newline t)) (insert "no newline") (Silence-Message (save-buffer 0)) (Assert (equal (buffer-string) "no newline\n")) (kill-buffer nil) (delete-file test-file-name))