Hacker News new | past | comments | ask | show | jobs | submit login

In C++, you can override the __cxa_throw() function to implement a fully-fledged condition system that calls handlers on top of the stack instead of unwinding first. Call the real __cxa_throw if there's no dynamic handler.

To top it off, you can provide a "restart" class that this new __cxa_throw treats like ordinary C++ exceptions, and throw an instance of it to perform the "exit".

I have no idea if this hack would comply with the standard, but it works with GCC.

You'd be missing COMPUTE-RESTARTS, however, so there'd be no asking the user where to jump.




The Itanium C++ ABI mentions something similar

> A two-phase exception-handling model is not strictly necessary to implement C++ language semantics, but it does provide some benefits. For example, the first phase allows an exception-handling mechanism to dismiss an exception before stack unwinding begins, which allows resumptive exception handling (correcting the exceptional condition and resuming execution at the point where it was raised). While C++ does not support resumptive exception handling, other languages do, and the two-phase model allows C++ to coexist with those languages on the stack.

http://itanium-cxx-abi.github.io/cxx-abi/abi-eh.html


I am aware that there have historically been other languages besides Lisp that allow resumptive exception handling (PL/I is a historical example), but I'm unaware of any modern language besides Lisp that does it.

What would C++ be coexisting with on non-mainframe hardware?


Could you link me to any sources for that GCC behavior?

Also, if we can have dynamically established handlers, then we could also have dynamically established restarts (even if by means of a dynamic variable implemented via a lexical variable + a destructor), and therefore we could have a COMPUTE-RESTARTS of our own and then be able to invoke it arbitrarily as well as invoke individual restarts.


This isn't about GCC, but GCC's behavior seems to be compatible:

https://libcxxabi.llvm.org/spec.html




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: