<html>
<head>
<base href="https://bugs.documentfoundation.org/">
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_UNCONFIRMED "
title="UNCONFIRMED - EDITING: Automatic cell alignment in Calc breaks with bidi-neutral characters"
href="https://bugs.documentfoundation.org/show_bug.cgi?id=119961">119961</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>EDITING: Automatic cell alignment in Calc breaks with bidi-neutral characters
</td>
</tr>
<tr>
<th>Product</th>
<td>LibreOffice
</td>
</tr>
<tr>
<th>Version</th>
<td>6.0.3.2 release
</td>
</tr>
<tr>
<th>Hardware</th>
<td>x86-64 (AMD64)
</td>
</tr>
<tr>
<th>OS</th>
<td>Linux (All)
</td>
</tr>
<tr>
<th>Status</th>
<td>UNCONFIRMED
</td>
</tr>
<tr>
<th>Severity</th>
<td>normal
</td>
</tr>
<tr>
<th>Priority</th>
<td>medium
</td>
</tr>
<tr>
<th>Component</th>
<td>Calc
</td>
</tr>
<tr>
<th>Assignee</th>
<td>libreoffice-bugs@lists.freedesktop.org
</td>
</tr>
<tr>
<th>Reporter</th>
<td>vaaydayaasra@gmail.com
</td>
</tr></table>
<p>
<div>
<pre>Description:
Calc seems to assign the alignment of any particular text cell based on the
contents of the cell: if the first character is a LTR character, the cell is
aligned to the left, and if the first character is RTL, the cell is aligned to
the right. This is desirable behavior but it breaks when the first character is
neutral, i.e. a character that behaves as RTL in an RTL context and as LTR in a
LTR context.
See the attached screenshot where cell A1 "abc" is automatically aligned to the
left and cell A2 "ابت" to the right. When I surround these strings with
parentheses, which are bidi-neutral characters, in A3 and A4, both are aligned
to the left. For some reason, even font metrics break with this assignment, as
the last character of the Arabic string overlaps visually with the closing
parenthesis (I filed this as a separate issue at
<a class="bz_bug_link
bz_status_UNCONFIRMED "
title="UNCONFIRMED - EDITING: Font metrics mixed up for RTL insets in a LTR context in Calc"
href="show_bug.cgi?id=119960">https://bugs.documentfoundation.org/show_bug.cgi?id=119960</a>).
In column C, I have copied the contents of column A but changed the
directionality setting of cell C4 manually to RTL through Format Cells > Text
direction. Here the cell is properly aligned to the right and the closing
parenthesis does not overlap with the last character of the string.
According to the Unicode standard, neutral characters should not affect
directionality, and that’s what I would expect as a user, too. I think the best
solution would be for Calc to skip all neutral characters in the beginning of
the string and just consider the first strong character for cell alignment.
Even better, Calc could use this heuristics to assign full text directionality
for the cell, not just change alignment. Right now, if you start the cell with
an RTL character followed by a LTR inset and then continue with RTL again, the
substrings are ordered as in a LTR context ("FIRST second THIRD"), not as in
true RTL ("THIRD second FIRST").
This bug was first reported for LO 6.0.3.2 on Launchpad at
<a href="https://bugs.launchpad.net/ubuntu/+source/libreoffice/+bug/1793126">https://bugs.launchpad.net/ubuntu/+source/libreoffice/+bug/1793126</a> . Another
user there confirmed the bug on LO 6.0.3.2 and 6.1.1.2.
Steps to Reproduce:
1. In an empty Calc cell with default directionality, write some text in Arabic
enclosed in parentheses.
Actual Results:
The cell is automatically aligned to the left.
Expected Results:
The cell should be aligned to the right, as parentheses are bidi-neutral and
should not affect directionality at all.
Reproducible: Always
User Profile Reset: No
Additional Info:</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the assignee for the bug.</li>
</ul>
</body>
</html>