Fix two time run
This commit is contained in:
parent
10afc750e8
commit
e719535d2a
@ -40,14 +40,17 @@ fn main() {
|
||||
fn activate(app: >k::Application) {
|
||||
ui::UI.with(|ui_cell| {
|
||||
let mut ui = ui_cell.borrow_mut();
|
||||
if !ui.initialized {
|
||||
ui.init(app);
|
||||
|
||||
let path = nvim_bin_path(std::env::args());
|
||||
let open_arg = open_arg();
|
||||
nvim::initialize(&mut *ui, path.as_ref(), open_arg.as_ref())
|
||||
nvim::initialize(&mut *ui, path.as_ref())
|
||||
.expect("Can't start nvim instance");
|
||||
|
||||
guard_dispatch_thread(&mut *ui);
|
||||
}
|
||||
|
||||
nvim::open_file(ui.nvim(), open_arg().as_ref());
|
||||
});
|
||||
}
|
||||
|
||||
|
13
src/nvim.rs
13
src/nvim.rs
@ -65,8 +65,7 @@ macro_rules! try_uint {
|
||||
}
|
||||
|
||||
pub fn initialize(ui: &mut Ui,
|
||||
nvim_bin_path: Option<&String>,
|
||||
open_arg: Option<&String>)
|
||||
nvim_bin_path: Option<&String>)
|
||||
-> Result<()> {
|
||||
let session = if let Some(path) = nvim_bin_path {
|
||||
Session::new_child_path(path)?
|
||||
@ -84,13 +83,15 @@ pub fn initialize(ui: &mut Ui,
|
||||
nvim.ui_attach(80, 24, UiAttachOptions::new()).map_err(|e| Error::new(ErrorKind::Other, e))?;
|
||||
nvim.command("runtime! ginit.vim").map_err(|e| Error::new(ErrorKind::Other, e))?;
|
||||
|
||||
if let Some(ref file) = open_arg {
|
||||
nvim.command(&format!("e {}", file)).report_err(nvim);
|
||||
}
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
pub fn open_file(nvim: &mut NeovimApi, file: Option<&String>) {
|
||||
if let Some(file_name) = file {
|
||||
nvim.command(&format!("e {}", file_name)).report_err(nvim);
|
||||
}
|
||||
}
|
||||
|
||||
fn nvim_cb(method: &str, params: Vec<Value>) {
|
||||
match method {
|
||||
"redraw" => {
|
||||
|
@ -46,6 +46,7 @@ enum NvimMode {
|
||||
|
||||
pub struct Ui {
|
||||
pub model: UiModel,
|
||||
pub initialized: bool,
|
||||
nvim: Option<Neovim>,
|
||||
drawing_area: DrawingArea,
|
||||
window: Option<ApplicationWindow>,
|
||||
@ -82,6 +83,7 @@ impl Ui {
|
||||
mouse_enabled: false,
|
||||
mouse_pressed: false,
|
||||
font_desc: FontDescription::from_string(FONT_NAME),
|
||||
initialized: false,
|
||||
}
|
||||
}
|
||||
|
||||
@ -98,6 +100,11 @@ impl Ui {
|
||||
}
|
||||
|
||||
pub fn init(&mut self, app: >k::Application) {
|
||||
if self.initialized {
|
||||
return
|
||||
}
|
||||
self.initialized = true;
|
||||
|
||||
SET.with(|settings| {
|
||||
let mut settings = settings.borrow_mut();
|
||||
settings.init(self);
|
||||
|
Loading…
Reference in New Issue
Block a user