extern crate gtk; extern crate gtk_sys; extern crate gio; extern crate gdk; extern crate gdk_sys; extern crate glib; extern crate cairo; extern crate pango; extern crate pangocairo; extern crate neovim_lib; extern crate phf; mod nvim; mod ui_model; mod ui; mod input; mod settings; use std::thread; use std::env; use gio::ApplicationExt; const BIN_PATH_ARG: &'static str = "--nvim-bin-path"; fn main() { let app = gtk::Application::new(Some("org.gtk.neovim-gtk"), gio::ApplicationFlags::empty()).expect("Failed to initialize GTK application"); app.connect_activate(activate); let args: Vec = env::args().collect(); let argv: Vec<&str> = args.iter().filter(|a| !a.starts_with(BIN_PATH_ARG)).map(String::as_str).collect(); app.run(argv.len() as i32, &argv); } fn activate(app: >k::Application) { ui::UI.with(|ui_cell| { let mut ui = ui_cell.borrow_mut(); ui.init(app); let path = nvim_bin_path(); nvim::initialize(&mut *ui, path.as_ref()).expect("Can't start nvim instance"); guard_dispatch_thread(&mut *ui); }); } fn nvim_bin_path() -> Option { std::env::args() .skip_while(|a| !a.starts_with(BIN_PATH_ARG)) .map(|p| p.split('=').nth(1).map(str::to_owned)) .nth(0) .unwrap_or(None) } fn guard_dispatch_thread(ui: &mut ui::Ui) { let guard = ui.nvim().session.take_dispatch_guard(); thread::spawn(move || { guard.join().expect("Can't join dispatch thread"); glib::idle_add(move || { ui::UI.with(|ui_cell| { ui_cell.borrow().destroy(); }); glib::Continue(false) }); }); }