{-# language AllowAmbiguousTypes #-} {-# language DataKinds #-} {-# language FlexibleContexts #-} {-# language FlexibleInstances #-} {-# language MultiParamTypeClasses #-} {-# language PolyKinds #-} {-# language QuantifiedConstraints #-} {-# language ScopedTypeVariables #-} {-# language TypeApplications #-} {-# language TypeFamilies #-} {-# language TypeOperators #-} {-# language UndecidableInstances #-} module Generics.Kind.Derive.EqTwoParams where import Data.Kind import Generics.Kind geq2' :: forall t. (GenericK t, GEq2 (RepK t) 'LoT0 'LoT0) => t -> t -> Bool geq2' x y = geq2 (fromK @_ @t @'LoT0 x) (fromK @_ @t @'LoT0 y) class GEq2 (f :: LoT k -> Type) (xs :: LoT k) (ys :: LoT k) where geq2 :: f xs -> f ys -> Bool instance GEq2 U1 xs ys where geq2 U1 U1 = True instance (GEq2 f xs ys) => GEq2 (M1 i c f) xs ys where geq2 (M1 x) (M1 y) = geq2 x y instance (GEq2 f xs ys, GEq2 g xs ys) => GEq2 (f :+: g) xs ys where geq2 (L1 x) (L1 y) = geq2 x y geq2 (R1 x) (R1 y) = geq2 x y geq2 _ _ = False instance (GEq2 f xs ys, GEq2 g xs ys) => GEq2 (f :*: g) xs ys where geq2 (x1 :*: x2) (y1 :*: y2) = geq2 x1 y1 && geq2 x2 y2 instance (Interpret t xs ~ Interpret t ys, Eq (Interpret t xs)) => GEq2 (Field t) xs ys where geq2 (Field x) (Field y) = x == y instance ((Interpret c xs, Interpret c ys) => GEq2 f xs ys) => GEq2 (c :=>: f) xs ys where geq2 (SuchThat x) (SuchThat y) = geq2 x y instance (forall x y. GEq2 f (x ':&&: xs) (y ':&&: ys)) => GEq2 (Exists k f) xs ys where geq2 (Exists x) (Exists y) = geq2 x y {- instance (forall x y. GEq2 f (x ':&&: xs) (y ':&&: ys)) => GEq2 (ERefl f) xs ys where geq2 (ERefl (x :: f (x :&&: xs))) (ERefl (y :: f (y :&&: ys))) = case eqTypeRep (typeRep @x) (typeRep @y) of Nothing -> False Just HRefl -> geq2 x y -}