From f87ff5396e6be4ad5832c00963c2a19c2d38aef2 Mon Sep 17 00:00:00 2001 From: Stefan Monnier Date: Wed, 21 Jan 2009 21:20:55 +0000 Subject: [PATCH] (completion--insert-strings): Fix up computation of column position which manifested e.g. in proced's signal completion. --- lisp/ChangeLog | 35 ++++++++++++++++------------- lisp/minibuffer.el | 56 +++++++++++++++++++++++++--------------------- 2 files changed, 49 insertions(+), 42 deletions(-) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 1275d5449f7..2c55236e0b9 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,8 @@ +2009-01-21 Stefan Monnier + + * minibuffer.el (completion--insert-strings): Fix up computation of + column position which manifested e.g. in proced's signal completion. + 2009-01-21 Chong Yidong * server.el (server-start): Allow server to shut down when no @@ -19,8 +24,8 @@ 2009-01-20 Agustín Martín - * textmodes/ispell.el (ispell-find-aspell-dictionaries): Use - aspell default dict. + * textmodes/ispell.el (ispell-find-aspell-dictionaries): + Use aspell default dict. 2009-01-20 Kenichi Handa @@ -67,8 +72,7 @@ 2009-01-17 Roland Winkler - * textmodes/bibtex.el (bibtex-format-entry): Simplify previous - change. + * textmodes/bibtex.el (bibtex-format-entry): Simplify previous change. 2009-01-17 Eli Zaretskii @@ -101,8 +105,8 @@ 2009-01-16 Ulrich Mueller - * international/quail.el (quail-insert-kbd-layout): Delete - superfluous handling of 8-bit code. (Bug#1418) + * international/quail.el (quail-insert-kbd-layout): + Delete superfluous handling of 8-bit code. (Bug#1418) 2009-01-16 Glenn Morris @@ -184,8 +188,8 @@ (special-display-regexps): Add customization support for function/other-args elements. Rewrite doc-strings. (special-display-function): Rewrite doc-string. - (same-window-buffer-names, same-window-regexps): Minor - doc-string fixes. + (same-window-buffer-names, same-window-regexps): + Minor doc-string fixes. (special-display-p): Minor rewrite. 2009-01-14 Glenn Morris @@ -303,8 +307,8 @@ Fix Bug #876: - * info.el (info-insert-file-contents, Info-insert-dir): Bind - inhibit-null-byte-detection to non-nil. + * info.el (info-insert-file-contents, Info-insert-dir): + Bind inhibit-null-byte-detection to non-nil. 2009-01-10 Martin Rudalics @@ -314,16 +318,15 @@ 2009-01-09 Chong Yidong * faces.el (face-valid-attribute-values): Use string as value for - :family attribute. Now, font-family-list returns a list of - strings. + :family attribute. Now, font-family-list returns a list of strings. (x-font-family-list): Obsolete compatibility version of function from xfaces.c. 2009-01-09 Martin Rudalics * window.el (special-display-buffer-names) - (special-display-regexps, special-display-function): In - doc-strings say "same-window" instead of "same-buffer". + (special-display-regexps, special-display-function): + In doc-strings say "same-window" instead of "same-buffer". 2009-01-09 Michael Albinus @@ -415,8 +418,8 @@ 2009-01-09 Reiner Steib - * net/imap.el (imap-enable-exchange-bug-workaround): Explain - auto-detection in the doc string. + * net/imap.el (imap-enable-exchange-bug-workaround): + Explain auto-detection in the doc string. 2009-01-09 Juanma Barranquero diff --git a/lisp/minibuffer.el b/lisp/minibuffer.el index 9e762d4ba32..c22448665b3 100644 --- a/lisp/minibuffer.el +++ b/lisp/minibuffer.el @@ -723,33 +723,37 @@ It also eliminates runs of equal strings." ;; The insertion should be "sensible" no matter what choices were made ;; for the parameters above. (dolist (str strings) - (unless (equal laststring str) ; Remove (consecutive) duplicates. + (unless (equal laststring str) ; Remove (consecutive) duplicates. (setq laststring str) - (unless (bolp) - (insert " \t") - (setq column (+ column colwidth)) - ;; Leave the space unpropertized so that in the case we're - ;; already past the goal column, there is still - ;; a space displayed. - (set-text-properties (- (point) 1) (point) - ;; We can't just set tab-width, because - ;; completion-setup-function will kill all - ;; local variables :-( - `(display (space :align-to ,column))) - (when (< wwidth (+ (max colwidth - (if (consp str) - (+ (string-width (car str)) - (string-width (cadr str))) - (string-width str))) - column)) - (delete-char -2) (insert "\n") (setq column 0))) - (if (not (consp str)) - (put-text-property (point) (progn (insert str) (point)) - 'mouse-face 'highlight) - (put-text-property (point) (progn (insert (car str)) (point)) - 'mouse-face 'highlight) - (put-text-property (point) (progn (insert (cadr str)) (point)) - 'mouse-face nil))))))) + (let ((length (if (consp str) + (+ (string-width (car str)) + (string-width (cadr str))) + (string-width str)))) + (unless (bolp) + (if (< wwidth (+ (max colwidth length) column)) + ;; No space for `str' at point, move to next line. + (progn (insert "\n") (setq column 0)) + (insert " \t") + ;; Leave the space unpropertized so that in the case we're + ;; already past the goal column, there is still + ;; a space displayed. + (set-text-properties (- (point) 1) (point) + ;; We can't just set tab-width, because + ;; completion-setup-function will kill all + ;; local variables :-( + `(display (space :align-to ,column))) + nil)) + (if (not (consp str)) + (put-text-property (point) (progn (insert str) (point)) + 'mouse-face 'highlight) + (put-text-property (point) (progn (insert (car str)) (point)) + 'mouse-face 'highlight) + (put-text-property (point) (progn (insert (cadr str)) (point)) + 'mouse-face nil)) + ;; Next column to align to. + (setq column (+ column + ;; Round up to a whole number of columns. + (* colwidth (ceiling length colwidth)))))))))) (defvar completion-common-substring nil) (make-obsolete-variable 'completion-common-substring nil "23.1") -- 2.39.2