From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!.POSTED!not-for-mail From: Tino Calancha Newsgroups: gmane.emacs.devel Subject: Re: tabulated-list: extend truncation into next align-right col Date: Wed, 2 Nov 2016 03:25:49 +0900 (JST) Message-ID: References: NNTP-Posting-Host: blaine.gmane.org Mime-Version: 1.0 Content-Type: multipart/mixed; BOUNDARY="8323329-1934636012-1478024751=:3586" X-Trace: blaine.gmane.org 1478024823 29232 195.159.176.226 (1 Nov 2016 18:27:03 GMT) X-Complaints-To: usenet@blaine.gmane.org NNTP-Posting-Date: Tue, 1 Nov 2016 18:27:03 +0000 (UTC) User-Agent: Alpine 2.20 (DEB 67 2015-01-07) Cc: Emacs developers , Tino Calancha To: Stefan Monnier Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Tue Nov 01 19:26:58 2016 Return-path: Envelope-to: ged-emacs-devel@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by blaine.gmane.org with esmtp (Exim 4.84_2) (envelope-from ) id 1c1dlm-0005ax-DQ for ged-emacs-devel@m.gmane.org; Tue, 01 Nov 2016 19:26:46 +0100 Original-Received: from localhost ([::1]:50303 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1c1dlp-0001uH-0q for ged-emacs-devel@m.gmane.org; Tue, 01 Nov 2016 14:26:49 -0400 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:35504) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1c1dkz-0001s8-CU for emacs-devel@gnu.org; Tue, 01 Nov 2016 14:25:58 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1c1dkw-0000fj-4R for emacs-devel@gnu.org; Tue, 01 Nov 2016 14:25:57 -0400 Original-Received: from mail-pf0-x234.google.com ([2607:f8b0:400e:c00::234]:35854) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1c1dkv-0000fe-L6 for emacs-devel@gnu.org; Tue, 01 Nov 2016 14:25:53 -0400 Original-Received: by mail-pf0-x234.google.com with SMTP id 189so45678139pfz.3 for ; Tue, 01 Nov 2016 11:25:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=from:date:to:cc:subject:in-reply-to:message-id:references :user-agent:mime-version; bh=CMq0XsBAmAhDPLTYaYBR6U5OcJygKN34G03tagggDEY=; b=TE1NltOXxZR60881XztnQT5U1KUoAswqef1IdxRK1PWwvGBWj/GCKetvpspjZK1DSZ CMYgYSvsF0Vn0IPUNBtXX/mSpem6X87xwtPv1qLXtjWybilAarftK7UeoCl4CTZ6S0RZ xH/em1Yxw6klGqGEAzaIUb0SqmZvVU8k7qlVmDZ94dFvmXnLYD4KQPx+fcYL2p61fLUX KmxeHjP061wqEozN2BgbupWGKYCzyWkRxqe8VCMUg6UZ4Uz/TolhgwEQn3uVqJlqDdwH 8gvBsW5nRqxK5OYh3jknTvp87CqravF7GPqb/3UN1IRab/XljRl/8IMGjJEd8FIy1P5H Br4Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:date:to:cc:subject:in-reply-to:message-id :references:user-agent:mime-version; bh=CMq0XsBAmAhDPLTYaYBR6U5OcJygKN34G03tagggDEY=; b=NXSi2bFkpTdBz+SS006XT9Vp066PlPn4UYxcNitl79tE8KsBLyoLRlgNtMmjrbr8ja X9YRzxIqww2klaDxbtT5/y/ZkyCUB8FDHjGEup7FUQwNhd1/6rICbt857Q/RfQcHDYO2 SpMb83OUUZMpF98dzzlVZS72rglY21KpLah9vtTVlXtAGsCQe8BjgdYwTkocBNStqh3t H07YYb2NHa4ZB+EHUEFkeZiceVTlctOi56y0ZlylGs/PVs8NxKgRbb8IYs8//LZWWiXB 040ly/rwK6x3qe1JJwTBObC6qXaomd0a/oLCxojTyNCj75ZG45bhqNNOVSxU8ytavO8f yfxw== X-Gm-Message-State: ABUngvfTtp7MsJRFEJM56KDdxm7kldr2pBDnWUHfqEQaZ+8XFJTCFZun8V9AaHO//UQRfw== X-Received: by 10.98.76.7 with SMTP id z7mr61529941pfa.143.1478024752215; Tue, 01 Nov 2016 11:25:52 -0700 (PDT) Original-Received: from calancha-pc (57.92.100.220.dy.bbexcite.jp. [220.100.92.57]) by smtp.gmail.com with ESMTPSA id 21sm43731783pfs.88.2016.11.01.11.25.50 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 01 Nov 2016 11:25:51 -0700 (PDT) X-Google-Original-From: Tino Calancha X-X-Sender: calancha@calancha-pc In-Reply-To: X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Received-From: 2607:f8b0:400e:c00::234 X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Original-Sender: "Emacs-devel" Xref: news.gmane.org gmane.emacs.devel:209082 Archived-At: --8323329-1934636012-1478024751=:3586 Content-Type: text/plain; format=flowed; charset=UTF-8 Content-Transfer-Encoding: 8BIT On Tue, 1 Nov 2016, Stefan Monnier wrote: >> ;; Without computing maximum widths: >> C1 C2 Numbers >> abc **************************************... 123456 >> abc *******************************************... 1 >> abc ************************************ 123 > > That's exactly what used to happen in *Buffer List* (and the source for > this TODO item). It wasn't that bad (I can't remember any user > complaints about it). Admittedly, we could do better: compute the max > width not of the whole column but of the current line, and the two > surrounding ones. This way we'd avoid We have now also a patch for that approach. Following is a comparison of: I) The classical: The current behaviour in master branch. II) The shy one: Using previous patch, i.e., computing the maximum width in the whole column. Note how, for every row, he feel shy to enter in Score column :-) III) The brother-in-law: Using new patch, i.e., computing the local maximum width in the column around the target row. Note how he enter in your score column, open your fridge without asking perm. and collect one of your favourite beers :-S ;; I) current behaviour: truncate until column width (50 in Comment column): M Name Date Comment Score ▼ Foo Tree 2016-11-02 02:51 ******************************************line ... 5 D Bar Soup 2016-11-02 02:51 line with 23 characters 15 * Baz Silver 2016-11-02 02:51 ***************************line with 50 characters 210000 Qux Spec 2016-11-02 02:51 ********************************line with 55 ch... 380000 ;; II) Previous patch; compute maximum in column: M Name Date Comment Score ▼ Foo Tree 2016-11-02 02:30 ******************************************line with 65 c... 5 D Bar Soup 2016-11-02 02:30 line with 23 characters 15 * Baz Silver 2016-11-02 02:30 ***************************line with 50 characters 210000 Qux Spec 2016-11-02 02:30 ********************************line with 55 characters 380000 ;; III) New patch; compute local maximum in column around target row: M Name Date Comment Score ▼ Foo Tree 2016-11-02 02:30 ******************************************line with 65 chara... 5 D Bar Soup 2016-11-02 02:30 line with 23 characters 15 * Baz Silver 2016-11-02 02:30 ***************************line with 50 characters 210000 Qux Spec 2016-11-02 02:30 ********************************line with 55 characters 380000 So, from previous e-mail exchange i guess you prefer III) right? ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; >From 6512184ccb8127d94410d56f147de9ecadc932c6 Mon Sep 17 00:00:00 2001 From: Tino Calancha Date: Wed, 2 Nov 2016 02:20:14 +0900 Subject: [PATCH] tabulated-list: extend truncation into next align-right column See discussion on: https://lists.gnu.org/archive/html/emacs-devel/2016-10/msg01101.html * lisp/emacs-lisp/tabulated-list.el (tabulated-list--near-cols-max-widths): New defun. (tabulated-list-print-col): Use it. If the next column is align-right, and has some space left then don't truncate to width, use some of the available space from the next column. --- lisp/emacs-lisp/tabulated-list.el | 54 +++++++++++++++++++++++++++++++++------ 1 file changed, 46 insertions(+), 8 deletions(-) diff --git a/lisp/emacs-lisp/tabulated-list.el b/lisp/emacs-lisp/tabulated-list.el index 00b029d..085fe6f 100644 --- a/lisp/emacs-lisp/tabulated-list.el +++ b/lisp/emacs-lisp/tabulated-list.el @@ -298,6 +298,27 @@ tabulated-list--get-sorter (lambda (a b) (not (funcall sorter a b))) sorter)))) +(defun tabulated-list--near-cols-max-widths (row col) + (let ((entries (if (functionp tabulated-list-entries) + (funcall tabulated-list-entries) + tabulated-list-entries))) + (let* ((entry (nth row entries)) + (entry-up (if (> row 0) + (nth (1- row) entries) + entry)) + (entry-down (if (< row (1- (length entries))) + (nth (1+ row) entries) + entry)) + (desc (elt (cadr entry) col)) + (desc-up (elt (cadr entry-up) col)) + (desc-down (elt (cadr entry-down) col))) + (apply #'max (mapcar (lambda (x) + (string-width + (if (stringp x) + x + (car x)))) + (list desc desc-up desc-down)))))) + (defun tabulated-list-print (&optional remember-pos update) "Populate the current Tabulated List mode buffer. This sorts the `tabulated-list-entries' list if sorting is @@ -402,8 +423,6 @@ tabulated-list-print-col N is the column number, COL-DESC is a column descriptor (see `tabulated-list-entries'), and X is the column number at point. Return the column number after insertion." - ;; TODO: don't truncate to `width' if the next column is align-right - ;; and has some space left. (let* ((format (aref tabulated-list-format n)) (name (nth 0 format)) (width (nth 1 format)) @@ -414,12 +433,31 @@ tabulated-list-print-col (label-width (string-width label)) (help-echo (concat (car format) ": " label)) (opoint (point)) - (not-last-col (< (1+ n) (length tabulated-list-format)))) + (not-last-col (< (1+ n) (length tabulated-list-format))) + available-space) + (when not-last-col + (let* ((next-col-format (aref tabulated-list-format (1+ n))) + (next-col-right-align (plist-get (nthcdr 3 next-col-format) + :right-align)) + (next-col-width (nth 1 next-col-format))) + (setq available-space + (if (and (not right-align) + next-col-right-align) + (- + (+ width next-col-width) + (min next-col-width + (tabulated-list--near-cols-max-widths + (1- (line-number-at-pos)) + (1+ n)))) + width)))) ;; Truncate labels if necessary (except last column). - (and not-last-col - (> label-width width) - (setq label (truncate-string-to-width label width nil nil t) - label-width width)) + ;; Don't truncate to `width' if the next column is align-right + ;; and has some space left, truncate to `available-space' instead. + (when (and not-last-col + (> label-width available-space) + (setq label (truncate-string-to-width + label available-space nil nil t) + label-width available-space))) (setq label (bidi-string-mark-left-to-right label)) (when (and right-align (> width label-width)) (let ((shift (- width label-width))) @@ -437,7 +475,7 @@ tabulated-list-print-col (when not-last-col (when (> pad-right 0) (insert (make-string pad-right ?\s))) (insert (propertize - (make-string (- next-x x label-width pad-right) ?\s) + (make-string (- width (min width label-width)) ?\s) 'display `(space :align-to ,next-x)))) (put-text-property opoint (point) 'tabulated-list-column-name name) next-x))) -- 2.10.1 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; In GNU Emacs 26.0.50.3 (x86_64-pc-linux-gnu, GTK+ Version 3.22.2) of 2016-11-02 built on calancha-pc Repository revision: c3640fcc96ed80368209c73d7ac9a0f0d1833d93 --8323329-1934636012-1478024751=:3586--