mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-02-27 04:38:02 +00:00
data:image/s3,"s3://crabby-images/7d1f2/7d1f232ca48a1ce620eb70a6728fbe1e5d53418e" alt="Masayuki Nakano"
`ContentEventHandler` may not replace open/close tags of inline elements and close tags of block elements with a line break etc. Therefore, one offset may mean multiple points in the DOM tree. From the DOM tree point of view, every DOM point may have different meaning and styles. Therefore, if IME sets `Selection` to current range, we should not update `Selection` with the log of `ContentEventHandler`. Otherwise, new content will appear at different position in the DOM tree and it may cause different style text, etc. `IMEContentObserver` has cache of `Selection` while an editor has focus. Therefore, for avoiding the query cost of `Selection` for each `eSetSelection` event, `ContentEventHandler` should be used in `IMEContentObserver` instead if an instance is available. Therefore, this patch makes `TextComposition` delegate the handling to `IMEContentObserver` and check `Selection` range only when `IMEContentObserver` is available. Note that `eSetSelection` is probably used only when editable element has focus. Therefore, it must be fine to skip selection range check in the other cases. Differential Revision: https://phabricator.services.mozilla.com/D171179