Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

MSC3554: Extensible Events - Translatable Text #3554

Open
wants to merge 6 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Update for MSC1767
  • Loading branch information
turt2live committed Apr 18, 2023
commit 5464232bd409ce94fe516a0015c7e5e3afa8a6f2
10 changes: 5 additions & 5 deletions proposals/3554-extensible-events-translatable-messages.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

[MSC1767](https://github.com/matrix-org/matrix-doc/pull/1767) describes Extensible Events in detail,
though deliberately does not include schemas for some messaging types. This MSC covers translations
on `m.markup` content blocks specifically.
on `m.text` content blocks specifically.

*Rationale*: Splitting the MSCs down into individual parts makes it easier to implement and review in
stages without blocking other pieces of the overall idea. For example, an issue with the way images
Expand All @@ -15,7 +15,7 @@ section for early support of this MSC.

## Proposal

As defined by MSC1767, `m.markup` currently specifies an array with "representations" for the text
As defined by MSC1767, `m.text` currently specifies an array with "representations" for the text
on the event. Clients are expected to find the first representation they can render based on mimetype,
which can be implicit.

Expand All @@ -24,7 +24,7 @@ used in a room, such as announcements or other prepared communications. Less com
(at least without a translation service on the sender's side), the receiving client can use the message
which matches the user's preferred language.

This MSC adds an additional key, `lang`, to the `m.markup` representation schema and adjusts how a
This MSC adds an additional key, `lang`, to the `m.text` representation schema and adjusts how a
client decides upon a representation to include the language in that consideration. The array overall
is still ordered, which means the sender should also supply the language which fits the scenario best
as the first item.
Expand All @@ -35,7 +35,7 @@ An example:
{
"type": "m.message",
"content": {
"m.markup": [
"m.text": [
{
"body": "Je suis un poisson",
"lang": "fr"
Expand All @@ -49,7 +49,7 @@ An example:
}
```

*Note*: `m.markup`'s support for `mimetype` has been excluded from the example for brevity. It is still
*Note*: `m.text`'s support for `mimetype` has been excluded from the example for brevity. It is still
supported in events.

By default, messages are assumed to be sent in English (`en`).
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think it makes a lot of sense to assume a language in this case. There is no fault prove way to guess a language, so many clients will probably default to just sending whatever the user typed without a language. What is the benefit of assuming English, if that is probably wrong in a lot of cases? Shouldn't it rather just be unspecified?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The vast majority of software in the ecosystem makes assumptions about text being English. This is just to help implementations which might be searching for a language code, not to define the language itself.

Unspecified leads to all kinds of issues with software, whereas French-as-default-English is generally fine.

anoadragon453 marked this conversation as resolved.
Show resolved Hide resolved
Expand Down