unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
From: "Arsen Arsenović via Bug reports for GNU Emacs, the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
To: Eli Zaretskii <eliz@gnu.org>
Cc: 75168@debbugs.gnu.org
Subject: bug#75168: 31.0.50; text-scale confuses ruler-mode when display-line-number-mode is active
Date: Sun, 29 Dec 2024 13:06:03 +0100	[thread overview]
Message-ID: <86y0zypuc4.fsf@aarsen.me> (raw)
In-Reply-To: <86o70vq9k2.fsf@gnu.org> (Eli Zaretskii's message of "Sun, 29 Dec 2024 08:37:17 +0200")


[-- Attachment #1.1: Type: text/plain, Size: 1838 bytes --]

Eli Zaretskii <eliz@gnu.org> writes:

>> Date: Sat, 28 Dec 2024 22:15:28 +0100
>> From:  Arsen Arsenović via "Bug reports for GNU Emacs,
>>  the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
>> 
>> Reproduction steps:
>> 1. emacs -Q
>> 2. M-x display-line-numbers-mode RET
>> 3. M-x ruler-mode RET
>> 4. C-x C-+ C-+ C-+ C-+
>> 
>> You should notice that the ruler is misaligned.
>
> Ruler mode doesn't work well with text-scale, as the comment there says.
>
>> I've hotfixed this in my running Emacs by applying:
>> 
>> modified   lisp/ruler-mode.el
>> @@ -636,7 +636,7 @@ ruler-mode-ruler
>>                  ;; FIXME: ruler-mode relies on I being an integer, so
>>                  ;; the column numbers might be slightly off if the
>>                  ;; line-number face is customized.
>> -                (round (line-number-display-width 'columns))
>> +                (+ (round (line-number-display-width)) 2)
>>                0))
>>           (j (ruler-mode-text-scaled-window-hscroll))
>>           ;; Setup the scrollbar, fringes, and margins areas.
>> 
>> ... and re-evaling the ruler-mode-ruler defun.
>> 
>> Per the line-number-display-width doc, when it is called with 'columns,
>> it returns the number of columns in the frames canonical font size, but
>> that's not the font size that is used for the fringes: the fringes seem
>> to use the font the buffer is using, at least after text-scale-mode does
>> its thing.
>
> I'm not sure I understand what you mean by "fringes seem to use the
> font the buffer is using".  When I type "C-x C-+ C-+...", the fringes
> stay at their original width.  Do you see something different?

Hm, yes, fringe might be the wrong word.  I am referring to the column
where the ruler and line number are, which I've outlined in red:


[-- Attachment #1.2: Red boxes represent what I was referring to --]
[-- Type: image/png, Size: 54405 bytes --]

[-- Attachment #1.3: Type: text/plain, Size: 3162 bytes --]


Sorry about the confusion.

That part of the display appears to use the same font size as the
buffer after text-scale has been enabled.

> Anyway, the change you suggest is basically going back to what we had
> before fixing bug#28855, so I don't think we can make such a change,
> at least not literally.  We need something more complex to account for
> the use cases described in that bug.

Yes, I had a feeling what I posted was not correct, because it seemed
like the "obvious" thing, and so, would've been there already if
correct.

I've just dug through the Elisp manual a little and I think (elisp)
Specified Space is precisely what's needed here.  I've tried the
following:

modified   lisp/ruler-mode.el
@@ -632,12 +632,7 @@ ruler-mode-ruler
   (let* ((w (ruler-mode-text-scaled-window-width))
          (m (window-margins))
          (f (window-fringes))
-         (i (if display-line-numbers
-                ;; FIXME: ruler-mode relies on I being an integer, so
-                ;; the column numbers might be slightly off if the
-                ;; line-number face is customized.
-                (round (line-number-display-width 'columns))
-              0))
+         (i 0)
          (j (ruler-mode-text-scaled-window-hscroll))
          ;; Setup the scrollbar, fringes, and margins areas.
          (lf (ruler-mode-space
@@ -739,7 +734,13 @@ ruler-mode-ruler
       (setq i (1+ i)
             j (1+ j)))
 
-    (let ((ruler-str (concat ruler))
+    (let ((ruler-indent
+           (if (not display-line-numbers)
+               ""
+             (propertize " " 'display
+                         `(space :width
+                                 (,(- (line-number-display-width t) 1))))))
+          (ruler-str (concat ruler))
           (len (length ruler)))
       (add-text-properties 0 len ruler-wide-props ruler-str)
       (dolist (p (nreverse props))
@@ -747,13 +748,14 @@ ruler-mode-ruler
 
       ;; Return the ruler propertized string.  Using list here,
       ;; instead of concat visually separate the different areas.
-      (if (nth 2 (window-fringes))
-          ;; fringes outside margins.
-          (list "" (and (eq 'left sbvt) sb) lf lm
-                ruler-str rm rf (and (eq 'right sbvt) sb))
-        ;; fringes inside margins.
-        (list "" (and (eq 'left sbvt) sb) lm lf
-              ruler-str rf rm (and (eq 'right sbvt) sb))))))
+      (let ((ruler-str-ind (concat ruler-indent ruler-str)))
+            (if (nth 2 (window-fringes))
+            ;; fringes outside margins.
+            (list "" (and (eq 'left sbvt) sb) lf lm
+                  ruler-str-ind rm rf (and (eq 'right sbvt) sb))
+          ;; fringes inside margins.
+          (list "" (and (eq 'left sbvt) sb) lm lf
+                ruler-str-ind rf rm (and (eq 'right sbvt) sb)))))))
 
 (provide 'ruler-mode)
 
This is almost perfect. The (- ... 1) in the :width pixel spec is
obviously a hack (and breaks this patch in emacs -nw).  I have no idea
why an extra pixel is inserted in GUI mode.  If you apply the above but
remove (- ... 1), you'll see the following:


[-- Attachment #1.4: Screen, zoomed in using GIMP.  The crosshair position is an extra column of pixels --]
[-- Type: image/png, Size: 7323 bytes --]

[-- Attachment #1.5: Type: text/plain, Size: 1300 bytes --]


The above is a screenshot of Emacs with the patch applied opened in GIMP
and zoomed in very far.  I've placed the crosshair on the problematic
pixel column.

If you know why that happens, this could constitute a fix with that
tweak applied.

Just using :align-to header-line-indent-width appears to have even worse
results, because ISTM that it gets rounded after scaling is applied, so
it is of the wrong width by different amounts for each text-scale.  Even
without any text-scale applied, it has the same extra-pixel problem.

I think the above is close to correct, though, it perhaps implies that
header-line-indent-mode should get some love in order to be
pixel-perfect in pixel specifications too.

>> Interestingly, changing text-scale-remap-header-line appears to have no
>> effect, but that variable ought to be accounted for somehow also, I
>> think?  Though, if the line-numbers and header line always use the same
>> face, then the above should be correct, I think?
>
> If you take a look at ruler-mode.el, you will see that it overrides
> header-line-format by its own code.

Yes, but the name and logic in text-scale seemed to imply to me that
text-scale would take the header-line-format set up by ruler-mode and
"alter" it somehow.
-- 
Arsen Arsenović

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 381 bytes --]

      reply	other threads:[~2024-12-29 12:06 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-12-28 21:15 bug#75168: 31.0.50; text-scale confuses ruler-mode when display-line-number-mode is active Arsen Arsenović via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-12-29  6:37 ` Eli Zaretskii
2024-12-29 12:06   ` Arsen Arsenović via Bug reports for GNU Emacs, the Swiss army knife of text editors [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=86y0zypuc4.fsf@aarsen.me \
    --to=bug-gnu-emacs@gnu.org \
    --cc=75168@debbugs.gnu.org \
    --cc=arsen@aarsen.me \
    --cc=eliz@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).