mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-26 03:36:32 +11:00
On X11, fix IME crashing during reload
During reload we were picking old styles, but the styles could change during reload leading to errors during IME building. Fixes #2510.
This commit is contained in:
parent
71094e5703
commit
f6ca8515ab
2 changed files with 14 additions and 2 deletions
|
@ -24,6 +24,7 @@ And please only add new entries to the top of this list, right below the `# Unre
|
||||||
- On Wayland, a new `wayland-csd-adwaita-crossfont` feature was added to use `crossfont` instead of `ab_glyph` for decorations.
|
- On Wayland, a new `wayland-csd-adwaita-crossfont` feature was added to use `crossfont` instead of `ab_glyph` for decorations.
|
||||||
- On Wayland, if not otherwise specified use upstream automatic CSD theme selection.
|
- On Wayland, if not otherwise specified use upstream automatic CSD theme selection.
|
||||||
- On X11, added `WindowExtX11::with_parent` to create child windows.
|
- On X11, added `WindowExtX11::with_parent` to create child windows.
|
||||||
|
- On X11, fixed IME crashing during reload.
|
||||||
|
|
||||||
# 0.27.3
|
# 0.27.3
|
||||||
|
|
||||||
|
|
|
@ -108,10 +108,21 @@ unsafe fn replace_im(inner: *mut ImeInner) -> Result<(), ReplaceImError> {
|
||||||
let mut new_contexts = HashMap::new();
|
let mut new_contexts = HashMap::new();
|
||||||
for (window, old_context) in (*inner).contexts.iter() {
|
for (window, old_context) in (*inner).contexts.iter() {
|
||||||
let spot = old_context.as_ref().map(|old_context| old_context.ic_spot);
|
let spot = old_context.as_ref().map(|old_context| old_context.ic_spot);
|
||||||
let style = old_context
|
|
||||||
|
// Check if the IME was allowed on that context.
|
||||||
|
let is_allowed = old_context
|
||||||
.as_ref()
|
.as_ref()
|
||||||
.map(|old_context| old_context.style)
|
.map(|old_context| old_context.is_allowed())
|
||||||
.unwrap_or_default();
|
.unwrap_or_default();
|
||||||
|
|
||||||
|
// We can't use the style from the old context here, since it may change on reload, so
|
||||||
|
// pick style from the new XIM based on the old state.
|
||||||
|
let style = if is_allowed {
|
||||||
|
new_im.preedit_style
|
||||||
|
} else {
|
||||||
|
new_im.none_style
|
||||||
|
};
|
||||||
|
|
||||||
let new_context = {
|
let new_context = {
|
||||||
let result = ImeContext::new(
|
let result = ImeContext::new(
|
||||||
xconn,
|
xconn,
|
||||||
|
|
Loading…
Add table
Reference in a new issue