{-# LANGUAGE CPP #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE GeneralizedNewtypeDeriving #-} {-# LANGUAGE StandaloneDeriving #-} {-# OPTIONS_GHC -fno-warn-orphans #-} {-| Module: Instances.Text.PrettyPrint Copyright: (C) 2014-2017 Ryan Scott License: BSD-style (see the file LICENSE) Maintainer: Ryan Scott Stability: Provisional Portability: GHC Provides 'Arbitrary' instances for data types in the @pretty@ library (as well as 'Show' instances if using an old version of @pretty@). -} module Instances.Text.PrettyPrint () where #if !(MIN_VERSION_pretty(1,1,2)) || MIN_VERSION_pretty(1,1,3) import GHC.Generics (Generic) #endif import Instances.Utils.GenericArbitrary (genericArbitrary) import Prelude () import Prelude.Compat import Test.QuickCheck (Arbitrary(..), arbitraryBoundedEnum) import Text.PrettyPrint.HughesPJ (Doc, Mode(..), Style(..), TextDetails(..), text) #if MIN_VERSION_pretty(1,1,2) import Text.PrettyPrint.HughesPJClass (PrettyLevel(..)) #endif #if MIN_VERSION_pretty(1,1,3) import qualified Text.PrettyPrint.Annotated.HughesPJ as Annot (Doc, text) import Text.PrettyPrint.Annotated.HughesPJ (AnnotDetails(..), Span(..)) import qualified Text.PrettyPrint.Annotated.HughesPJClass as Annot (PrettyLevel(..)) #endif instance Arbitrary Doc where arbitrary = text <$> arbitrary deriving instance Bounded Mode deriving instance Enum Mode instance Arbitrary Mode where arbitrary = arbitraryBoundedEnum instance Arbitrary Style where arbitrary = genericArbitrary instance Arbitrary TextDetails where arbitrary = genericArbitrary #if MIN_VERSION_pretty(1,1,2) deriving instance Arbitrary PrettyLevel #else deriving instance Show Mode deriving instance Show Style deriving instance Show TextDetails deriving instance Generic Style deriving instance Generic TextDetails #endif #if MIN_VERSION_pretty(1,1,3) instance Arbitrary a => Arbitrary (AnnotDetails a) where arbitrary = genericArbitrary instance Arbitrary (Annot.Doc a) where arbitrary = Annot.text <$> arbitrary deriving instance Arbitrary Annot.PrettyLevel instance Arbitrary a => Arbitrary (Span a) where arbitrary = genericArbitrary deriving instance Generic (AnnotDetails a) deriving instance Generic (Span a) #endif