From: "Gerd Möllmann" <gerd.moellmann@gmail.com>
To: Mohsin Kaleem <mohkale@kisara.moe>
Cc: 75024@debbugs.gnu.org
Subject: bug#75024: [PATCH] Fix check for underlining capability on ttys
Date: Sun, 05 Jan 2025 12:48:54 +0100 [thread overview]
Message-ID: <m2bjwlv5uh.fsf@gmail.com> (raw)
In-Reply-To: <874j2dh4q5.fsf@kisara.moe> (Mohsin Kaleem's message of "Sun, 05 Jan 2025 11:36:50 +0000")
Mohsin Kaleem <mohkale@kisara.moe> writes:
> Gerd Möllmann <gerd.moellmann@gmail.com> writes:
>
> Hi there,
>
> Sorry for the late response.
>
>>> I meanwhile found this, to my great surprise:
>>>
>>> #define TTY_CAP_UNDERLINE_STYLED (0x32 & TTY_CAP_UNDERLINE)
>>>
>>> That makes TTY_CAP_UNDERLINE_STYLED == TTY_CAP_UNDERLINE. And this test
>>> in tty_capable_p
>>>
>>> TTY_CAPABLE_P_TRY (tty,
>>> TTY_CAP_UNDERLINE, tty->TS_enter_underline_mode,
>>> NC_UNDERLINE);
>>> TTY_CAPABLE_P_TRY (tty,
>>> TTY_CAP_UNDERLINE_STYLED, tty->TF_set_underline_style,
>>>
>>> fails because it tests TTY_CAP_UNDERLINE twice, and requires both
>>> TS_enter_underline_mode and TF_set_underline_style to be usable for
>>> underline support. In Terminal.app, only TS_enter_underline_mode is
>>> available.
>>>
>>> Maybe this should have been
>>>
>>> #define TTY_CAP_UNDERLINE_STYLED 0x40
>>>
>>> ?
>
> Ah, yep. The original intention was or a new bit flag with the existing
> underline bit flag so that styled underlines were only available in
> environments with at least regular underlines. In retrospect that was
> probably excessive and simply checking for styled underline support by
> itself (with a value of 0x40) is sufficient. I'd find it strange to have
> a terminal that supported styled underlines but not regular ones but
> there's no need to enforce this on the Emacs side.
>
>>>
>>> BTW, the 0x32 also also makes no sense to me because of
>>>
>>> #define TTY_CAP_ITALIC 0x10
>>> #define TTY_CAP_STRIKE_THROUGH 0x20
>>>
>>> CC to the original author to check.
>
> Correct here as well, I should've confirmed the binary representation
> :-(.
>
> 0b00000000000000000000000000010000 0o00000000020 0d0000000016 0x00000010
> 0b00000000000000000000000000100000 0o00000000040 0d0000000032 0x00000020
> 0b00000000000000000000000000110010 0o00000000062 0d0000000050 0x00000032
> 0b00000000000000000000000001000000 0o00000000100 0d0000000064 0x00000040
>
> 0x40 is what the next entry in the flag should have been.
Thanks for checking, Mohsin!
Would you perhaps have the time to prepare a patch that fixes this?
next prev parent reply other threads:[~2025-01-05 11:48 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-22 13:13 bug#75024: [PATCH] Fix check for underlining capability on ttys Gerd Möllmann
2024-12-23 5:52 ` Gerd Möllmann
[not found] ` <m2ttauj0lm.fsf@gmail.com>
2025-01-05 4:08 ` Gerd Möllmann
2025-01-05 11:36 ` Mohsin Kaleem
2025-01-05 11:48 ` Gerd Möllmann [this message]
2025-01-05 11:53 ` Mohsin Kaleem
2025-01-05 11:54 ` Gerd Möllmann
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=m2bjwlv5uh.fsf@gmail.com \
--to=gerd.moellmann@gmail.com \
--cc=75024@debbugs.gnu.org \
--cc=mohkale@kisara.moe \
/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).