Made with KolourPaint and screenshots from Kate (with the GitHub theme).

  • sph@lemmy.world
    link
    fedilink
    arrow-up
    4
    ·
    4 months ago

    This obviously just illustrates a point, but callbacks and decorators are not uncommon. And iterators are exactly like that:

    type (
    	Seq[V any]     func(yield func(V) bool)
    	Seq2[K, V any] func(yield func(K, V) bool)
    )
    

    Which is very readable.

    • phlegmy@sh.itjust.works
      link
      fedilink
      arrow-up
      3
      ·
      4 months ago

      Callbacks and decorators are fine, but callbacks/decorators to a function which itself takes a function pointer and returns another function pointer are crazy.

      I’ve thankfully never had to use recursive callbacks or decorators, but it seems like it could very quickly become difficult to keep track of.

      • sph@lemmy.world
        link
        fedilink
        arrow-up
        3
        ·
        4 months ago

        I don’t think it’s that uncommon. Let’s say you have a function that handles a request. A common use case is to add permission checks before applying that function. You can write a generic permission check a bit like this:

        func NeedsPermission(f func(Request) (Response, error), perm string) func(Request) (Response, error) {
            return func(r Request) (Response, error) {
                if !check(r, perm) {
                    return nil, NewPermError(perm)
                }
                return f(r)
            }
        }
        
        // elsewhere
        Bar := NeedsPermission(Foo, "superman")
        

        This would allow you to separate the permission check logic from the business logic. Though to be fair, in Go they prefer to keep things as simple as possible but it’s just to illustrate that these concepts are not that alien.