module Data.Derive.ArbitraryOld where
{-
import "QuickCheck-1.2.0.0" Test.QuickCheck(Arbitrary(..), choose,variant)

example :: Sample

instance Arbitrary a => Arbitrary (Sample a) where
    arbitrary = do
        x <- choose (0,length [First{},Second{},Third{}]-1)
        case x of
            0 -> do return (First)
            1 -> do x1 <- arbitrary
                    x2 <- arbitrary
                    return (Second x1 x2)
            2 -> do x1 <- arbitrary
                    return (Third x1)

    coarbitrary (First) = variant 0
    coarbitrary (Second x1 x2) = variant 1 . coarbitrary x1 . coarbitrary x2
    coarbitrary (Third x1) = variant 2 . coarbitrary x1

-}
-- GENERATED START

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

makeArbitraryOld :: Derivation
makeArbitraryOld = derivationDSL "ArbitraryOld" dslArbitraryOld

dslArbitraryOld =
    List [Instance ["Arbitrary"] "Arbitrary" (List [App "InsDecl" (
    List [App "PatBind" (List [App "PVar" (List [App "Ident" (List [
    String "arbitrary"])]),App "Nothing" (List []),App "UnGuardedRhs"
    (List [App "Do" (List [List [App "Generator" (List [App "PVar" (
    List [App "Ident" (List [String "x"])]),App "App" (List [App "Var"
    (List [App "UnQual" (List [App "Ident" (List [String "choose"])])]
    ),App "Tuple" (List [List [App "Lit" (List [App "Int" (List [Int 0
    ])]),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 "Qualifier" (
    List [App "Case" (List [App "Var" (List [App "UnQual" (List [App
    "Ident" (List [String "x"])])]),MapCtor (App "Alt" (List [App
    "PLit" (List [App "Int" (List [CtorIndex])]),App "UnGuardedAlt" (
    List [App "Do" (List [Concat (List [MapField (App "Generator" (
    List [App "PVar" (List [App "Ident" (List [Concat (List [String
    "x",ShowInt FieldIndex])])]),App "Var" (List [App "UnQual" (List [
    App "Ident" (List [String "arbitrary"])])])])),List [App
    "Qualifier" (List [App "App" (List [App "Var" (List [App "UnQual"
    (List [App "Ident" (List [String "return"])])]),App "Paren" (List
    [Application (Concat (List [List [App "Con" (List [App "UnQual" (
    List [App "Ident" (List [CtorName])])])],MapField (App "Var" (List
    [App "UnQual" (List [App "Ident" (List [Concat (List [String "x",
    ShowInt FieldIndex])])])]))]))])])])]])])]),App "BDecls" (List [
    List []])]))])])]])]),App "BDecls" (List [List []])])]),App
    "InsDecl" (List [App "FunBind" (List [MapCtor (App "Match" (List [
    App "Ident" (List [String "coarbitrary"]),List [App "PParen" (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 "Nothing" (List []),
    App "UnGuardedRhs" (List [Fold (App "InfixApp" (List [Head,App
    "QVarOp" (List [App "UnQual" (List [App "Symbol" (List [String "."
    ])])]),Tail])) (Concat (List [List [App "App" (List [App "Var" (
    List [App "UnQual" (List [App "Ident" (List [String "variant"])])]
    ),App "Lit" (List [App "Int" (List [CtorIndex])])])],MapField (App
    "App" (List [App "Var" (List [App "UnQual" (List [App "Ident" (
    List [String "coarbitrary"])])]),App "Var" (List [App "UnQual" (
    List [App "Ident" (List [Concat (List [String "x",ShowInt
    FieldIndex])])])])]))]))]),App "BDecls" (List [List []])]))])])])]
-- GENERATED STOP