On 4/12/22 11:53, Roman Simakov wrote:
Alex,

Is it documented somewhere?

Exactly in this form - not. I.e. a fact that exceptions are caught when throwing from OO API functions is documented (in Using_OO_API) and special position of FbException is documented too, but need of first Status parameter to make all that work is not emphasized. To be precise - _any_ exception in _any_ OO API function will be caught, but it will not be delivered in original way to caller. The humor is that FB_PLUGIN_ENTRY_POINT (except missing Status parameter) is not OO API call - it's just plain C function which is needed to 'boot' OO API in plugin, and certainly it should not throw over module boundaries.

пн, 11 апр. 2022 г. в 18:45, Alex Peshkoff via Firebird-devel
<firebird-devel@lists.sourceforge.net>:
On 4/11/22 17:56, Dimitry Sibiryakov wrote:
Vasiliy Yashkov wrote 11.04.2022 16:52:
What is the right way to throw an exception?
   Plugins (as any other DLL) is not supposed to throw exceptions ever.

Yes, throwing directly (like in your code) is impossible. But there is a
way to return an exception information from plugin using Status
interface, which is passed as first parameter in that case.
Pay attention - FB_PLUGIN_ENTRY_POINT has no such parameter and
therefore is not expected to return exception information. (there are
more reasons why exceptions not to be used in that call but let me not
dive too deep here)

But if some plugin entry has first Status parameter you can throw
FbException in it, it will be caught by thin API layer which actually
invoked your plugin entry and delivered to the code which called plugin.




Firebird-Devel mailing list, web interface at 
https://lists.sourceforge.net/lists/listinfo/firebird-devel





Firebird-Devel mailing list, web interface at 
https://lists.sourceforge.net/lists/listinfo/firebird-devel

Reply via email to