Check vim-plug loaded
This commit is contained in:
		
							parent
							
								
									a3eba12b24
								
							
						
					
					
						commit
						b0477c36f6
					
				
							
								
								
									
										11
									
								
								src/nvim.rs
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								src/nvim.rs
									
									
									
									
									
								
							| @ -505,17 +505,24 @@ fn call( | |||||||
|     Ok(repaint_mode) |     Ok(repaint_mode) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub trait ErrorReport { | pub trait ErrorReport<T> { | ||||||
|     fn report_err(&self, nvim: &mut NeovimApi); |     fn report_err(&self, nvim: &mut NeovimApi); | ||||||
|  | 
 | ||||||
|  |     fn ok_and_report(&self, nvim: &mut NeovimApi) -> Option<&T>; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<T> ErrorReport for result::Result<T, CallError> { | impl<T> ErrorReport<T> for result::Result<T, CallError> { | ||||||
|     fn report_err(&self, _: &mut NeovimApi) { |     fn report_err(&self, _: &mut NeovimApi) { | ||||||
|         if let Err(ref err) = *self { |         if let Err(ref err) = *self { | ||||||
|             println!("{}", err); |             println!("{}", err); | ||||||
|             //nvim.report_error(&err_msg).expect("Error report error :)");
 |             //nvim.report_error(&err_msg).expect("Error report error :)");
 | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     fn ok_and_report(&self, nvim: &mut NeovimApi) -> Option<&T> { | ||||||
|  |         self.report_err(nvim); | ||||||
|  |         self.as_ref().ok() | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[derive(Clone, Debug)] | #[derive(Clone, Debug)] | ||||||
|  | |||||||
| @ -1,9 +1,9 @@ | |||||||
| use std::rc::Rc; | use std::rc::Rc; | ||||||
| use std::cell::{RefCell, RefMut}; | use std::cell::{RefCell, RefMut}; | ||||||
| 
 | 
 | ||||||
| use neovim_lib::{Neovim, NeovimApi, Value}; | use neovim_lib::{Neovim, NeovimApi}; | ||||||
| 
 | 
 | ||||||
| use nvim::NeovimClient; | use nvim::{NeovimClient, ErrorReport}; | ||||||
| 
 | 
 | ||||||
| pub struct Manager { | pub struct Manager { | ||||||
|     nvim: Option<Rc<RefCell<NeovimClient>>>, |     nvim: Option<Rc<RefCell<NeovimClient>>>, | ||||||
| @ -11,9 +11,7 @@ pub struct Manager { | |||||||
| 
 | 
 | ||||||
| impl Manager { | impl Manager { | ||||||
|     pub fn new() -> Self { |     pub fn new() -> Self { | ||||||
|         Manager { 
 |         Manager { nvim: None } | ||||||
|             nvim: None, |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     pub fn initialize(&mut self, nvim: Rc<RefCell<NeovimClient>>) { |     pub fn initialize(&mut self, nvim: Rc<RefCell<NeovimClient>>) { | ||||||
| @ -31,10 +29,18 @@ impl Manager { | |||||||
| 
 | 
 | ||||||
|     pub fn get_state(&self) -> State { |     pub fn get_state(&self) -> State { | ||||||
|         if let Some(mut nvim) = self.nvim() { |         if let Some(mut nvim) = self.nvim() { | ||||||
|             nvim.command("exists('g:loaded_plug')"); |             let loaded_plug = nvim.eval("exists('g:loaded_plug')"); | ||||||
|         } |             loaded_plug | ||||||
|         
 |                 .ok_and_report(&mut *nvim) | ||||||
|  |                 .and_then(|loaded_plug| loaded_plug.as_i64()) | ||||||
|  |                 .map_or(State::Unknown, |loaded_plug| if loaded_plug > 0 { | ||||||
|  |                     State::AlreadyLoaded | ||||||
|  |                 } else { | ||||||
|                     State::Unknown |                     State::Unknown | ||||||
|  |                 }) | ||||||
|  |         } else { | ||||||
|  |             State::Unknown | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -9,9 +9,7 @@ pub struct Ui <'a> { | |||||||
| 
 | 
 | ||||||
| impl<'a> Ui<'a> { | impl<'a> Ui<'a> { | ||||||
|     pub fn new(manager: &'a manager::Manager) -> Ui<'a> { |     pub fn new(manager: &'a manager::Manager) -> Ui<'a> { | ||||||
|         Ui { |         Ui { manager } | ||||||
|             manager, |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     pub fn show<T: IsA<gtk::Window>>(&self, parent: &T) { |     pub fn show<T: IsA<gtk::Window>>(&self, parent: &T) { | ||||||
| @ -27,9 +25,24 @@ impl <'a> Ui <'a> { | |||||||
|         let content = dlg.get_content_area(); |         let content = dlg.get_content_area(); | ||||||
|         let tabs = gtk::Notebook::new(); |         let tabs = gtk::Notebook::new(); | ||||||
| 
 | 
 | ||||||
|  |         match self.get_state() { | ||||||
|  |             manager::State::AlreadyLoaded => { | ||||||
|  |                 let get_plugins = gtk::Box::new(gtk::Orientation::Vertical, 0); | ||||||
|  |                 let warn_lbl = gtk::Label::new( | ||||||
|  |                     "Plug manager already loaded.\n\ | ||||||
|  |                                                NeovimGtk manages plugins using vim-plug as backend.\n\ | ||||||
|  |                                                To allow NeovimGtk manage plugins please disable vim-plug in your configuration",
 | ||||||
|  |                 ); | ||||||
|  |                 get_plugins.add(&warn_lbl); | ||||||
|  |                 let get_plugins_lbl = gtk::Label::new("Help"); | ||||||
|  |                 tabs.append_page(&get_plugins, Some(&get_plugins_lbl)); | ||||||
|  |             } | ||||||
|  |             manager::State::Unknown => { | ||||||
|                 let get_plugins = gtk::Box::new(gtk::Orientation::Vertical, 0); |                 let get_plugins = gtk::Box::new(gtk::Orientation::Vertical, 0); | ||||||
|                 let get_plugins_lbl = gtk::Label::new("Get Plugins"); |                 let get_plugins_lbl = gtk::Label::new("Get Plugins"); | ||||||
|                 tabs.append_page(&get_plugins, Some(&get_plugins_lbl)); |                 tabs.append_page(&get_plugins, Some(&get_plugins_lbl)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         let plugins = gtk::Box::new(gtk::Orientation::Vertical, 0); |         let plugins = gtk::Box::new(gtk::Orientation::Vertical, 0); | ||||||
|         let plugins_lbl = gtk::Label::new("Plugins"); |         let plugins_lbl = gtk::Label::new("Plugins"); | ||||||
| @ -49,4 +62,8 @@ impl <'a> Ui <'a> { | |||||||
| 
 | 
 | ||||||
|         dlg.destroy(); |         dlg.destroy(); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     fn get_state(&self) -> manager::State { | ||||||
|  |         self.manager.get_state() | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 daa
						daa