This is an interesting question.

It seems the task of parsing a text into sequences depends on the purpose. Not all sequences of interest are named and, in the general case, not all attempts at parsing may be unique. In this case, it looks like the named sequences would correspond to a specific (ligated) glyph that matches a user-perceived unit of the writing system.

Such a parsing task is akin to scanning, for example, strings using the Latin script for ligatures - while trying to emulate the rules that were in effect during days of hot metal typesetting for certain languages. For example, it wasn't enough to know that a certain cluster of letters might have a ligature glyph, one would also have to know whether the cluster straddled a (compound) word boundary or not. Just knowing the specification of ligated sequences alone would not be enough to identify a correct parse.

Such rules, however, are usually not part of the Unicode standard.

The situation here is similar; the standard simply specifies that a certain sequence of code points has a collective name. In case of ambiguities, you'll have to turn to external sources to resolve them.

Now, if this isthe only such ambiguity (or one of a very small number) and if identification of the correct sequence is essential for selecting the correct rendering, I don't see why the script description for Sinhala couldn't be augmented to discuss that issue.

In which case, the way to proceed is to assemble the full set of facts and submit them to the UTC using the reporting form on the website.

A./


On 10/14/2016 10:07 AM, Martin Jansche wrote:
For Sinhala, the following named sequences are defined (for good reasons):

SINHALA CONSONANT SIGN YANSAYA;0DCA 200D 0DBA
SINHALA CONSONANT SIGN RAKAARAANSAYA;0DCA 200D 0DBB
SINHALA CONSONANT SIGN REPAYA;0DBB 0DCA 200D

I'll abbreviate these as Yansaya, Rakaransaya, and Repaya, and I'll write Ya for 0DBA and Ra for 0DBB.

Note that these give rise to two potentially ambiguous codepoint strings, namely

  0DBB 0DCA 200D 0DBA
  0DBB 0DCA 200D 0DBB

I'll concentrate on the first, as all arguments apply to the second one analogously.

At a first glance, the sequence 0DBB 0DCA 200D 0DBA has two possible parses:

  0DBB + 0DCA 200D 0DBA, i.e. Ra + Yansaya
  0DBB 0DCA 200D + 0DBA, i.e. Repaya + Ya

First question: Does the standard give any guidance as to which one is the intended parse? The section on Sinhala in the Unicode Standard is silent about this. Is there a general principle I'm missing?

Sri Lanka Standard SLS 1134 (2004 draft) states that Ra+Yansaya is not used and is considered incorrect, suggesting that the second parse (Repaya+Ya) should be the default interpretation of this sequence. However, SLS 1134 does not address the potential ambiguity of this sequence explicitly and the description there could be read as informative, not normative.

Second question: Given that one parse of this sequence should be the default, how does one represent the non-default parse?

In most cases one can guess what the intended meaning is, but I suspect this is somewhat of a gray area. In practice, trying to render these problematic sequences and their neighbors in HarfBuzz with a variety of fonts results in a variety of outcomes (including occasionally unexpected glyph choices). If the meaning of these sequences is not well defined, that would partly explain the variation across fonts.

Am I missing something fundamental? If not, it seems this issue should be called out explicit in some part of the standard.

Regards,
-- martin


Reply via email to