diff options
Diffstat (limited to 'src/lib.rs')
-rw-r--r-- | src/lib.rs | 60 |
1 files changed, 31 insertions, 29 deletions
diff --git a/src/lib.rs b/src/lib.rs index 3211786..fb207aa 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -187,11 +187,12 @@ pub extern crate libc; mod eat; +mod extra_tests; mod infoid; mod internals; mod pluginfo; -mod word; mod strip; +mod word; pub use eat::*; pub use infoid::InfoId; @@ -295,7 +296,8 @@ pub unsafe trait Plugin<'ph> { #[derive(Copy, Clone, Debug, PartialEq, PartialOrd, Eq, Ord, Hash)] pub struct LtPhPtr<'ph> { ph: *mut RawPh, - _lt: PhantomData<&'ph RawPh>, + // 'ph has to be invariant because RawPh is self-referential. + _lt: PhantomData<fn(&'ph ()) -> &'ph ()>, } /// A hexchat plugin handle, used to register hooks and interact with hexchat. @@ -588,33 +590,33 @@ impl<'ph> PluginHandle<'ph> { } } - /// Operates on a virtual plugin. - /// - /// # Examples - /// - /// ```no_run - /// use hexchat_unsafe_plugin::{PluginHandle}; - /// - /// fn contexts_can_be_passed_in(ph: &mut PluginHandle<'_>) { - /// let ctx = ph.get_context(); - /// let mut vplug = ph.plugingui_add("foo", "bar", "baz", "qux"); - /// ph.for_entry_mut(&mut vplug, |ph| { - /// ph.set_context(&ctx); - /// }); - /// } - /// ``` - pub fn for_entry_mut<'eh, F, R>(&mut self, entry: &mut PluginEntryHandle<'ph>, f: F) -> R where F: FnOnce(&mut PluginHandle<'eh>) -> R, 'ph: 'eh { - // we're doing something kinda (very) weird here, but this is the only - // way to get and set pluginprefs for virtual plugins. - // this should be sound. - let data = self.data; - let info = self.info; - let contexts = Rc::clone(&self.contexts); - let mut handle = unsafe { Self::new(data, info, contexts) }; - handle.plugin = entry.entry as *mut RawPh; - handle.set_context(&self.get_context()); - f(&mut handle) - } + ///// Operates on a virtual plugin. + ///// + ///// # Examples + ///// + ///// ```no_run + ///// use hexchat_unsafe_plugin::{PluginHandle}; + ///// + ///// fn contexts_can_be_passed_in(ph: &mut PluginHandle<'_>) { + ///// let ctx = ph.get_context(); + ///// let mut vplug = ph.plugingui_add("foo", "bar", "baz", "qux"); + ///// ph.for_entry_mut(&mut vplug, |ph| { + ///// ph.set_context(&ctx); + ///// }); + ///// } + ///// ``` + //pub fn for_entry_mut<'eh, F, R>(&mut self, entry: &mut PluginEntryHandle<'ph>, f: F) -> R where F: FnOnce(&mut PluginHandle<'eh>) -> R, 'ph: 'eh { + // // we're doing something kinda (very) weird here, but this is the only + // // way to get and set pluginprefs for virtual plugins. + // // this should be sound. + // let data = self.data; + // let info = self.info; + // let contexts = Rc::clone(&self.contexts); + // let mut handle = unsafe { Self::new(data, info, contexts) }; + // handle.plugin = entry.entry as *mut RawPh; + // handle.set_context(&self.get_context()); + // f(&mut handle) + //} /// Registers a virtual plugin. pub fn plugingui_add(&self, filename: &str, name: &str, description: &str, version: &str) -> PluginEntryHandle<'ph> { |