summary refs log tree commit diff stats
path: root/src
diff options
context:
space:
mode:
authorSoniEx2 <endermoneymod@gmail.com>2018-10-15 16:32:43 -0300
committerSoniEx2 <endermoneymod@gmail.com>2018-10-15 16:32:43 -0300
commit872f4d72a7c78c882ff19e28f35f9aec4395f791 (patch)
treed8724b5b7a62485299189aba1168593a7b31fa20 /src
parentd6971a712f80be6dad6441b5610e84067d884ecd (diff)
Fix huge oops
Still crashes when reloading tho
Diffstat (limited to 'src')
-rw-r--r--src/lib.rs12
1 files changed, 7 insertions, 5 deletions
diff --git a/src/lib.rs b/src/lib.rs
index a9cd4df..77edf8d 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -1410,7 +1410,8 @@ pub unsafe fn hexchat_plugin_init<T>(plugin_handle: *mut libc::c_void,
 }
 
 #[doc(hidden)]
-pub unsafe fn hexchat_plugin_deinit<T>(plugin_handle: *mut libc::c_void) where T: Plugin {
+pub unsafe fn hexchat_plugin_deinit<T>(plugin_handle: *mut libc::c_void) -> libc::c_int where T: Plugin {
+    let mut safe_to_unload = 1;
     // plugin_handle should never be null, but just in case.
     if !plugin_handle.is_null() {
         let ph = plugin_handle as *mut internals::Ph;
@@ -1420,11 +1421,11 @@ pub unsafe fn hexchat_plugin_deinit<T>(plugin_handle: *mut libc::c_void) where T
                 let mut info: Option<PluginInfo> = None;
                 {
                     let mut ausinfo = ::std::panic::AssertUnwindSafe(&mut info);
-                    catch_unwind(move || {
+                    safe_to_unload = if catch_unwind(move || {
                         let userdata = *pop_userdata(ph);
                         **ausinfo = Some(userdata.pluginfo);
                         userdata.plug.deinit(&mut PluginHandle { ph, info: userdata.pluginfo });
-                    }).ok();
+                    }).is_ok() { 1 } else { 0 };
                 }
                 if let Some(mut info) = info {
                     info.drop_info();
@@ -1438,6 +1439,7 @@ pub unsafe fn hexchat_plugin_deinit<T>(plugin_handle: *mut libc::c_void) where T
     } else {
         eprintln!("hexchat_plugin_deinit called with a null plugin_handle - broken hexchat");
     }
+    safe_to_unload
 }
 
 /// Exports a hexchat plugin.
@@ -1453,8 +1455,8 @@ macro_rules! hexchat_plugin {
             $crate::hexchat_plugin_init::<$t>(plugin_handle, plugin_name, plugin_desc, plugin_version, arg)
         }
         #[no_mangle]
-        pub unsafe extern "C" fn hexchat_plugin_deinit(plugin_handle: *mut $crate::libc::c_void) {
-            $crate::hexchat_plugin_deinit::<$t>(plugin_handle);
+        pub unsafe extern "C" fn hexchat_plugin_deinit(plugin_handle: *mut $crate::libc::c_void) -> $crate::libc::c_int {
+            $crate::hexchat_plugin_deinit::<$t>(plugin_handle)
         }
         // unlike what the documentation states, there's no need to define hexchat_plugin_get_info.
         // so we don't. it'd be impossible to make it work well with rust anyway.