• Gonzako@lemmy.world
    link
    fedilink
    arrow-up
    5
    arrow-down
    1
    ·
    1 month ago

    I’ve only had to implement equality in C# but that didn’t seem that hard of a problem. you just expand the operator = function

      • Deckweiss@lemmy.world
        link
        fedilink
        arrow-up
        1
        arrow-down
        6
        ·
        edit-2
        1 month ago

        My IDE can do that for me. And it was able to do that pre AI boom. Yes, the code ends up more verbose, but I just collapse it.

        So from a modern dev UX perspective, this shouldn’t be a major difference.

        • porous_grey_matter@lemmy.ml
          link
          fedilink
          arrow-up
          5
          arrow-down
          1
          ·
          1 month ago

          Even if the tool works perfectly, you have to run it every time you change something. It’s not the end of the world, but it’s still much nicer to just have a macro to derive it at compile time.

        • kazaika@lemmy.world
          link
          fedilink
          arrow-up
          2
          ·
          1 month ago

          What if youre working with library types? The problem is not not you compare a bunch of fields but that the implementation on those members is most likely bad.

    • copygirl@lemmy.blahaj.zone
      link
      fedilink
      English
      arrow-up
      7
      ·
      1 month ago

      Then you should also override Equals(object), GetHashCode, and implement IEquatable<T>.

      Thankfully a lot of the usual boilerplate code can be avoided using a record class or struct:

      public record Person(string Name, uint Age);
      
      • Gonzako@lemmy.world
        link
        fedilink
        arrow-up
        1
        ·
        1 month ago

        Oh well, It does show how little I do have to actually use that. It just hasn’t come up that much