(setq ele (cdr ele)))
(concat res "$\\)")))
-;;; Font-Lock-Settings
+;; Font-Lock-Settings
(defvar bs-mode-font-lock-keywords
(list ;; header in font-lock-type-face
(list (bs--make-header-match-string)
(defvar bs--marked-buffers nil
"Currently marked buffers in Buffer Selection Menu.")
-(defvar bs-mode-map ()
+(defvar bs-mode-map
+ (let ((map (make-sparse-keymap)))
+ (define-key map " " 'bs-select)
+ (define-key map "f" 'bs-select)
+ (define-key map "v" 'bs-view)
+ (define-key map "!" 'bs-select-in-one-window)
+ (define-key map [mouse-2] 'bs-mouse-select) ;; for GNU EMACS
+ (define-key map [button2] 'bs-mouse-select) ;; for XEmacs
+ (define-key map "F" 'bs-select-other-frame)
+ (let ((key ?1))
+ (while (<= key ?9)
+ (define-key map (char-to-string key) 'digit-argument)
+ (setq key (1+ key))))
+ (define-key map "-" 'negative-argument)
+ (define-key map "\e-" 'negative-argument)
+ (define-key map "o" 'bs-select-other-window)
+ (define-key map "\C-o" 'bs-tmp-select-other-window)
+ ;; for GNU EMACS
+ (define-key map [mouse-3] 'bs-mouse-select-other-frame)
+ ;; for XEmacs
+ (define-key map [button3] 'bs-mouse-select-other-frame)
+ (define-key map [up] 'bs-up)
+ (define-key map "n" 'bs-down)
+ (define-key map "p" 'bs-up)
+ (define-key map [down] 'bs-down)
+ (define-key map "\C-m" 'bs-select)
+ (define-key map "b" 'bs-bury-buffer)
+ (define-key map "s" 'bs-save)
+ (define-key map "S" 'bs-show-sorted)
+ (define-key map "a" 'bs-toggle-show-all)
+ (define-key map "d" 'bs-delete)
+ (define-key map "\C-d" 'bs-delete-backward)
+ (define-key map "k" 'bs-delete)
+ (define-key map "g" 'bs-refresh)
+ (define-key map "C" 'bs-set-configuration-and-refresh)
+ (define-key map "c" 'bs-select-next-configuration)
+ (define-key map "q" 'bs-kill)
+ ;; (define-key map "z" 'bs-kill)
+ (define-key map "\C-c\C-c" 'bs-kill)
+ (define-key map "\C-g" 'bs-abort)
+ (define-key map "\C-]" 'bs-abort)
+ (define-key map "%" 'bs-toggle-readonly)
+ (define-key map "~" 'bs-clear-modified)
+ (define-key map "M" 'bs-toggle-current-to-show)
+ (define-key map "+" 'bs-set-current-buffer-to-show-always)
+ ;;(define-key map "-" 'bs-set-current-buffer-to-show-never)
+ (define-key map "t" 'bs-visit-tags-table)
+ (define-key map "m" 'bs-mark-current)
+ (define-key map "u" 'bs-unmark-current)
+ (define-key map ">" 'scroll-right)
+ (define-key map "<" 'scroll-left)
+ (define-key map "?" 'bs-help)
+ map)
"Keymap of `bs-mode'.")
-(if bs-mode-map
- ()
- (setq bs-mode-map (make-sparse-keymap))
- (define-key bs-mode-map " " 'bs-select)
- (define-key bs-mode-map "f" 'bs-select)
- (define-key bs-mode-map "v" 'bs-view)
- (define-key bs-mode-map "!" 'bs-select-in-one-window)
- (define-key bs-mode-map [mouse-2] 'bs-mouse-select) ;; for GNU EMACS
- (define-key bs-mode-map [button2] 'bs-mouse-select) ;; for XEmacs
- (define-key bs-mode-map "F" 'bs-select-other-frame)
-
- (let ((key ?1))
- (while (<= key ?9)
- (define-key bs-mode-map (char-to-string key) 'digit-argument)
- (setq key (1+ key))))
-
- (define-key bs-mode-map "-" 'negative-argument)
- (define-key bs-mode-map "\e-" 'negative-argument)
-
- (define-key bs-mode-map "o" 'bs-select-other-window)
- (define-key bs-mode-map "\C-o" 'bs-tmp-select-other-window)
- ;; for GNU EMACS
- (define-key bs-mode-map [mouse-3] 'bs-mouse-select-other-frame)
- ;; for XEmacs
- (define-key bs-mode-map [button3] 'bs-mouse-select-other-frame)
- (define-key bs-mode-map [up] 'bs-up)
- (define-key bs-mode-map "n" 'bs-down)
- (define-key bs-mode-map "p" 'bs-up)
- (define-key bs-mode-map [down] 'bs-down)
- (define-key bs-mode-map "\C-m" 'bs-select)
- (define-key bs-mode-map "b" 'bs-bury-buffer)
- (define-key bs-mode-map "s" 'bs-save)
- (define-key bs-mode-map "S" 'bs-show-sorted)
- (define-key bs-mode-map "a" 'bs-toggle-show-all)
- (define-key bs-mode-map "d" 'bs-delete)
- (define-key bs-mode-map "\C-d" 'bs-delete-backward)
- (define-key bs-mode-map "k" 'bs-delete)
- (define-key bs-mode-map "g" 'bs-refresh)
- (define-key bs-mode-map "C" 'bs-set-configuration-and-refresh)
- (define-key bs-mode-map "c" 'bs-select-next-configuration)
- (define-key bs-mode-map "q" 'bs-kill)
- ;; (define-key bs-mode-map "z" 'bs-kill)
- (define-key bs-mode-map "\C-c\C-c" 'bs-kill)
- (define-key bs-mode-map "\C-g" 'bs-abort)
- (define-key bs-mode-map "\C-]" 'bs-abort)
- (define-key bs-mode-map "%" 'bs-toggle-readonly)
- (define-key bs-mode-map "~" 'bs-clear-modified)
- (define-key bs-mode-map "M" 'bs-toggle-current-to-show)
- (define-key bs-mode-map "+" 'bs-set-current-buffer-to-show-always)
- ;;(define-key bs-mode-map "-" 'bs-set-current-buffer-to-show-never)
- (define-key bs-mode-map "t" 'bs-visit-tags-table)
- (define-key bs-mode-map "m" 'bs-mark-current)
- (define-key bs-mode-map "u" 'bs-unmark-current)
- (define-key bs-mode-map ">" 'scroll-right)
- (define-key bs-mode-map "<" 'scroll-left)
- (define-key bs-mode-map "\e\e" nil)
- (define-key bs-mode-map "\e\e\e" 'bs-kill)
- (define-key bs-mode-map [escape escape escape] 'bs-kill)
- (define-key bs-mode-map "?" 'bs-help))
-
;; ----------------------------------------------------------------------
;; Functions
;; ----------------------------------------------------------------------
(interactive)
(let ((current (bs--current-buffer))
(inhibit-read-only t))
+ (unless (kill-buffer current)
+ (error "Buffer was not deleted"))
(setq bs-current-list (delq current bs-current-list))
- (kill-buffer current)
(beginning-of-line)
(delete-region (point) (save-excursion
(end-of-line)
(defun bs-message-without-log (&rest args)
"Like `message' but don't log it on the message log.
-All arguments ARGS are transfered to function `message'."
+All arguments ARGS are transferred to function `message'."
(let ((message-log-max nil))
(apply 'message args)))
START-BUFFER is the buffer where we started buffer selection.
ALL-BUFFERS is the list of buffer appearing in Buffer Selection Menu."
(let ((name (copy-sequence (buffer-name))))
- (put-text-property 0 (length name) 'mouse-face 'highlight name)
+ (add-text-properties
+ 0 (length name)
+ '(mouse-face highlight
+ help-echo
+ "mouse-2: select this buffer, mouse-3: select in other frame")
+ name)
(if (< (length name) bs--name-entry-length)
(concat name
(make-string (- bs--name-entry-length (length name)) ? ))
'(shell-mode dired-mode))
default-directory
(or buffer-file-name "")))))
- (put-text-property 0 (length string) 'mouse-face 'highlight string)
+ (add-text-properties
+ 0 (length string)
+ '(mouse-face highlight
+ help-echo "mouse-2: select this buffer, mouse-3: select in other frame")
+ string)
string))
(defun bs--insert-one-entry (buffer)
(setq bs--marked-buffers nil)
(bs--show-with-configuration (bs--configuration-name-for-prefix-arg arg)))
-;;; Now provide feature bs
+;; Now provide feature bs
(provide 'bs)
+;;; arch-tag: c0d9ab34-bf06-4368-ae9d-af88878e6802
;;; bs.el ends here