I disagree.  The "user" in this case, is the user of the library code.  He does 
in fact need to know the file/line that caused the problem, and more useful 
would be the full stack trace so he can see where his code used the offending 
value.

If you are relying on enforce to give insightful error messages to an actual 
user (that is, someone who runs your program), then you need some training in 
user interface design :)

-Steve



----- Original Message ----
> From: Lars Tandle Kyllingstad <[email protected]>
> To: Phobos mailing list <[email protected]>
> Sent: Thu, July 1, 2010 9:50:15 AM
> Subject: [phobos] enforce() improvement
> 
> Often, at least in small programs, when an exception is thrown you just
want 
> to present a sensible message to the user and abort the 
> current
operation.  Example:

        void 
> doStuff(int i) { enforce(i >= 0, "Need nonnegative i"); }

  
>       try doStuff(-1);
        catch 
> (Exception e) writeln("Error: ", e.msg);

In this case, the user will 
> see

        Error: b.d(5): Need nonnegative 
> i

My point is that the user doesn't need to see the file and line 
> number
that caused the error.  This is only useful for the 
> programmer.  So I
suggest we make either of the following changes to 
> enforce():

     1. Drop the file and line number from the 
> message.  The Throwable
        class has dedicated 
> 'file' and 'line' fields which we can
        populate 
> with that information without polluting the error
        
> message.
     2. Another option is to include the file and line 
> only in debug
        builds.

-Lars 
> 


_______________________________________________
phobos mailing 
> list

> href="mailto:[email protected]";>[email protected]
http://lists.puremagic.com/mailman/listinfo/phobos


      
_______________________________________________
phobos mailing list
[email protected]
http://lists.puremagic.com/mailman/listinfo/phobos

Reply via email to