Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Multiple set_handler calls don't properly overwrite? 🤔 #118

Closed
slafs opened this issue Apr 8, 2024 · 5 comments
Closed

Multiple set_handler calls don't properly overwrite? 🤔 #118

slafs opened this issue Apr 8, 2024 · 5 comments

Comments

@slafs
Copy link

slafs commented Apr 8, 2024

Hello!

Not sure if I'm holding it wrong or... 🤔

The docs for set_handler say:

Will return an error if a system error occurred while setting the handler.

and for try_set_handler say:

Will return an error if another handler exists or if a system error occurred while setting the handler.

But a modified snippet from the README like this:

use ctrlc;
use std::sync::mpsc::channel;

fn main() {
    let (tx, rx) = channel();

    ctrlc::set_handler(move || {}).expect("Error setting Ctrl-C handler");

    ctrlc::set_handler(move || tx.send(()).expect("Could not send signal on channel."))
        .expect("Error setting Ctrl-C handler for the second time");

    println!("Waiting for Ctrl-C...");
    rx.recv().expect("Could not receive from channel.");
    println!("Got it! Exiting...");
}

panics with:

thread 'main' panicked at src/main.rs:10:10:
Error setting Ctrl-C handler for the second time: MultipleHandlers

So it seems set_handler can return MultipleHandlers? 🤔

I'm on OSX 14.4.1

@Detegr
Copy link
Owner

Detegr commented Apr 8, 2024

Hi.

You are correct, this is a bug. It has been there since the introduction of try_set_handler. Quite an obvious bug as well, what have I been thinking :)

@Detegr
Copy link
Owner

Detegr commented Apr 13, 2024

Actually, I'm taking it back. set_handler will overwrite whatever handler there was set by something else than this crate, but it will do it just once. try_set_handler will return MultipleHandlers if something else than this crate had set a handler for the signal.

The wording for the logic is quite poor as my initial thoughts were too that it's not working properly.

@Tuupertunut
Copy link

So there is no way to replace a handler with another. Maybe there should be.

@Detegr
Copy link
Owner

Detegr commented Jan 2, 2025

Perhaps. I'm open to code contributions if they don't make the crate too complicated. Closing this issue for now as the original question was answered.

@Detegr Detegr closed this as completed Jan 2, 2025
@Detegr
Copy link
Owner

Detegr commented Jan 2, 2025

There is the discussion about reverting the signal handler #106. This would allow a new one to be placed after reverting the originally set handler back.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants