<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><br id="lineBreakAtBeginningOfSignature"><div dir="ltr"><style class="WebKit-mso-list-quirks-style">
<!--
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{mso-style-unhide:no;
mso-style-qformat:yes;
mso-style-parent:"";
margin:0cm;
mso-pagination:widow-orphan;
font-size:11.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-fareast-font-family:"Times New Roman";
mso-fareast-theme-font:minor-fareast;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-bidi-font-family:"Times New Roman";
mso-bidi-theme-font:minor-bidi;
mso-font-kerning:1.0pt;
mso-ligatures:standardcontextual;}
p.MsoListParagraph, li.MsoListParagraph, div.MsoListParagraph
{mso-style-priority:34;
mso-style-unhide:no;
mso-style-qformat:yes;
margin-top:0cm;
margin-right:0cm;
margin-bottom:0cm;
margin-left:36.0pt;
mso-add-space:auto;
mso-pagination:widow-orphan;
font-size:11.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-fareast-font-family:"Times New Roman";
mso-fareast-theme-font:minor-fareast;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-bidi-font-family:"Times New Roman";
mso-bidi-theme-font:minor-bidi;
mso-font-kerning:1.0pt;
mso-ligatures:standardcontextual;}
p.MsoListParagraphCxSpFirst, li.MsoListParagraphCxSpFirst, div.MsoListParagraphCxSpFirst
{mso-style-priority:34;
mso-style-unhide:no;
mso-style-qformat:yes;
mso-style-type:export-only;
margin-top:0cm;
margin-right:0cm;
margin-bottom:0cm;
margin-left:36.0pt;
mso-add-space:auto;
mso-pagination:widow-orphan;
font-size:11.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-fareast-font-family:"Times New Roman";
mso-fareast-theme-font:minor-fareast;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-bidi-font-family:"Times New Roman";
mso-bidi-theme-font:minor-bidi;
mso-font-kerning:1.0pt;
mso-ligatures:standardcontextual;}
p.MsoListParagraphCxSpMiddle, li.MsoListParagraphCxSpMiddle, div.MsoListParagraphCxSpMiddle
{mso-style-priority:34;
mso-style-unhide:no;
mso-style-qformat:yes;
mso-style-type:export-only;
margin-top:0cm;
margin-right:0cm;
margin-bottom:0cm;
margin-left:36.0pt;
mso-add-space:auto;
mso-pagination:widow-orphan;
font-size:11.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-fareast-font-family:"Times New Roman";
mso-fareast-theme-font:minor-fareast;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-bidi-font-family:"Times New Roman";
mso-bidi-theme-font:minor-bidi;
mso-font-kerning:1.0pt;
mso-ligatures:standardcontextual;}
p.MsoListParagraphCxSpLast, li.MsoListParagraphCxSpLast, div.MsoListParagraphCxSpLast
{mso-style-priority:34;
mso-style-unhide:no;
mso-style-qformat:yes;
mso-style-type:export-only;
margin-top:0cm;
margin-right:0cm;
margin-bottom:0cm;
margin-left:36.0pt;
mso-add-space:auto;
mso-pagination:widow-orphan;
font-size:11.0pt;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-fareast-font-family:"Times New Roman";
mso-fareast-theme-font:minor-fareast;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-bidi-font-family:"Times New Roman";
mso-bidi-theme-font:minor-bidi;
mso-font-kerning:1.0pt;
mso-ligatures:standardcontextual;}
.MsoChpDefault
{mso-style-type:export-only;
mso-default-props:yes;
font-family:"Calibri",sans-serif;
mso-ascii-font-family:Calibri;
mso-ascii-theme-font:minor-latin;
mso-fareast-font-family:"Times New Roman";
mso-fareast-theme-font:minor-fareast;
mso-hansi-font-family:Calibri;
mso-hansi-theme-font:minor-latin;
mso-bidi-font-family:"Times New Roman";
mso-bidi-theme-font:minor-bidi;}
@page WordSection1
{size:612.0pt 792.0pt;
margin:70.85pt 70.85pt 70.85pt 70.85pt;
mso-header-margin:36.0pt;
mso-footer-margin:36.0pt;
mso-paper-source:0;}
div.WordSection1
{page:WordSection1;}
/* List Definitions */
@list l0
{mso-list-id:760758770;
mso-list-type:hybrid;
mso-list-template-ids:729199342 -1 69009433 69009435 69009423 69009433 69009435 69009423 69009433 69009435;}
@list l0:level1
{mso-level-text:"%1\)";
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-18.0pt;}
@list l0:level2
{mso-level-number-format:alpha-lower;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-18.0pt;}
@list l0:level3
{mso-level-number-format:roman-lower;
mso-level-tab-stop:none;
mso-level-number-position:right;
text-indent:-9.0pt;}
@list l0:level4
{mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-18.0pt;}
@list l0:level5
{mso-level-number-format:alpha-lower;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-18.0pt;}
@list l0:level6
{mso-level-number-format:roman-lower;
mso-level-tab-stop:none;
mso-level-number-position:right;
text-indent:-9.0pt;}
@list l0:level7
{mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-18.0pt;}
@list l0:level8
{mso-level-number-format:alpha-lower;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-18.0pt;}
@list l0:level9
{mso-level-number-format:roman-lower;
mso-level-tab-stop:none;
mso-level-number-position:right;
text-indent:-9.0pt;}
-->
</style><p class="MsoNormal" style="-webkit-text-size-adjust: auto;">Well, ”curses” was a solution for last century’s problems.<o:p></o:p></p><p class="MsoListParagraphCxSpFirst" style="text-indent:-18.0pt;mso-list:l0 level1 lfo1"><!--[if !supportLists]-->1)<span style="font-style: normal; font-variant-caps: normal; font-stretch: normal; font-size: 7pt; line-height: normal; font-family: "Times New Roman"; font-size-adjust: none; font-kerning: auto; font-variant-alternates: normal; font-variant-ligatures: normal; font-variant-numeric: normal; font-variant-east-asian: normal; font-variant-position: normal; font-feature-settings: normal; font-optical-sizing: auto; font-variation-settings: normal;"> </span><!--[endif]-->Covers just very limited functionality, no parameters.<o:p></o:p></p><p class="MsoListParagraphCxSpMiddle" style="text-indent:-18.0pt;mso-list:l0 level1 lfo1"><!--[if !supportLists]-->2)<span style="font-style: normal; font-variant-caps: normal; font-stretch: normal; font-size: 7pt; line-height: normal; font-family: "Times New Roman"; font-size-adjust: none; font-kerning: auto; font-variant-alternates: normal; font-variant-ligatures: normal; font-variant-numeric: normal; font-variant-east-asian: normal; font-variant-position: normal; font-feature-settings: normal; font-optical-sizing: auto; font-variation-settings: normal;"> </span><!--[endif]-->Approximately the same functionality for all.<o:p></o:p></p><p class="MsoListParagraphCxSpLast" style="text-indent:-18.0pt;mso-list:l0 level1 lfo1"><!--[if !supportLists]-->3)<span style="font-style: normal; font-variant-caps: normal; font-stretch: normal; font-size: 7pt; line-height: normal; font-family: "Times New Roman"; font-size-adjust: none; font-kerning: auto; font-variant-alternates: normal; font-variant-ligatures: normal; font-variant-numeric: normal; font-variant-east-asian: normal; font-variant-position: normal; font-feature-settings: normal; font-optical-sizing: auto; font-variation-settings: normal;"> </span><!--[endif]-->But different manufacturers, or different models, had different controls to invoke each function. “Curses” did help in that context.<o:p></o:p></p><p class="MsoNormal" style="-webkit-text-size-adjust: auto;">But with ECMA-48, the popularity of xterm (and derivatives), and the obsolescence of physical terminals by the use of terminal emulators, that solution is already obsolete. It is hard to see that it would have any future, since it is so limiting.<o:p></o:p></p><p class="MsoNormal" style="-webkit-text-size-adjust: auto;"><br></p><p class="MsoNormal" style="-webkit-text-size-adjust: auto;">/Kent K</p></div><div dir="ltr"><br><blockquote type="cite">11 jan. 2024 kl. 11:35 skrev Giacomo Catenazzi <cate@cateee.net>:<br><br></blockquote></div><blockquote type="cite"><div dir="ltr"><span>On 9 Jan 2024 23:12, Kent Karlsson wrote:</span><br><span>(...)</span><br><span></span><br><span>Let's skip a lot of *details*.</span><br><span></span><br><blockquote type="cite"><blockquote type="cite"><span></span><br></blockquote></blockquote><blockquote type="cite"><blockquote type="cite"><span>But how do you input the formatting?</span><br></blockquote></blockquote><blockquote type="cite"><span>For output to a terminal emulator from a program, the source program would have string constants for control sequences or parts thereof, just like done now.</span><br></blockquote><blockquote type="cite"><span>For a styling enhanced plain text editor one should be able to select a text portion, and then use a menu or keyboard shortcut to select a styling, as it is done in just about any modern text editor. There is no need for an end user to see the styling codes. Using something like HTML syntax would have terrible consequences in that it is hard to tell content from controls. For HTML for instance one MUST use < for <, so that it is not taken as start of a “tag”. That is absolutely nothing you want to see for a terminal, nor for a styling enhanced plain text editor.</span><br></blockquote><span></span><br><span>I dislike this part, and I think it is the main problem.</span><br><span></span><br><span>Note: I'm actively fighting the use of "string constants" for CSI, in programs. Note: maybe we have a different interpretation.</span><br><span></span><br><span>For emulators I want that they uses libraries or at least they check terminal capabilities and they issues formatting codes (CSI, from ECMA-48 or common usage which are de-facto standards).</span><br><span></span><br><span>Every terminal emulator is different, and users want to use it also differently (so changing the settings). A programmer should not make a choice for me.</span><br><span></span><br><span>Do a program want to print on console? I'm ok that it may write some warnings in colours (but often they fails: they assume a background colour (and please: it is my choice!)), if I want to write to a log file, no CSI codes.</span><br><span></span><br><span>Hard coded formatting code are bad (and BTW html strongly discourage them, for reason: we learn from past).</span><br><span></span><br><span>And now I stop with the first rant.</span><br><span></span><br><span></span><br><span>HTML (and LaTeX) can format text according the medium, and HTML is responsive. I find no good way to do it with ECMA-48 style. We can ask the size of the screen, or get a signal when it changes, but there is not real support on emulators: rendering is performed by programs (e.g. using dialog, or directly with curses library). Could you find a good way to display in a sensible way tables with different terminal widths (starting from 40 or less columns?). It is not code we want in most (or any) terminal emulator.</span><br><span></span><br><span>But also in an editor...I feel that programmers must transform it in html/css, do the rendering with existing libraries (which they are huge), and render it as text + CSI.</span><br><span></span><br><span></span><br><span>What problem are you solving? Real case problem. The more I look the proposal, the more I think other tools are much easier and simpler.</span><br><span></span><br><span>Note: HTML with years solved many problems (also considering colour blind people, printing, etc.). Note: HTML as technology, not what we got from web (but so, possibly you should implement your proposal in that way: you just convert CSI to html (DOM), and lets' display it): so we have a real case to look. (and there are already libraries that do it, but without your extension proposal).</span><br><span></span><br><span>Your proposal is in any case doesn't maintain plain text: CSI sequences have punctuation, letters and numbers. So there is no much differences of text in elements and tags in HTML: a program/person which want the plain text, e.g. for copy/past, must do a lot of work removing formatting. In modern html is easy.</span><br><span></span><br><span></span><br><span>I find it would have been nice idea if we were in 1990s (and so an alternative of HTML), but now we have good designs, so do not let's to duplicate the huge work HTML did in past). For a practical point (if I need to implement it): just a filter to a DOM engine (which at the end would be a subset of existing HTML engines) and a rendering (which trend go in direction of HTML like formatting API for different graphical environment).</span><br><span></span><br><span></span><br><span>And in any case, you should start at a higher layer: show programs, and if it is useful emulators and editors will adopt it. Or like tmux (so a sort of filter, and IIRC in past some *extensions*, e.g. the UTF-8 where done first as filter between user and terminal emulator.</span><br><span></span><br><span> cate</span><br></div></blockquote></body></html>