I am developing a thin managed C++ wrapper over a large unmanaged C++ library, and a large C# library. I need to catch errors originating in that large unmanaged C++ library, and rethrow them as Clr exceptions. The unmanaged library throws instances of the following class:
Error::Error(const std::string& file, long line,
const std::string& function,
const std::string& message) {
message_ = boost::shared_ptr<std::string>(new std::string(
format(file, line, function, message)));
}
const char* Error::what() const throw () {
return message_->c_str();
}
So far I have come up with this:
try{
// invoke some unmanaged code
}
catch(Object*)
{
throw gcnew System::Exception("something bad happened");
}
How do I extract the message from Error class and convert it to the Clr String class, so that I can pass it to gcnew System::Exception() constructor? If the unmanaged code throws something else, will my catch block catch it?
Edit: I am using catch(Object*) because that is recommended in MCDN
Does the following not work for you?
Because this certainly works for me:
I use
You may want to put this into a pair of macros since they'll be used everywhere.
You can add a custom
catch
block with yourError
class, but since it seems to derive fromstd::exception
, the code I show you should be OK.You could also want to catch more specifically
std::invalid_argument
and translate it intoArgumentException
, etc. but I find this overkill.The only reliable way I've come up with to catch most unmanaged exceptions is catch (...) which won't give you any information to rethrow, but will prevent most crashes. There are still some exceptions that even catch (...) won't catch and will crash your application, even without a crash indicator (the app just disappears), like if a badly written 3rd party app uses SetJump/LongJump with the wrong error handling or thread protocols.
You could write a long series of catch blocks if you wanted to try to type many C++ exceptions, like: