diff options
author | SoniEx2 <endermoneymod@gmail.com> | 2022-04-22 09:54:34 -0300 |
---|---|---|
committer | SoniEx2 <endermoneymod@gmail.com> | 2022-04-22 09:55:06 -0300 |
commit | 85e7a543c9c5729752ad0cc83a51806f77a3fb65 (patch) | |
tree | 2d4b6dcf15da764eda439e624114560a4d9a88a4 /src | |
parent | 4d5699665e7ffdab8ce1729e330fe1092b8ddf15 (diff) |
Prevent eating "Close Context"
Diffstat (limited to 'src')
-rw-r--r-- | src/lib.rs | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/src/lib.rs b/src/lib.rs index 3343fed..ac8ef85 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -838,6 +838,13 @@ impl<'ph> PluginHandle<'ph> { let f: Rc<HookUd> = rc_clone_from_raw(ud as *const HookUd); (f)(word, ptr::null(), ptr::null()).do_eat as c_int } + // we use "Close Context" to clean up dangling pointers. + // hexchat lets plugins/hooks eat "Close Context" from eachother (tho + // not from hexchat, for good reason), so this can still be unsound + // if other plugins eat "Close Context". in those cases, we'd consider + // those plugins to be faulty, tho it'd be nice if hexchat handled it. + // we still do our best to be well-behaved. + let suppress_eat = name.eq_ignore_ascii_case("Close Context"); let b: Rc<HookUd> = { let ph = self.data; let info = self.info; @@ -849,7 +856,10 @@ impl<'ph> PluginHandle<'ph> { call_hook_protected(ph.ph, move || { let mut ph = PluginHandle::new(ph, info, contexts); let word = Word::new(word); - cb(&mut ph, word) + match cb(&mut ph, word) { + _ if suppress_eat => EAT_NONE, + eat => eat, + } }) } })) |