-
Notifications
You must be signed in to change notification settings - Fork 46
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Does ozo throw exceptions? #219
Comments
Hi, Michael! Yes, potentially it may throw despite a |
I don't really follow your answer. What code from ozo would throw? |
There is no certain logic that throws exceptions during the operation - error codes are used instead, but there are customization points that aren't specified as Do you have any problem with an exception during the operation? |
I'm not currently seeing any exceptions from ozo, no. I'm asking because I'm trying to make improvements to my code that uses ozo, and part of that is investigating exception guarantees and placing the noexcept keyword where it made sense, or wrapping function calls in try-catch, and so on. I think that ozo should be more strict with the behavior that it accepts from customization points. Given that ozo is a boost::asio library, once control passes into boost::asio's main loop, throwing an exception is likely to cause major problems. E.g. send_impl specialization throwing is something that a program cannot recover from, practically speaking. So it should be noexcept only. In this way, ozo can then mark parts of itself noexcept where that makes sense, and that will allow consumers of the ozo API to have an easier time managing control flow / try-catch. |
Another option that is significantly more work is to use the noexcept(noexcept(list-of-function-calls-here)) logic that can calculate whether a particular customization point is marked as noexcept by the caller at compile time. I'm not suggesting that you do that, it honestly doesn't seem like it would be worth it, since just declaring functions as noexcept, or not-noexcept is likely to be what makes sense. But it is something that could be done. |
In general, you right. But the problem is much deeper than the |
@thed636 Have you had any time to consider this? |
Hi Michael! Sorry for so long silence. Haven't had enough time yet. :( |
Will, for example,
ozo::execute
throw an exception for reasons other than the CompletionToken provided to it throwing an exception?The text was updated successfully, but these errors were encountered: