Seems  the easiest way to address that is with a DSL and a code generator. 

> On Jun 18, 2023, at 9:47 AM, Jan Pfeifer <pfei...@gmail.com> wrote:
> 
> 
> hi Shulhan, I see your points, thanks for the reply. Let me comment on them 
> below:
> 
>> On Sat, Jun 17, 2023 at 9:21 AM Shulhan <m.shul...@gmail.com> wrote:
>> Hi Jan, thanks for response.
>> 
>> On Mon, 5 Jun 2023 01:06:37 -0700 (PDT)
>> Jan <pfei...@gmail.com> wrote:
>> 
>> > Repeating Justin's consideration: one of my (and from colleagues I
>> > discuss the topic with) major issues with current error handling is
>> > the repetition of identical code. Your proposal still requires `when
>> > err handle ...` at every statement.
>> 
>> Yes, correct.
>> The idea is not to minimise repetition on error handling statement, the
>> "if err != nil", but to minimise repetitive error handling body by
>> grouping it into single handle based on the context of error.
> 
> Oh, I see. I have to say I wish one didn't need to do the `if err != nil` all 
> the time either, when the handling is the same :) But if that is your 
> proposal it makes sense.
> 
>> > It also doesn't allow for nested
>> > call of functions that return errors -- e.g: `f(g(h(x)))`, where `h`,
>> > `g`, and `f` can return errors (all presumably handled the same way).
>> > 
>> 
>> I am not sure I understand this, but should not each function handle it
>> on its own?
>> Or should not `f` being called if `g` return an error?
>> If its later, yes, it does not allow for nested handling of error.
> 
> Sorry I was not clear. What I mean is, with current error handling would be 
> written like:
> 
> hValue, err := h(x)
> if err != nil {...}
> gValue, err := g(hValue)
> if err != nil {...}
> fValue, err := f(gValue)
> if err != nil {...}
> 
> Where all of the `if err` are identical.
> 
> Let me provide a more concrete example: I'm working on an ML framework 
> (github.com/gomlx/gomlx), and I'm writing computational graphs (that get 
> just-in-time compiled for speed/GPU support) like:
> 
> func EuclideanDistance(x, y *Node) *Node {
>    return Sqrt(ReduceAllSum(Square(Sub(x, y))))
> }
> 
> Where each of these functions could return an error (if shapes are 
> incompatible). If an error is raised (they hold a stack trace), I want them 
> simply propagated upwards. Error handling in the middle of these math 
> expressions (some are larger) get in the way of the math being expressed.
> 
> cheers 
> Jan
> 
> 
>  
> -- 
> You received this message because you are subscribed to the Google Groups 
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an 
> email to golang-nuts+unsubscr...@googlegroups.com.
> To view this discussion on the web visit 
> https://groups.google.com/d/msgid/golang-nuts/CAE%3D7LsUQfPLP1w0s9EN3XZSsoproEStkQHRb-s8pcdTgmpbzTw%40mail.gmail.com.

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/6115E519-3E68-4DD2-877D-66EB54ECA26F%40ix.netcom.com.

Reply via email to