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:
Kirill Chibisov 2022-10-10 00:13:37 +03:00 committed by GitHub
parent 71094e5703
commit f6ca8515ab
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 14 additions and 2 deletions

View file

@ -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

View file

@ -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,