[Issue 17226] Exception during the generation of an assert message hides AssertError
    d-bugmail at puremagic.com 
    d-bugmail at puremagic.com
       
    Thu Dec  8 16:55:02 UTC 2022
    
    
  
https://issues.dlang.org/show_bug.cgi?id=17226
Steven Schveighoffer <schveiguy at gmail.com> changed:
           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |schveiguy at gmail.com
--- Comment #12 from Steven Schveighoffer <schveiguy at gmail.com> ---
What about creating a wrapper for format:
```d
string assertFormat(Args...)(string fmt, Args args)
{
   try {
     return format(fmt, args);
   } catch(Exception ex) {
     return "Error while evaluating assert message: " ~ ex.toString;
   }
}
// use like
assert(i == 42, assertFormat("Something %s", functionThatThrows()));
```
This solves the problem, and also doesn't throw away any information. Plus it's
not unpleasant to use.
Yes, it's opt in. So what? It can just be a best practice recommendation.
--
    
    
More information about the Digitalmars-d-bugs
mailing list