plutus icon indicating copy to clipboard operation
plutus copied to clipboard

Derivation of Ord type class

Open mgajda opened this issue 3 years ago • 2 comments

Describe the feature you'd like

PlutusTx.Ord does not have automatic derivation mechanism which means a lot of error-prone work for large algebraic datatypes.

It would be nice to have TemplateHaskell derivation deriveOrd just like makeLift or a mechanism based on Generic.

Describe alternatives you've considered

Alternative is to manually derive Ord instances. It is not only a lot of manual work (with 20 constructors we see about 190 comparisons), but it is also error prone. Since this work also needs to be audited, any such work may also lead to slight increase in cost of the smart contract security.

Describe the approach you would take to implement this

I would follow makeLift as a template, and define the deriveOrd in a similar fashion. Please let me know if you have a better plan.

Additional context / screenshots

Several type classes as fundamental for best practice of Haskell programming and derived automatically for ADTs:

  • Eq (which can be derived from Ord and suffers from the same problem)
  • Enum
  • Bounded
  • Arbitrary

Expansion of this work can serve to help maintain the best practices of using these without extra coding.

mgajda avatar Dec 08 '21 22:12 mgajda

While this would be nice, writing large amounts of TH is fairly unpleasant and error-prone. This would be a good thing for someone to contribute!

michaelpj avatar Dec 17 '21 14:12 michaelpj

Whatever we do to resolve #5129 will help with this issue as well.

effectfully avatar Feb 22 '23 18:02 effectfully