Resize nvim on font change, not window

This commit is contained in:
daa84 2017-09-13 18:34:18 +03:00
parent 94747615af
commit 90fad0fe9c
2 changed files with 57 additions and 48 deletions

View File

@ -47,8 +47,10 @@ impl State {
} }
if let Some(ref font_name) = if let Some(ref font_name) =
self.gnome_interface_settings self.gnome_interface_settings.get_string(
.get_string("monospace-font-name") { "monospace-font-name",
)
{
shell.set_font_desc(font_name); shell.set_font_desc(font_name);
self.font_source = FontSource::Gnome; self.font_source = FontSource::Gnome;
} }
@ -76,11 +78,15 @@ impl Settings {
pub fn init(&mut self) { pub fn init(&mut self) {
let shell = Weak::upgrade(self.shell.as_ref().unwrap()).unwrap(); let shell = Weak::upgrade(self.shell.as_ref().unwrap()).unwrap();
let state = self.state.clone(); let state = self.state.clone();
self.state.borrow_mut().update_font(&mut *shell.borrow_mut()); self.state.borrow_mut().update_font(
&mut *shell.borrow_mut(),
);
self.state self.state
.borrow() .borrow()
.gnome_interface_settings .gnome_interface_settings
.connect_changed(move |_, _| monospace_font_changed(&mut *shell.borrow_mut(), &mut *state.borrow_mut())); .connect_changed(move |_, _| {
monospace_font_changed(&mut *shell.borrow_mut(), &mut *state.borrow_mut())
});
} }
#[cfg(target_os = "windows")] #[cfg(target_os = "windows")]

View File

@ -1,4 +1,4 @@
use std::cell::{RefMut, RefCell}; use std::cell::{RefMut, RefCell, Cell};
use std::rc::Rc; use std::rc::Rc;
use std::sync::Arc; use std::sync::Arc;
use std::ops::Deref; use std::ops::Deref;
@ -48,6 +48,7 @@ macro_rules! idle_cb_call {
) )
} }
#[derive(Clone, Copy)]
enum ResizeState { enum ResizeState {
RequestNvimResize(glib::SourceId), RequestNvimResize(glib::SourceId),
RequestWindowResize, RequestWindowResize,
@ -73,7 +74,7 @@ pub struct State {
im_context: gtk::IMMulticontext, im_context: gtk::IMMulticontext,
error_area: error::ErrorArea, error_area: error::ErrorArea,
resize_state: ResizeState, resize_state: Rc<Cell<ResizeState>>,
options: ShellOptions, options: ShellOptions,
@ -106,7 +107,7 @@ impl State {
im_context: gtk::IMMulticontext::new(), im_context: gtk::IMMulticontext::new(),
error_area: error::ErrorArea::new(), error_area: error::ErrorArea::new(),
resize_state: ResizeState::Wait, resize_state: Rc::new(Cell::new(ResizeState::Wait)),
options, options,
@ -152,7 +153,7 @@ impl State {
pub fn set_font_desc(&mut self, desc: &str) { pub fn set_font_desc(&mut self, desc: &str) {
self.font_ctx.update(FontDescription::from_string(desc)); self.font_ctx.update(FontDescription::from_string(desc));
self.model.clear_glyphs(); self.model.clear_glyphs();
self.update_dirty_glyphs(); self.try_nvim_resize();
self.on_redraw(&RepaintMode::All); self.on_redraw(&RepaintMode::All);
} }
@ -245,8 +246,47 @@ impl State {
self.im_context.reset(); self.im_context.reset();
} }
fn try_nvim_resize(&self) {
match self.resize_state.get() {
ResizeState::RequestWindowResize => {
self.resize_state.set(ResizeState::Wait);
return;
}
ResizeState::RequestNvimResize(timer) => {
glib::source_remove(timer);
}
ResizeState::Wait => (),
}
if !self.nvim.borrow().is_initialized() {
return;
}
let (columns, rows) = self.calc_nvim_size();
let resize_state = self.resize_state.clone();
let nvim = self.nvim.clone();
if self.model.rows == rows && self.model.columns == columns {
return;
}
self.resize_state.set(ResizeState::RequestNvimResize(
gtk::timeout_add(250, move || {
resize_state.set(ResizeState::Wait);
let mut nvim = nvim.borrow_mut();
if let Err(err) = nvim.ui_try_resize(columns as u64, rows as u64) {
error!("Error trying resize nvim {}", err);
}
Continue(false)
}),
));
}
fn resize_main_window(&mut self) { fn resize_main_window(&mut self) {
match self.resize_state { match self.resize_state.get() {
ResizeState::RequestNvimResize(_) => return, ResizeState::RequestNvimResize(_) => return,
_ => (), _ => (),
} }
@ -263,7 +303,7 @@ impl State {
let request_width = (self.model.columns as f64 * char_width) as i32; let request_width = (self.model.columns as f64 * char_width) as i32;
if width != request_width || height != request_height { if width != request_width || height != request_height {
self.resize_state = ResizeState::RequestWindowResize; self.resize_state.set(ResizeState::RequestWindowResize);
let window: gtk::Window = self.drawing_area let window: gtk::Window = self.drawing_area
.get_toplevel() .get_toplevel()
@ -453,7 +493,7 @@ impl Shell {
let ref_state = self.state.clone(); let ref_state = self.state.clone();
state.drawing_area.connect_configure_event(move |_, _| { state.drawing_area.connect_configure_event(move |_, _| {
try_nvim_resize(&ref_state); ref_state.borrow().try_nvim_resize();
false false
}); });
@ -762,42 +802,6 @@ fn init_nvim(state_ref: &Arc<UiMutex<State>>) {
} }
} }
fn try_nvim_resize(state: &Arc<UiMutex<State>>) {
let mut state_ref = state.borrow_mut();
match state_ref.resize_state {
ResizeState::RequestWindowResize => {
state_ref.resize_state = ResizeState::Wait;
return;
}
ResizeState::RequestNvimResize(timer) => {
glib::source_remove(timer);
}
ResizeState::Wait => (),
}
if !state_ref.nvim.borrow().is_initialized() {
return;
}
let (columns, rows) = state_ref.calc_nvim_size();
let state = state.clone();
state_ref.resize_state = ResizeState::RequestNvimResize(gtk::timeout_add(250, move || {
let mut state_ref = state.borrow_mut();
state_ref.resize_state = ResizeState::Wait;
if state_ref.model.rows != rows || state_ref.model.columns != columns {
let nvim = state_ref.nvim();
if let Some(mut nvim) = nvim {
if let Err(err) = nvim.ui_try_resize(columns as u64, rows as u64) {
error!("Error trying resize nvim {}", err);
}
}
}
Continue(false)
}));
}
impl RedrawEvents for State { impl RedrawEvents for State {
fn on_cursor_goto(&mut self, row: u64, col: u64) -> RepaintMode { fn on_cursor_goto(&mut self, row: u64, col: u64) -> RepaintMode {
@ -992,6 +996,5 @@ impl GuiApi for State {
} }
self.set_font_desc(font_desc); self.set_font_desc(font_desc);
self.resize_main_window();
} }
} }