Fix application starting for windows

This commit is contained in:
daa84 2017-03-13 18:03:32 +03:00
parent c538caabfe
commit d7b2c313f8
3 changed files with 109 additions and 48 deletions

View File

@ -14,6 +14,7 @@ mod nvim;
mod ui_model; mod ui_model;
mod ui; mod ui;
mod input; mod input;
mod settings;
use std::thread; use std::thread;
use std::env; use std::env;

84
src/settings.rs Normal file
View File

@ -0,0 +1,84 @@
#[cfg(target_os = "unix")]
use ui::UI;
use ui::Ui;
#[cfg(target_os = "unix")]
use gio;
#[derive(PartialEq)]
pub enum FontSource {
Rpc,
Gnome,
Default,
}
pub struct Settings {
font_source: FontSource,
#[cfg(target_os = "unix")]
gnome_interface_settings: gio::Settings,
}
impl Settings {
#[cfg(target_os = "unix")]
pub fn new() -> Settings {
Settings {
font_source: FontSource::Default,
gnome_interface_settings: gio::Settings::new("org.gnome.desktop.interface"),
}
}
#[cfg(target_os = "windows")]
pub fn new() -> Settings {
Settings {
font_source: FontSource::Default,
}
}
#[cfg(target_os = "unix")]
pub fn init(&mut self, ui: &mut Ui) {
self.gnome_interface_settings.connect_changed(|_, _| monospace_font_changed());
self.update_font(ui);
}
#[cfg(target_os = "windows")]
pub fn init(&mut self, ui: &mut Ui) {
}
#[cfg(target_os = "windows")]
fn update_font(&mut self, ui: &mut Ui) {
}
#[cfg(target_os = "unix")]
fn update_font(&mut self, ui: &mut Ui) {
// rpc is priority for font
if self.font_source == FontSource::Rpc {
return;
}
if let Some(ref font_name) = self.gnome_interface_settings.get_string("monospace-font-name") {
ui.set_font_desc(font_name);
self.font_source = FontSource::Gnome;
}
}
pub fn set_font_source(&mut self, src: FontSource) {
self.font_source = src;
}
}
#[cfg(target_os = "unix")]
fn monospace_font_changed() {
UI.with(|ui_cell| {
let mut ui = ui_cell.borrow_mut();
// rpc is priority for font
if ui.settings.font_source != FontSource::Rpc {
ui.settings.update_font(ui);
ui.on_redraw();
}
});
}

View File

@ -13,24 +13,29 @@ use gtk_sys;
use gdk::{ModifierType, Event, EventKey, EventConfigure, EventButton, EventMotion, EventType}; use gdk::{ModifierType, Event, EventKey, EventConfigure, EventButton, EventMotion, EventType};
use gdk_sys; use gdk_sys;
use glib; use glib;
use gio;
use neovim_lib::{Neovim, NeovimApi, Value, Integer}; use neovim_lib::{Neovim, NeovimApi, Value, Integer};
use ui_model::{UiModel, Cell, Attrs, Color, COLOR_BLACK, COLOR_WHITE, COLOR_RED}; use ui_model::{UiModel, Cell, Attrs, Color, COLOR_BLACK, COLOR_WHITE, COLOR_RED};
use nvim::{RedrawEvents, GuiApi, ErrorReport}; use nvim::{RedrawEvents, GuiApi, ErrorReport};
use settings;
use input::{convert_key, keyval_to_input_string}; use input::{convert_key, keyval_to_input_string};
const FONT_NAME: &'static str = "DejaVu Sans Mono 12"; const FONT_NAME: &'static str = "DejaVu Sans Mono 12";
thread_local!(pub static UI: RefCell<Ui> = { macro_rules! ui_thread_var {
let thread = thread::current(); ($id:ident, $ty:ty, $expr:expr) => (thread_local!(pub static $id: RefCell<$ty> = {
let current_thread_name = thread.name(); let thread = thread::current();
if current_thread_name != Some("main") { let current_thread_name = thread.name();
panic!("Can create UI only from main thread, {:?}", current_thread_name); if current_thread_name != Some("main") {
} panic!("Can create UI only from main thread, {:?}", current_thread_name);
RefCell::new(Ui::new()) }
}); RefCell::new($expr)
});)
}
ui_thread_var![UI, Ui, Ui::new()];
ui_thread_var![SET, settings::Settings, settings::Settings::new()];
#[derive(PartialEq)] #[derive(PartialEq)]
enum NvimMode { enum NvimMode {
@ -39,13 +44,6 @@ enum NvimMode {
Other, Other,
} }
#[derive(PartialEq)]
enum FontSource {
Rpc,
Gnome,
Default,
}
pub struct Ui { pub struct Ui {
pub model: UiModel, pub model: UiModel,
nvim: Option<Neovim>, nvim: Option<Neovim>,
@ -63,8 +61,6 @@ pub struct Ui {
mouse_enabled: bool, mouse_enabled: bool,
mouse_pressed: bool, mouse_pressed: bool,
font_desc: FontDescription, font_desc: FontDescription,
font_source: FontSource,
gnome_interface_settings: gio::Settings,
} }
impl Ui { impl Ui {
@ -86,8 +82,6 @@ impl Ui {
mouse_enabled: false, mouse_enabled: false,
mouse_pressed: false, mouse_pressed: false,
font_desc: FontDescription::from_string(FONT_NAME), font_desc: FontDescription::from_string(FONT_NAME),
gnome_interface_settings: gio::Settings::new("org.gnome.desktop.interface"),
font_source: FontSource::Default,
} }
} }
@ -104,8 +98,10 @@ impl Ui {
} }
pub fn init(&mut self, app: &gtk::Application) { pub fn init(&mut self, app: &gtk::Application) {
self.gnome_interface_settings.connect_changed(|_, _| monospace_font_changed()); SET.with(|settings| {
self.update_font(); let mut settings = settings.borrow_mut();
settings.init(self);
});
self.header_bar.set_show_close_button(true); self.header_bar.set_show_close_button(true);
@ -151,7 +147,7 @@ impl Ui {
self.font_desc.clone() self.font_desc.clone()
} }
fn set_font_desc(&mut self, desc: &str) { pub fn set_font_desc(&mut self, desc: &str) {
self.font_desc = FontDescription::from_string(desc); self.font_desc = FontDescription::from_string(desc);
} }
@ -173,30 +169,6 @@ impl Ui {
(bg, fg) (bg, fg)
} }
} }
fn update_font(&mut self) {
// rpc is priority for font
if self.font_source == FontSource::Rpc {
return;
}
if let Some(ref font_name) = self.gnome_interface_settings.get_string("monospace-font-name") {
self.set_font_desc(font_name);
self.font_source = FontSource::Gnome;
}
}
}
fn monospace_font_changed() {
UI.with(|ui_cell| {
let mut ui = ui_cell.borrow_mut();
// rpc is priority for font
if ui.font_source != FontSource::Rpc {
ui.update_font();
ui.on_redraw();
}
});
} }
fn gtk_button_press(_: &DrawingArea, ev: &EventButton) -> Inhibit { fn gtk_button_press(_: &DrawingArea, ev: &EventButton) -> Inhibit {
@ -542,7 +514,11 @@ fn request_width(ui: &Ui) {
impl GuiApi for Ui { impl GuiApi for Ui {
fn set_font(&mut self, font_desc: &str) { fn set_font(&mut self, font_desc: &str) {
self.set_font_desc(font_desc); self.set_font_desc(font_desc);
self.font_source = FontSource::Rpc;
SET.with(|settings| {
let mut settings = settings.borrow_mut();
settings.set_font_source(settings::FontSource::Rpc);
});
} }
} }