diff options
| author | Michele Calgaro <michele.calgaro@yahoo.it> | 2025-02-04 17:59:57 +0900 | 
|---|---|---|
| committer | Michele Calgaro <michele.calgaro@yahoo.it> | 2025-02-09 19:21:23 +0900 | 
| commit | fd79f0c8b020ff0c60b62c83745beb030ef38997 (patch) | |
| tree | 9c9b0f1801b49d6d674685e257247db95df12a9f /src/kernel/qtextengine.cpp | |
| parent | 7f62b55432d2a5712694dec689f1ce4f07bc70a4 (diff) | |
| download | tqt-fd79f0c8b020ff0c60b62c83745beb030ef38997.tar.gz tqt-fd79f0c8b020ff0c60b62c83745beb030ef38997.zip | |
Extend work on supporting surrogate characters done in commit e0a38072
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
(cherry picked from commit 486aa07930e7b6e900f77e64726c8cc4110511d8)
Diffstat (limited to 'src/kernel/qtextengine.cpp')
| -rw-r--r-- | src/kernel/qtextengine.cpp | 107 | 
1 files changed, 56 insertions, 51 deletions
| diff --git a/src/kernel/qtextengine.cpp b/src/kernel/qtextengine.cpp index 7ada261e9..3af2aa309 100644 --- a/src/kernel/qtextengine.cpp +++ b/src/kernel/qtextengine.cpp @@ -800,72 +800,77 @@ static void calcLineBreaks(const TQString &str, TQCharAttributes *charAttributes  {      int len = str.length();      if (!len) -        return; +	return;      const TQChar *uc = str.unicode();      int cls = lineBreakClass(*uc);      if (cls >= TQUnicodeTables::LineBreak_CM) -        cls = TQUnicodeTables::LineBreak_ID; +	cls = TQUnicodeTables::LineBreak_ID;      charAttributes[0].softBreak = FALSE;      charAttributes[0].whiteSpace = (cls == TQUnicodeTables::LineBreak_SP);      charAttributes[0].charStop = TRUE; -    for (int i = 1; i < len; ++i) { -        int ncls = ::lineBreakClass(uc[i]); -        int category = ::category(uc[i]); -        if (category == TQChar::Mark_NonSpacing) -            goto nsm; -         -        if (category == TQChar::Other_Surrogate) { -            // char stop only on first pair -            if (uc[i].isHighSurrogate() && i < (len - 1) && uc[i + 1].isLowSurrogate()) -                goto nsm; -            // ### correctly handle second surrogate -        } - -        if (ncls == TQUnicodeTables::LineBreak_SP) { -            charAttributes[i].softBreak = FALSE; -            charAttributes[i].whiteSpace = TRUE; -            charAttributes[i].charStop = TRUE; -            cls = ncls; -            continue; -        } +    bool prevIsHighSurrogate = uc[0].isHighSurrogate(); +    for (int i = 1; i < len; ++i) +    { +	// Don't stop on low surrogate characters of complete valid pairs +	if (prevIsHighSurrogate && uc[i].isLowSurrogate()) +	{ +	    prevIsHighSurrogate = false; +	    charAttributes[i].softBreak = FALSE; +	    charAttributes[i].whiteSpace = FALSE; +	    charAttributes[i].charStop = FALSE; +	    continue; +	} +	prevIsHighSurrogate = uc[i].isHighSurrogate(); +	int ncls = ::lineBreakClass(uc[i]); +	int category = ::category(uc[i]); +	if (category == TQChar::Mark_NonSpacing) +	{ +	    charAttributes[i].softBreak = FALSE; +	    charAttributes[i].whiteSpace = FALSE; +	    charAttributes[i].charStop = FALSE; +	    continue; +	} -	if (cls == TQUnicodeTables::LineBreak_SA && ncls == TQUnicodeTables::LineBreak_SA) { -            // two complex chars (thai or lao), thai_attributes might override, but here -            // we do a best guess -            charAttributes[i].softBreak = TRUE; -            charAttributes[i].whiteSpace = FALSE; -            charAttributes[i].charStop = TRUE; -            cls = ncls; -            continue; -        } -        { -	    int tcls = ncls; -	    if (tcls >= TQUnicodeTables::LineBreak_SA) -		tcls = TQUnicodeTables::LineBreak_ID; -	    if (cls >= TQUnicodeTables::LineBreak_SA) -		cls = TQUnicodeTables::LineBreak_ID; - -	    bool softBreak; -	    int brk = breakTable[cls][tcls]; -	    if (brk == Ibk) -		softBreak = (cls == TQUnicodeTables::LineBreak_SP); -	    else -		softBreak = (brk == Dbk); -//        tqDebug("char = %c %04x, cls=%d, ncls=%d, brk=%d soft=%d", uc[i].cell(), uc[i].unicode(), cls, ncls, brk, charAttributes[i].softBreak); -	    charAttributes[i].softBreak = softBreak; +	if (ncls == TQUnicodeTables::LineBreak_SP) { +	    charAttributes[i].softBreak = FALSE; +	    charAttributes[i].whiteSpace = TRUE; +	    charAttributes[i].charStop = TRUE; +	    cls = ncls; +	    continue; +	} + +	if (cls == TQUnicodeTables::LineBreak_SA && ncls == TQUnicodeTables::LineBreak_SA) +	{ +	    // two complex chars (thai or lao), thai_attributes might override, but here +	    // we do a best guess +	    charAttributes[i].softBreak = TRUE;  	    charAttributes[i].whiteSpace = FALSE;  	    charAttributes[i].charStop = TRUE;  	    cls = ncls; +	    continue;  	} -        continue; -    nsm: -        charAttributes[i].softBreak = FALSE; -        charAttributes[i].whiteSpace = FALSE; -        charAttributes[i].charStop = FALSE; + +	int tcls = ncls; +	if (tcls >= TQUnicodeTables::LineBreak_SA) +	    tcls = TQUnicodeTables::LineBreak_ID; +	if (cls >= TQUnicodeTables::LineBreak_SA) +	    cls = TQUnicodeTables::LineBreak_ID; + +	bool softBreak; +	int brk = breakTable[cls][tcls]; +	if (brk == Ibk) +	    softBreak = (cls == TQUnicodeTables::LineBreak_SP); +	else +	    softBreak = (brk == Dbk); +	// tqDebug("char = %c %04x, cls=%d, ncls=%d, brk=%d soft=%d", uc[i].cell(), uc[i].unicode(), cls, ncls, brk, charAttributes[i].softBreak); +	charAttributes[i].softBreak = softBreak; +	charAttributes[i].whiteSpace = FALSE; +	charAttributes[i].charStop = TRUE; +	cls = ncls;      }  } | 
