module Data.Derive.Eq where
{-
import Prelude

example :: Sample

instance (Eq a) => Eq (Sample a) where
    First == First = True
    Second x1 x2 == Second y1 y2 = x1 == y1 && x2 == y2 && True
    Third x1 == Third y1 = x1 == y1 && True
    _ == _ | length [First{},Second{},Third{}] > 1 = False

test :: Assoced
instance Eq typ => Eq (Assoced typ) where
    Assoced x1 x2 == Assoced y1 y2 = x1 == y1 && x2 == y2

test :: TwoParam
instance Eq b => Eq (TwoParam a b) where
    TwoParam x1 == TwoParam y1 = x1 == y1

-}
-- GENERATED START

import Data.Derive.DSL.DSL
import Data.Derive.Internal.Derivation

makeEq :: Derivation
makeEq = derivationDSL "Eq" dslEq

dslEq =
    List [Instance ["Eq"] "Eq" (List [App "InsDecl" (List [App
    "FunBind" (List [Concat (List [MapCtor (App "Match" (List [App
    "Symbol" (List [String "=="]),List [App "PApp" (List [App "UnQual"
    (List [App "Ident" (List [CtorName])]),MapField (App "PVar" (List
    [App "Ident" (List [Concat (List [String "x",ShowInt FieldIndex])]
    )]))]),App "PApp" (List [App "UnQual" (List [App "Ident" (List [
    CtorName])]),MapField (App "PVar" (List [App "Ident" (List [Concat
    (List [String "y",ShowInt FieldIndex])])]))])],App "Nothing" (List
    []),App "UnGuardedRhs" (List [Fold (App "InfixApp" (List [Head,App
    "QVarOp" (List [App "UnQual" (List [App "Symbol" (List [String
    "&&"])])]),Tail])) (Concat (List [MapField (App "InfixApp" (List [
    App "Var" (List [App "UnQual" (List [App "Ident" (List [Concat (
    List [String "x",ShowInt FieldIndex])])])]),App "QVarOp" (List [
    App "UnQual" (List [App "Symbol" (List [String "=="])])]),App
    "Var" (List [App "UnQual" (List [App "Ident" (List [Concat (List [
    String "y",ShowInt FieldIndex])])])])])),List [App "Con" (List [
    App "UnQual" (List [App "Ident" (List [String "True"])])])]]))]),
    App "BDecls" (List [List []])])),List [App "Match" (List [App
    "Symbol" (List [String "=="]),List [App "PWildCard" (List []),App
    "PWildCard" (List [])],App "Nothing" (List []),App "GuardedRhss" (
    List [List [App "GuardedRhs" (List [List [App "Qualifier" (List [
    App "InfixApp" (List [App "App" (List [App "Var" (List [App
    "UnQual" (List [App "Ident" (List [String "length"])])]),App
    "List" (List [MapCtor (App "RecConstr" (List [App "UnQual" (List [
    App "Ident" (List [CtorName])]),List []]))])]),App "QVarOp" (List
    [App "UnQual" (List [App "Symbol" (List [String ">"])])]),App
    "Lit" (List [App "Int" (List [Int 1])])])])],App "Con" (List [App
    "UnQual" (List [App "Ident" (List [String "False"])])])])]]),App
    "BDecls" (List [List []])])]])])])])]
-- GENERATED STOP