From 8097dd15c28e9978b5cb666a66b3101ee1ebbe62 Mon Sep 17 00:00:00 2001 From: Gerd Moellmann Date: Mon, 17 Apr 2000 12:31:49 +0000 Subject: [PATCH] (iswitchb-case): New function. If the user input contains any upper-case characters, the search is made case-sensitive. --- lisp/iswitchb.el | 37 ++++++++++++++++++++++++++++++++----- 1 file changed, 32 insertions(+), 5 deletions(-) diff --git a/lisp/iswitchb.el b/lisp/iswitchb.el index 0b5ad730fea..0f57b789038 100644 --- a/lisp/iswitchb.el +++ b/lisp/iswitchb.el @@ -46,7 +46,7 @@ ;; common to all of the matching buffers as you type. ;; This code is similar to a couple of other packages. Michael R Cook -;; wrote a similar buffer switching package, but +;; wrote a similar buffer switching package, but ;; does exact matching rather than substring matching on buffer names. ;; I also modified a couple of functions from icomplete.el to provide ;; the completion feedback in the minibuffer. @@ -111,6 +111,23 @@ ;; See the doc string of iswitchb for full keybindings and features. ;; (describe-function 'iswitchb) +;; Case matching: The case of strings when matching can be ignored or +;; used depending on the value of iswitchb-case (default is the same +;; as case-fold-search, normally t). Imagine you have the following +;; buffers: +;; +;; INBOX *info* *scratch* +;; +;; Then these will be the matching buffers, depending on how you type +;; the two letters `in' and the value of iswitchb-case: +;; +;; iswitchb-case user input | matching buffers +;; ---------------------------------------------- +;; nil in | *info* +;; t in | INBOX, *info* +;; t IN | INBOX +;; t In | [No match] + ;;; Customisation ;; See the User Variables section below for easy ways to change the @@ -224,7 +241,9 @@ :link '(emacs-library-link :tag "Lisp File" "iswitchb.el")) (defcustom iswitchb-case case-fold-search - "*Non-nil if searching of buffer names should ignore case." + "*Non-nil if searching of buffer names should ignore case. +If this is non-nil but the user input has any upper case letters, matching +is temporarily case sensitive." :type 'boolean :group 'iswitchb) @@ -741,7 +760,7 @@ current frame, rather than all frames, regardless of value of "Return buffers matching REGEXP. If STRING-FORMAT is nil, consider REGEXP as just a string. BUFFER-LIST can be list of buffers or list of strings." - (let* ((case-fold-search iswitchb-case) + (let* ((case-fold-search (iswitchb-case)) ;; need reverse since we are building up list backwards (list (reverse buffer-list)) (do-string (stringp (car list))) @@ -793,7 +812,7 @@ BUFFER-LIST can be list of buffers or list of strings." (defun iswitchb-word-matching-substring (word) "Return part of WORD before 1st match to `iswitchb-change-word-sub'. If `iswitchb-change-word-sub' cannot be found in WORD, return nil." - (let ((case-fold-search iswitchb-case)) + (let ((case-fold-search (iswitchb-case))) (let ((m (string-match iswitchb-change-word-sub word))) (if m (substring word m) @@ -814,7 +833,7 @@ If `iswitchb-change-word-sub' cannot be found in WORD, return nil." (setq alist (mapcar 'iswitchb-makealist res)) ;; could use an OBARRAY ;; try-completion returns t if there is an exact match. - (let ((completion-ignore-case iswitchb-case)) + (let ((completion-ignore-case (iswitchb-case))) (try-completion subs alist)))) @@ -1256,6 +1275,14 @@ This is an example function which can be hooked on to iswitchb-temp-buflist)))) (iswitchb-to-end summaries))) +(defun iswitchb-case () + "Return non-nil iff we should ignore case when matching. +See the variable `iswitchb-case' for details." + (if iswitchb-case + (if iswitchb-xemacs + (isearch-no-upper-case-p iswitchb-text) + (isearch-no-upper-case-p iswitchb-text t)))) + (provide 'iswitchb) ;;; iswitchb.el ends here -- 2.39.5