summaryrefslogtreecommitdiff
path: root/indra/llcommon/lleventdispatcher.cpp
diff options
context:
space:
mode:
authorNat Goodspeed <nat@lindenlab.com>2023-01-23 10:51:33 -0500
committerNat Goodspeed <nat@lindenlab.com>2023-07-13 12:49:09 -0400
commit2eb0ea9593d0e299445d2e1dde711bfe5072542e (patch)
treea64768f1b6b2a2a6fc64940e96ba99d12a7cb59c /indra/llcommon/lleventdispatcher.cpp
parentc747ff0925fb85147a96745bb55e66e7e8004fd8 (diff)
DRTVWR-558: Nail down LLDispatchListener exception handling
for exceptions other than those thrown by base-class LLEventDispatcher. Explain in LLDispatchListener Doxygen comments that for a request lacking a "reply" key, any exception is allowed to propagate because it's likely to reach the post() call that triggered the exception in the first place. For batch LLDispatchListener operations, catch not only LLEventDispatcher:: DispatchError exceptions but any std::exception, so we can collect them to report to the invoker. "Gotta catch 'em all!" Make LLLeap catch any std::exception thrown by processing a request from the plugin child process, log it and send a reply to the plugin. No plugin should be allowed to crash the viewer. (cherry picked from commit 94e10fd039b79f71ed8d7e10807b6e4eebd1928c)
Diffstat (limited to 'indra/llcommon/lleventdispatcher.cpp')
-rw-r--r--indra/llcommon/lleventdispatcher.cpp15
1 files changed, 10 insertions, 5 deletions
diff --git a/indra/llcommon/lleventdispatcher.cpp b/indra/llcommon/lleventdispatcher.cpp
index 0079b9ce36..a4c0ed3766 100644
--- a/indra/llcommon/lleventdispatcher.cpp
+++ b/indra/llcommon/lleventdispatcher.cpp
@@ -848,10 +848,12 @@ void LLDispatchListener::call_map(const LLSD& reqmap, const LLSD& event) const
// which request keys succeeded.
result[name] = (*this)(name, args);
}
- catch (const DispatchError& err)
+ catch (const std::exception& err)
{
- // collect message in 'errors'
- errors << delim << err.what();
+ // Catch not only DispatchError, but any C++ exception thrown by
+ // the target callable. Collect exception name and message in
+ // 'errors'.
+ errors << delim << LLError::Log::classname(err) << ": " << err.what();
delim = "\n";
}
}
@@ -921,9 +923,12 @@ void LLDispatchListener::call_array(const LLSD& reqarray, const LLSD& event) con
// With this form, capture return value even if undefined
results.append((*this)(name, args));
}
- catch (const DispatchError& err)
+ catch (const std::exception& err)
{
- error = err.what();
+ // Catch not only DispatchError, but any C++ exception thrown by
+ // the target callable. Report the exception class as well as the
+ // error string.
+ error = stringize(LLError::Log::classname(err), ": ", err.what());
break;
}
}