From: Peter Feigl Date: Sun, 25 Jul 2021 07:16:08 +0000 (+0200) Subject: Add commands to move to next/previous column in tabulated-list-mode X-Git-Tag: emacs-28.0.90~1706 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=a6afa221d7b373271bedef69e3a5f9e957e9fbf8;p=emacs.git Add commands to move to next/previous column in tabulated-list-mode * lisp/emacs-lisp/tabulated-list.el (tabulated-list-mode-map): Add keybindings M-left and M-right. (tabulated-list-previous-column tabulated-list-next-column): Implement commands (bug#44711). --- diff --git a/etc/NEWS b/etc/NEWS index f1502a8e0e8..f1635ae2e64 100644 --- a/etc/NEWS +++ b/etc/NEWS @@ -2331,6 +2331,9 @@ previously no easy way to get back to the original displayed order after sorting, but giving a -1 numerical prefix to the sorting command will now restore the original order. +--- +*** 'M-left' and 'M-right' now move between columns in 'tabulated-list-mode'. + +++ *** New utility function 'insert-into-buffer'. This is like 'insert-buffer-substring', but works in the opposite diff --git a/lisp/emacs-lisp/tabulated-list.el b/lisp/emacs-lisp/tabulated-list.el index 04f3b70aaa8..f0ee78745ac 100644 --- a/lisp/emacs-lisp/tabulated-list.el +++ b/lisp/emacs-lisp/tabulated-list.el @@ -214,6 +214,8 @@ If ADVANCE is non-nil, move forward by one line afterwards." special-mode-map)) (define-key map "n" 'next-line) (define-key map "p" 'previous-line) + (define-key map (kbd "M-") 'tabulated-list-previous-column) + (define-key map (kbd "M-") 'tabulated-list-next-column) (define-key map "S" 'tabulated-list-sort) (define-key map "}" 'tabulated-list-widen-current-column) (define-key map "{" 'tabulated-list-narrow-current-column) @@ -740,6 +742,28 @@ Interactively, N is the prefix numeric argument, and defaults to (setq-local tabulated-list--current-lnum-width lnum-width) (tabulated-list-init-header))))) +(defun tabulated-list-next-column (&optional arg) + "Go to the start of the next column after point on the current line. +If ARG is provided, move that many columns." + (interactive "p") + (dotimes (_ (or arg 1)) + (let ((next (or (next-single-property-change + (point) 'tabulated-list-column-name) + (point-max)))) + (when (<= next (line-end-position)) + (goto-char next))))) + +(defun tabulated-list-previous-column (&optional arg) + "Go to the start of the column point is in on the current line. +If ARG is provided, move that many columns." + (interactive "p") + (dotimes (_ (or arg 1)) + (let ((prev (or (previous-single-property-change + (point) 'tabulated-list-column-name) + 1))) + (unless (< prev (line-beginning-position)) + (goto-char prev))))) + ;;; The mode definition: (defvar tabulated-list--original-order nil)