On Jul 12, 2020, at 1:43 PM, Axel Wagner <axel.wagner...@googlemail.com> wrote:
> 
> 
> 
> On Sun, Jul 12, 2020 at 9:33 PM Bakul Shah <ba...@iitbombay.org> wrote:
> On Jul 12, 2020, at 11:11 AM, Gert <gert.cuyk...@gmail.com> wrote:
> > 
> > https://play.golang.org/p/6xMgjr1IyFD
> > 
> > var fn myHandler
> > fn = func(w http.ResponseWriter, r *http.Request) {
> >   fn.GET(w, r)
> > }
> > 
> > Just wondering if it's possible somehow to write this in one line like so
> > 
> > var fn myHandler = func(w http.ResponseWriter, r *http.Request) {
> >   fn.GET(w, r)
> > }
> 
> The issue is that fn's type can't be completely determined until
> the RHS func is fully analyzed but for that to work fn must be
> known!
> 
> Why? ISTM the type is mentioned twice - once as "myHandler" on the LHS and 
> once in the signature on the RHS. And there isn't even a way to write down a 
> function literal without mentioning the full type. On the surface, this seems 
> like a relatively straightforward scoping issue, introduced by the fact that 
> the scope of a variable declaration starts at the end of it's VarSpec, not 
> the "=". Interestingly though, the initialization rules prevent this from 
> working at the package-level, where this scoping problem doesn't exist: 
> https://play.golang.org/p/IPMxtYETGsg

You're right.

> 
> Also note that the first definition won't do what you may be thinking
> it does. The`fn.GET` call will be to the existing value of fn, not
> the result of the assignment.
> 
> No, it won't. The function-literal closes over `fn`, so it will use whatever 
> is assigned at call-time.
> https://play.golang.org/p/VCvCt8J8Zcw
> I use this pattern all the time to define a recursive function without 
> polluting the package-scope.

Right again. What matters is the value of fn when the function is called,
not when it is defined. Clearly I wasn't thinking clearly.

Thanks for setting me straight. And apologies to Gert.

-- 
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/9D3EE282-2C7A-42DA-8282-CBFFF9C3935A%40iitbombay.org.

Reply via email to