diff options
author | Chris Lattner <sabre@nondot.org> | 2002-04-18 19:53:53 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2002-04-18 19:53:53 +0000 |
commit | bac27a49b1eb47018169dcde469d84363465aa2c (patch) | |
tree | 1b819ac2033a67ff98c9f17375b7a22e9fe6a350 | |
parent | 922a392565130d658f34abb65f5b710e600a1a83 (diff) |
Add new api for basic signal handling for tools
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2302 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Support/Signals.cpp | 53 | ||||
-rw-r--r-- | support/lib/Support/Signals.cpp | 53 |
2 files changed, 106 insertions, 0 deletions
diff --git a/lib/Support/Signals.cpp b/lib/Support/Signals.cpp new file mode 100644 index 0000000000..8aa1b6047a --- /dev/null +++ b/lib/Support/Signals.cpp @@ -0,0 +1,53 @@ +//===- Signals.cpp - Signal Handling support ------------------------------===// +// +// This file defines some helpful functions for dealing with the possibility of +// unix signals occuring while your program is running. +// +//===----------------------------------------------------------------------===// + +#include "Support/Signals.h" +#include <vector> +#include <algorithm> +#include <cstdlib> +#include <cstdio> +#include <signal.h> + +static vector<string> FilesToRemove; + +// IntSigs - Signals that may interrupt the program at any time. +static const int IntSigs[] = { + SIGHUP, SIGINT, SIGQUIT, SIGKILL, SIGPIPE, SIGTERM, SIGUSR1, SIGUSR2 +}; +static const int *IntSigsEnd = IntSigs + sizeof(IntSigs)/sizeof(IntSigs[0]); + +// KillSigs - Signals that are synchronous with the program that will cause it +// to die. +static const int KillSigs[] = { + SIGILL, SIGTRAP, SIGABRT, SIGEMT, SIGFPE, + SIGBUS, SIGSEGV, SIGSYS, SIGXCPU, SIGXFSZ +}; +static const int *KillSigsEnd = KillSigs + sizeof(KillSigs)/sizeof(KillSigs[0]); + + +// SignalHandler - The signal handler that runs... +static void SignalHandler(int Sig) { + while (!FilesToRemove.empty()) { + std::remove(FilesToRemove.back().c_str()); + FilesToRemove.pop_back(); + } + + if (find(IntSigs, IntSigsEnd, Sig) != IntSigsEnd) + exit(1); // If this is an interrupt signal, exit the program + + // Otherwise if it is a fault (like SEGV) reissue the signal to die... +} + +static void RegisterHandler(int Signal) { signal(Signal, SignalHandler); } + +// RemoveFileOnSignal - The public API +void RemoveFileOnSignal(const string &Filename) { + FilesToRemove.push_back(Filename); + + for_each(IntSigs, IntSigsEnd, RegisterHandler); + for_each(KillSigs, KillSigsEnd, RegisterHandler); +} diff --git a/support/lib/Support/Signals.cpp b/support/lib/Support/Signals.cpp new file mode 100644 index 0000000000..8aa1b6047a --- /dev/null +++ b/support/lib/Support/Signals.cpp @@ -0,0 +1,53 @@ +//===- Signals.cpp - Signal Handling support ------------------------------===// +// +// This file defines some helpful functions for dealing with the possibility of +// unix signals occuring while your program is running. +// +//===----------------------------------------------------------------------===// + +#include "Support/Signals.h" +#include <vector> +#include <algorithm> +#include <cstdlib> +#include <cstdio> +#include <signal.h> + +static vector<string> FilesToRemove; + +// IntSigs - Signals that may interrupt the program at any time. +static const int IntSigs[] = { + SIGHUP, SIGINT, SIGQUIT, SIGKILL, SIGPIPE, SIGTERM, SIGUSR1, SIGUSR2 +}; +static const int *IntSigsEnd = IntSigs + sizeof(IntSigs)/sizeof(IntSigs[0]); + +// KillSigs - Signals that are synchronous with the program that will cause it +// to die. +static const int KillSigs[] = { + SIGILL, SIGTRAP, SIGABRT, SIGEMT, SIGFPE, + SIGBUS, SIGSEGV, SIGSYS, SIGXCPU, SIGXFSZ +}; +static const int *KillSigsEnd = KillSigs + sizeof(KillSigs)/sizeof(KillSigs[0]); + + +// SignalHandler - The signal handler that runs... +static void SignalHandler(int Sig) { + while (!FilesToRemove.empty()) { + std::remove(FilesToRemove.back().c_str()); + FilesToRemove.pop_back(); + } + + if (find(IntSigs, IntSigsEnd, Sig) != IntSigsEnd) + exit(1); // If this is an interrupt signal, exit the program + + // Otherwise if it is a fault (like SEGV) reissue the signal to die... +} + +static void RegisterHandler(int Signal) { signal(Signal, SignalHandler); } + +// RemoveFileOnSignal - The public API +void RemoveFileOnSignal(const string &Filename) { + FilesToRemove.push_back(Filename); + + for_each(IntSigs, IntSigsEnd, RegisterHandler); + for_each(KillSigs, KillSigsEnd, RegisterHandler); +} |