I guess we will just have to disagree.

On Wed, 4 Jun 2025 at 15:38, tapi...@gmail.com <tapir....@gmail.com> wrote:

>
>
> On Wednesday, June 4, 2025 at 12:18:26 PM UTC+8 Axel Wagner wrote:
>
> On Tue, 3 Jun 2025 at 22:17, tapi...@gmail.com <tapi...@gmail.com> wrote:
>
> Or better, use ErrType instead of *ErrType, so that no need to declare the
> global error var.
>
>
> Doing that is problematic. If the `Error` method is declared with a value
> receiver, it is promoted to the pointer-type as well. At that point, it is
> no longer a priori clear, whether you should type-assert to `ErrType` or
> `*ErrType`. Or similarly, which to use with `errors.As`. Likewise, it is
> possible to assign either to `error`, so it is easy to accidentally return
> the wrong type. This can lead to very hard to find bugs, as error-paths
> tend to not be well tested anyways. This doesn't happen with pointer
> receivers, as they are not promoted to the value type. So any mixup gets
> statically caught by the compiler.
>
> So, as a general rule, an often type-asserted interface like `error`
> should be implemented using pointer-receivers.
>
>
> As a basic rule, we should never use *ZeroSizeType as error types. Just
> use ZeroSizeType as error types.
>
>
>
>
>
>
>
> On Tue, 3 Jun 2025 at 17:56, tapi...@gmail.com <tapi...@gmail.com> wrote:
>
>
>
> On Tuesday, June 3, 2025 at 8:58:10 PM UTC+8 Bushnell, Thomas wrote:
>
> Why do you think these are incorrect uses of errors.Is? If you are only
> testing the Boolean value, Is is fine and the same as As; you should only
> use As if you are actually going to use the identified error value in some
> way.
>
> Because errors.Is mainly use == to compare errors. When the errors are
> pointers to zero-size values, the comparison result is compiler dependent,
> as the whole thread is talking about.
>
> Maybe using errors.As is also not a good idea for such cases. Such cases
> just need an errors.OfType[ErrType]() alike function.
>
>
>
>
> *From:* golan...@googlegroups.com <golan...@googlegroups.com> *On Behalf
> Of *tapi...@gmail.com
> *Sent:* Monday, June 2, 2025 3:14 PM
> *To:* golang-nuts <golan...@googlegroups.com>
> *Subject:* Re: [go-nuts] Comparison of pointers to distinct zero-sized
> variables
>
>
>
> This message was sent by an external party.
>
>
>
>
>
> On Sunday, June 1, 2025 at 11:21:28 PM UTC+8 Oliver Eikemeier wrote:
>
> > Am 27.06.2024 um 05:17 schrieb Ian Lance Taylor <ia...@golang.org>:
> >
> > On Tue, Jun 25, 2024 at 9:37 PM 'Axel Wagner' via golang-nuts
> > <golan...@googlegroups.com> wrote:
> >>
> >> you might be interested to learn that Ian has filed a CL adding an FAQ
> entry.
> >
> > Now committed at https://go.dev/doc/faq#zero_size_types .
> >
> > Ian
>
> Thanks for that. I discovered that comparing pointers to ZSTs is pretty
> popular in Go:
>
> - x/sync/singleflight:
> https://cs.opensource.google/go/x/sync/+/refs/tags/v0.14.0:singleflight/singleflight_test.go;l=78
>
> - Delve:
> https://github.com/go-delve/delve/blob/v1.24.2/service/debugger/debugger.go#L387
>
> - Grafana:
> https://github.com/grafana/grafana/blob/v12.0.1/pkg/services/serviceaccounts/extsvcaccounts/service.go#L353
>
> - Skaffold:
> https://github.com/GoogleContainerTools/skaffold/blob/v2.16.0/pkg/skaffold/hooks/render.go#L93
>
> - Coder: https://github.com/coder/coder/blob/v2.22.1/cli/ssh.go#L578
>
> - quic-go:
> https://github.com/quic-go/quic-go/blob/v0.52.0/connection_test.go#L1008
>
> - SigStore Cosign:
> https://github.com/sigstore/cosign/blob/v2.5.0/cmd/cosign/cli/attest/attest_blob_test.go#L60
>
> Seems like a classic example of Hyrum's Law, we now have a lot of code
> that depends on runtime.zerobase.
>
>
>
> It looks all of bad code (using errors.Is) should use errors.As instead.
>
> This indeed reflects that the design of the errors APIs is prone to being
> misused.
>
>
>
> An "errros/v2" is really needed to avoid such misuses.
>
>
>
>
>
> I’ve written a linter along with an accompanying blog post about the
> subject:
>
> fillmore-labs.com/zerolint: https://github.com/fillmore-labs/zerolint
>
> “The Perils of Pointers in the Land of the Zero-Sized Type”:
> https://blog.fillmore-labs.com/posts/zerosized-1/
>
>
> I would be interested whether I got the “default” level right. Or maybe
> everything wrong.
>
> Thanks for the insight, again
> Oliver
>
> --
> 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...@googlegroups.com.
>
> To view this discussion visit
> https://groups.google.com/d/msgid/golang-nuts/7750b85c-2e09-4e42-a290-480b81caf19dn%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/7750b85c-2e09-4e42-a290-480b81caf19dn%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>
> --
> 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...@googlegroups.com.
>
> To view this discussion visit
> https://groups.google.com/d/msgid/golang-nuts/06eef021-6d5b-496c-898f-bdd375453b35n%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/06eef021-6d5b-496c-898f-bdd375453b35n%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>
> --
> 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...@googlegroups.com.
>
> To view this discussion visit
> https://groups.google.com/d/msgid/golang-nuts/d9b53c59-1d53-49bc-98e0-5d0b587b5705n%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/d9b53c59-1d53-49bc-98e0-5d0b587b5705n%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>
> --
> 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 visit
> https://groups.google.com/d/msgid/golang-nuts/39f6abe2-3cd9-4cd0-8998-44cf5157df8bn%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/39f6abe2-3cd9-4cd0-8998-44cf5157df8bn%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>

-- 
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 visit 
https://groups.google.com/d/msgid/golang-nuts/CAEkBMfGZarSO9GqGRmPCAm4KxSATQ6ZNirwW_6RBwJ4wUnsazQ%40mail.gmail.com.

Reply via email to