diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-08-10 03:36:26 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-08-10 03:36:26 +0000 |
commit | 1bf60c257cd14caee8da595bb9328a18439a2821 (patch) | |
tree | 50abc45b30c631d2090abc55695e483d0fc060fc /llvm/lib/Support/ErrorHandling.cpp | |
parent | 9b3484dd141787acbe6372a14c378b4f91bc8c80 (diff) | |
download | bcm5719-llvm-1bf60c257cd14caee8da595bb9328a18439a2821.tar.gz bcm5719-llvm-1bf60c257cd14caee8da595bb9328a18439a2821.zip |
Add support for a user supplied pointer argument to llvm_install_error_handler.
llvm-svn: 78553
Diffstat (limited to 'llvm/lib/Support/ErrorHandling.cpp')
-rw-r--r-- | llvm/lib/Support/ErrorHandling.cpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/llvm/lib/Support/ErrorHandling.cpp b/llvm/lib/Support/ErrorHandling.cpp index d60dc1d2ad2..81669223b05 100644 --- a/llvm/lib/Support/ErrorHandling.cpp +++ b/llvm/lib/Support/ErrorHandling.cpp @@ -23,12 +23,16 @@ using namespace llvm; using namespace std; static llvm_error_handler_t ErrorHandler = 0; +static void *ErrorHandlerUserData = 0; + namespace llvm { -void llvm_install_error_handler(llvm_error_handler_t handler) { +void llvm_install_error_handler(llvm_error_handler_t handler, + void *user_data) { assert(!llvm_is_multithreaded() && "Cannot register error handlers after starting multithreaded mode!\n"); assert(!ErrorHandler && "Error handler already registered!\n"); ErrorHandler = handler; + ErrorHandlerUserData = user_data; } void llvm_remove_error_handler(void) { @@ -47,7 +51,7 @@ void llvm_report_error(const Twine &reason) { if (!ErrorHandler) { errs() << "LLVM ERROR: " << reason << "\n"; } else { - ErrorHandler(reason.str()); + ErrorHandler(ErrorHandlerUserData, reason.str()); } exit(1); } |