On Mon, 22 May 2023 14:21:33 GMT, Karthik P K <k...@openjdk.org> wrote:
>> Since surrogate pairs are internally considered as 2 characters and text >> field is null in `HitInfo` when `getInsertionIndex` is invoked from >> `TextFlow`, wrong insertion index was returned. >> >> Updated code to calculate insertion index in `getHitInfo` method of >> `PrismTextLayout` class when `hitTest` of trailing side of surrogate pair is >> requested. Since text runs are processed in this method already, calculating >> the insertion index in this method looks better than calculating in >> `getInsertionIndex` of `HitInfo` method. >> The latter approach also requires the text to be sent to `HitInfo` as >> parameter from the `hitTest` method of `TextFlow`. If the number of `Text` >> nodes in `TextFlow` are very large, processing all the `Text` nodes on each >> `hitTest` method invocation might cause performance issue. Hence implemented >> first approach. >> >> Added system test to validate the fix. > > Karthik P K has updated the pull request with a new target base due to a > merge or a rebase. The pull request now contains eight commits: > > - Merge master to resolve merge conflict > - Stabilizing the system tests > - Add new test. Optimizations to make the tests robust > - Change insertion index initialization approach. Add additional test > - Initialize insertion index in PrismTextLayout > - Address code review > - Fix insertion index calculation issue with emojis. Add additional test > cases > - Fix insertion index calculation issue in TextFlow verified on macOS, Windows 11. looks good! ------------- Marked as reviewed by angorya (Reviewer). PR Review: https://git.openjdk.org/jfx/pull/1091#pullrequestreview-1436893604