module Data.Derive.Bounded where
{-
import Prelude

example :: Sample

instance Bounded a => Bounded (Sample a) where
    minBound = head [First, Second (const minBound 1) (const minBound 2), Third (const minBound 1)]
    maxBound = head [Third (const maxBound 1), Second (const maxBound 1) (const maxBound 2), First]

-}
-- GENERATED START

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

makeBounded :: Derivation
makeBounded = derivationDSL "Bounded" dslBounded

dslBounded =
    List [Instance ["Bounded"] "Bounded" (List [App "InsDecl" (List [
    App "PatBind" (List [App "PVar" (List [App "Ident" (List [String
    "minBound"])]),App "UnGuardedRhs" (List [App "App" (List [App
    "Var" (List [App "UnQual" (List [App "Ident" (List [String "head"]
    )])]),App "List" (List [MapCtor (Application (Concat (List [List [
    App "Con" (List [App "UnQual" (List [App "Ident" (List [CtorName])
    ])])],MapField (App "Paren" (List [Application (List [App "Var" (
    List [App "UnQual" (List [App "Ident" (List [String "const"])])]),
    App "Var" (List [App "UnQual" (List [App "Ident" (List [String
    "minBound"])])]),App "Lit" (List [App "Int" (List [FieldIndex])])]
    )]))])))])])]),App "BDecls" (List [List []])])]),App "InsDecl" (
    List [App "PatBind" (List [App "PVar" (List [App "Ident" (List [
    String "maxBound"])]),App "UnGuardedRhs" (List [App "App" (List [
    App "Var" (List [App "UnQual" (List [App "Ident" (List [String
    "head"])])]),App "List" (List [Reverse (MapCtor (Application (
    Concat (List [List [App "Con" (List [App "UnQual" (List [App
    "Ident" (List [CtorName])])])],MapField (App "Paren" (List [
    Application (List [App "Var" (List [App "UnQual" (List [App
    "Ident" (List [String "const"])])]),App "Var" (List [App "UnQual"
    (List [App "Ident" (List [String "maxBound"])])]),App "Lit" (List
    [App "Int" (List [FieldIndex])])])]))]))))])])]),App "BDecls" (
    List [List []])])])])]
-- GENERATED STOP