<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body>
See the old discussion quoted below. I have now found a few more
strings with the same problem. The QML file at
<a class="moz-txt-link-freetext" href="https://invent.kde.org/libraries/kirigami-addons/-/blob/master/src/mobileform/AboutKDE.qml#L99">https://invent.kde.org/libraries/kirigami-addons/-/blob/master/src/mobileform/AboutKDE.qml#L99</a>
has this multiline string:<br>
<blockquote>text: i18nd("kirigami-addons", "Software can always be
improved, and the KDE team is ready to do so. However, you - the
user - must tell us when something does not work as expected or
could be done better.\n<br>
KDE has a bug tracking system. Use the button below to file a bug,
or use the program's About page to report a bug specific to this
application.\n<br>
If you have a suggestion for improvement then you are welcome to
use the bug tracking system to register your wish. Make sure you
use the severity called \"Wishlist\".")<br>
</blockquote>
But the extracted string in the translation file
(kirigami-addons.pot) only contains the first paragraph/line:<br>
<blockquote>msgid "Software can always be improved, and the KDE team
is ready to do so. However, you - the user - must tell us when
something does not work as expected or could be done better.\n"<br>
</blockquote>
<p>Since the two strings don’t match, and the string is always shown
in English in the UI.</p>
<p>There are multiple similar strings in the above file with the
same problem. And probably strings in other files too.<br>
</p>
<p>The problem is that strings like these *seem* to work, i.e., they
are shown in UI as multiline strings. And they generate valid (but
different) strings in .pot file. So it’s very difficult to
discover that there’s a problem at all.<br>
</p>
<p>Is there a way to fix this once and for all, perhaps by changing
the L10N extractor to handle such (not really valid?) multiline
strings, or by changing the compiler toolchain or some automatic
tests to *reject* such strings?<br>
</p>
<div class="moz-cite-prefix"><br>
</div>
<div class="moz-cite-prefix">Karl<br>
</div>
<div class="moz-cite-prefix"><br>
</div>
<div class="moz-cite-prefix">Luigi Toscano skreiv 21.01.2023 15:23:<br>
</div>
<blockquote type="cite"
cite="mid:153a2125-cb1f-252f-5626-dfd015eceb86@tiscali.it">
<pre class="moz-quote-pre" wrap="">Karl Ove Hufthammer ha scritto:
</pre>
<blockquote type="cite">
<pre class="moz-quote-pre" wrap="">In the new ‘Welcome’ app, there’s a long, multi-line string that begins with
the text ‘KDE Connect lets you integrate your phone with your computer in
various ways:’
<a class="moz-txt-link-freetext" href="https://invent.kde.org/plasma/plasma-welcome/-/blob/master/src/contents/ui/pages/PowerfulWhenNeeded.qml#L173-181">https://invent.kde.org/plasma/plasma-welcome/-/blob/master/src/contents/ui/pages/PowerfulWhenNeeded.qml#L173-181</a>
However, in the corresponding POT file (plasma-welcome.pot), only the first
line of the string is present. And if we translate it, the translation is not
being used (as it doesn’t match the original string).
The string in the .qml file was added in 2022, and the POT file last updated
2023-01-19, so it doesn’t seem to be a case of an outdated POT file.
The .qml file uses a normal xi18nc() call, which looks correct. Any ideas
what’s causing the problem?
</pre>
</blockquote>
<pre class="moz-quote-pre" wrap="">
(assing plasma-devel in CC):
I suspect, but please others correct me, this may be related to the handling
of strings in Javascript/QML, as previously discussed here:
<a class="moz-txt-link-freetext" href="https://phabricator.kde.org/D24073">https://phabricator.kde.org/D24073</a> and <a class="moz-txt-link-freetext" href="https://phabricator.kde.org/T11721">https://phabricator.kde.org/T11721</a>
If that's the case, the strings should be reformatted accordingly, either as a
long string on a single line, or using the format:
i18n("foo \
bar \
baz")</pre>
</blockquote>
</body>
</html>