Rusty 🦀 Femboy 🏳️🌈 to Programmer [email protected]English • 6 hours agoI love Rustlemmy.blahaj.zoneimagemessage-square31fedilinkarrow-up1111arrow-down111
arrow-up1100arrow-down1imageI love Rustlemmy.blahaj.zoneRusty 🦀 Femboy 🏳️🌈 to Programmer [email protected]English • 6 hours agomessage-square31fedilink
minus-square@Gonzakolink2•5 hours agoI’ve only had to implement equality in C# but that didn’t seem that hard of a problem. you just expand the operator = function
minus-square@[email protected]linkfedilink7•4 hours agoIt’s not hard, just if you’re doing it for a struct with a lot of fields it’s a lot of boilerplate
minus-square@[email protected]linkfedilink1•edit-23 hours agoI just use the HashCode class and compare the results. Pretty sure there’s a source generator for it as well nowadays.
minus-square@Deckweisslink-3•edit-23 hours agoMy 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.
minus-square@[email protected]linkfedilink3•2 hours agoEven 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.
minus-squarecopygirllinkfedilinkEnglish2•3 hours agoThen 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);
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
It’s not hard, just if you’re doing it for a struct with a lot of fields it’s a lot of boilerplate
I just use the HashCode class and compare the results.
Pretty sure there’s a source generator for it as well nowadays.
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.
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.
Then you should also override
Equals(object)
,GetHashCode
, and implementIEquatable<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);