-
Notifications
You must be signed in to change notification settings - Fork 74
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
Invoking previously registered action #130
Comments
Sorry for the late response. First, the more direct answer to your question. If the previous one registered a signal action/signal handler the unix way ( https://github.com/vorner/signal-hook/blob/master/signal-hook-registry/src/lib.rs#L324 Then, the hooks by signal-hook are all executed in the order they were registered, one by one. However, a lot of these hooks just postpone the actual stuff for later ‒ for example, what you use has some small code that runs inside the signal handler. That small code sets few flags and wakes up the blocked thread. Then that thread executes. If some other thread does similar thing, the order in which they wake up is not specified and one or the other may win. By the way, at the time you call unregister here, all the other hooks were already called (because unregister actually waits for any running hooks to finish first, it can't manipulate the internal structures). So, it is somewhat possible, yes, but probably not easy. The less direct answer is, the API you provide seems subtly bit wrong to me ‒ it actually does two unrelated things. Prints the statistics and terminates. That API is very much „global“ (but what manipulating signal handlers isn't). I'd try to find out some way to either take a cleanup callback to get called, or leave the „wiring“ of signal to print up to the user to have under control. As a shameless plug, I also maintain the |
Ok, that wasn't obvious to me. That means that my code is correct wrt handlers registered from outside signal-hook. But I'm still unclear on how to get the effect of performing an action SIGINT and then exiting as if SIGINT wasn't handled, while allowing others (including signal-hook users) the same privilege.
The idea is to just print the statistics. But if I didn't terminate, the program would just keep running as if ^C wasn't pressed, right? Explicit termination is only needed to counter-act the fact that SIGINT is handled.
Thanks, I'll look into it - but in this case the API is provided by a library, which can't depend on the program it runs in using a particular application framework. |
I have a stats library which I'd like to have the option of printing its stats on
^C
. So I wrote something like this:This works nicely - if you interrupt the program with
^C
, a report gets printed, and the program exists as if^C
were pressed (the shell reports an exit status of 130).But this approach will clobber someone else who installs a SIGINT hook - my cleanup code just executes the default action, where I'd like it to remember the previously installed action and execute that. So I wrote something like this:
Of course, the above doesn't work, It always exits with 255 - first, because
unregister
doesn't restore the previous action, it just removes the dummy one we've installed. And second becauseunregister
docs explicitly specify that it will never restore the default terminating action.Is it possible to implement the behavior I'd like using
signal_hook
?The text was updated successfully, but these errors were encountered: