💾 Archived View for idiomdrottning.org › format-flowed captured on 2023-09-28 at 16:11:34. Gemini links have been rewritten to link to archived content
⬅️ Previous capture (2023-03-20)
-=-=-=-=-=-=-
According to RFC 2646, email apps should:
Space-stuff lines which start with a space, “From ”, or “>”.
So I’m gonna argue against an RFC should here.
The intent behind this particular should is to prevent lines that normally start with a greater-than character to be misinterpreted as if they were quote characters. I’m hard pressed to come up with even one example but I’m sure there are some math situation or something where it could conceivably come up. The intent was that there should be some sort of UI widget to explicitly mark text as “quoted”.
My recommendation is that MUAs (including webmail interfaces) should not space-stuff lines that start with a “>” character, and if there is a line that starts with “ >” (a single space in front of the >), leave those alone too.
That way, if math nerds want to send non-quoted lines that do start with a >, they still can, they just add a space in front of them manually.
Still space stuff lines that start with “From ”, and lines (other than “ >”) that start with a space.
Format=Flowed is otherwise a fantastic format. It solves a lot of email’s problems. The next section (4.2) in the RFC is still great. Non–space-stuffed lines starting with a > are marked as quoted. Perfect, that’s exactly what we want. In other words, I am not suggesting changing the format or the on-the-wire protocol. I’m only talking about a way to make generating this format more palatable for text area based interfaces.
Email is a text format and having to reach for a formatting menu or toolbar just to mark some text as quoted falls apart pretty quickly, as does trying to interleave your own responses in between the quoted lines. Those interfaces work for top-posting and bottom-posting, and that’s great, but they make inline-posting impossible.
Thank you, Delta Chat, for having implemented this after I complained about it.
There are some variants of markdown where every linebreak is hard, just like gemtext, but in original markdown you mark hard linebreaks with two spaces at the end of the line (before the break), and blank lines are also hard.
Format=Flowed is the other way around. Soft linebreaks are marked with a single space at the end of the line, before the break.
Therefore, to convert, one way is to add a space to the end of every line, then remove three spaces from lines that now have three spaces, then remove one space from lines that only contain that space and nothing else, then remove one space from lines before a blank line.
Another way to do it is go from top to bottom; if there are two spaces, just remove them, otherwise, if there is text (the line is non-blank) on both the current and the next line, add one space to the current line.