diff options
author | Hisham Muhammad <hisham@gobolinux.org> | 2016-09-16 13:03:46 -0300 |
---|---|---|
committer | Hisham <hisham@gobolinux.org> | 2016-09-16 13:36:58 -0300 |
commit | 46d8f2eef28ef4230cbafa3f8e9a47dd6e8fa090 (patch) | |
tree | 7677d7735b6362fdaa910df644a611a0bc7c4df0 | |
parent | 823481ae22b185d2ef10eb4c48a2fb33e15daa40 (diff) | |
parent | 0ce4835f95a6dc358710c5c16723295a8370d4f5 (diff) |
Merge pull request #551 from Explorer09/rt-signals
Real-time signals support (kill command)
-rw-r--r-- | SignalsPanel.c | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/SignalsPanel.c b/SignalsPanel.c index 9816a848..22fefa62 100644 --- a/SignalsPanel.c +++ b/SignalsPanel.c @@ -31,13 +31,36 @@ Panel* SignalsPanel_new() { Panel* this = Panel_new(1, 1, 1, 1, true, Class(ListItem), FunctionBar_newEnterEsc("Send ", "Cancel ")); const int defaultSignal = SIGTERM; int defaultPosition = 15; - for(unsigned int i = 0; i < Platform_numberOfSignals; i++) { + unsigned int i; + for (i = 0; i < Platform_numberOfSignals; i++) { Panel_set(this, i, (Object*) ListItem_new(Platform_signals[i].name, Platform_signals[i].number)); // signal 15 is not always the 15th signal in the table if (Platform_signals[i].number == defaultSignal) { defaultPosition = i; } } + #if (defined(SIGRTMIN) && defined(SIGRTMAX)) + // Real-time signals. + // SIGRTMIN and SIGRTMAX expand to libc internal functions and we have to + // grab their numbers at runtime. + static char buf[15]; // 15 == sizeof("xx SIGRTMIN+nn") + int rtmax; + for (int sig = SIGRTMIN; sig <= (rtmax = SIGRTMAX); i++, sig++) { + // Every signal between SIGRTMIN and SIGRTMAX are denoted in "SIGRTMIN+n" + // notation. This matches glibc's strsignal(3) behavior. + // We deviate from behaviors of Bash, ksh and Solaris intentionally. + if (sig == rtmax) { + snprintf(buf, 15, "%2d SIGRTMAX", sig); + } else { + int n = sig - SIGRTMIN; + snprintf(buf, 15, "%2d SIGRTMIN%+d", sig, n); + if (n == 0) { + buf[11] = '\0'; + } + } + Panel_set(this, i, (Object*) ListItem_new(buf, sig)); + } + #endif Panel_setHeader(this, "Send signal:"); Panel_setSelected(this, defaultPosition); return this; |