aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthias P. Braendli <matthias.braendli@mpb.li>2015-01-23 12:00:54 +0100
committerMatthias P. Braendli <matthias.braendli@mpb.li>2015-01-23 12:00:54 +0100
commit109d40f1e598f9d122a91ad0267e6ce199b174a4 (patch)
treefe355fb8ea320ac25f2984bcd18882f55c54a005
parent2e646a26c9db66dd5776667d9c9b73d798f5ffda (diff)
downloaddabmod-109d40f1e598f9d122a91ad0267e6ce199b174a4.tar.gz
dabmod-109d40f1e598f9d122a91ad0267e6ce199b174a4.tar.bz2
dabmod-109d40f1e598f9d122a91ad0267e6ce199b174a4.zip
Replace signal() by sigaction()
-rw-r--r--src/DabMod.cpp15
1 files changed, 11 insertions, 4 deletions
diff --git a/src/DabMod.cpp b/src/DabMod.cpp
index cc7dd96..06d1254 100644
--- a/src/DabMod.cpp
+++ b/src/DabMod.cpp
@@ -71,13 +71,13 @@
typedef std::complex<float> complexf;
-bool running = true;
+volatile sig_atomic_t running = 1;
void signalHandler(int signalNb)
{
PDEBUG("signalHandler(%i)\n", signalNb);
- running = false;
+ running = 0;
}
@@ -218,7 +218,14 @@ int main(int argc, char* argv[])
#endif
InputReader* inputReader;
- signal(SIGINT, signalHandler);
+ struct sigaction sa;
+ memset(&sa, 0, sizeof(struct sigaction));
+ sa.sa_handler = &signalHandler;
+
+ if (sigaction(SIGINT, &sa, NULL) == -1) {
+ perror("sigaction");
+ return EXIT_FAILURE;
+ }
// Set timezone to UTC
setenv("TZ", "", 1);
@@ -844,7 +851,7 @@ int main(int argc, char* argv[])
else {
fprintf(stderr, "Input read error.\n");
}
- running = false;
+ running = 0;
}
} catch (std::exception& e) {
fprintf(stderr, "EXCEPTION: %s\n", e.what());