{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveGeneric #-}
module SDL.Internal.Types
  ( Joystick(..)
  , GameController(..)
  , Window(..)
  , Renderer(..)
  ) where

import Data.Data (Data)
import Data.Typeable
import GHC.Generics (Generic)

import qualified SDL.Raw as Raw

newtype Joystick = Joystick { Joystick -> Joystick
joystickPtr :: Raw.Joystick }
  deriving (Typeable Joystick
Joystick -> DataType
Joystick -> Constr
(forall b. Data b => b -> b) -> Joystick -> Joystick
forall a.
Typeable a
-> (forall (c :: Type -> Type).
    (forall d b. Data d => c (d -> b) -> d -> c b)
    -> (forall g. g -> c g) -> a -> c a)
-> (forall (c :: Type -> Type).
    (forall b r. Data b => c (b -> r) -> c r)
    -> (forall r. r -> c r) -> Constr -> c a)
-> (a -> Constr)
-> (a -> DataType)
-> (forall (t :: Type -> Type) (c :: Type -> Type).
    Typeable t =>
    (forall d. Data d => c (t d)) -> Maybe (c a))
-> (forall (t :: Type -> Type -> Type) (c :: Type -> Type).
    Typeable t =>
    (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c a))
-> ((forall b. Data b => b -> b) -> a -> a)
-> (forall r r'.
    (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall r r'.
    (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall u. (forall d. Data d => d -> u) -> a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> a -> u)
-> (forall (m :: Type -> Type).
    Monad m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: Type -> Type).
    MonadPlus m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: Type -> Type).
    MonadPlus m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> Data a
forall u. Int -> (forall d. Data d => d -> u) -> Joystick -> u
forall u. (forall d. Data d => d -> u) -> Joystick -> [u]
forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> Joystick -> r
forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> Joystick -> r
forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Joystick -> m Joystick
forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Joystick -> m Joystick
forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Joystick
forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Joystick -> c Joystick
forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Joystick)
forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Joystick)
gmapMo :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Joystick -> m Joystick
$cgmapMo :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Joystick -> m Joystick
gmapMp :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Joystick -> m Joystick
$cgmapMp :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Joystick -> m Joystick
gmapM :: forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Joystick -> m Joystick
$cgmapM :: forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Joystick -> m Joystick
gmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Joystick -> u
$cgmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Joystick -> u
gmapQ :: forall u. (forall d. Data d => d -> u) -> Joystick -> [u]
$cgmapQ :: forall u. (forall d. Data d => d -> u) -> Joystick -> [u]
gmapQr :: forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> Joystick -> r
$cgmapQr :: forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> Joystick -> r
gmapQl :: forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> Joystick -> r
$cgmapQl :: forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> Joystick -> r
gmapT :: (forall b. Data b => b -> b) -> Joystick -> Joystick
$cgmapT :: (forall b. Data b => b -> b) -> Joystick -> Joystick
dataCast2 :: forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Joystick)
$cdataCast2 :: forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Joystick)
dataCast1 :: forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Joystick)
$cdataCast1 :: forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Joystick)
dataTypeOf :: Joystick -> DataType
$cdataTypeOf :: Joystick -> DataType
toConstr :: Joystick -> Constr
$ctoConstr :: Joystick -> Constr
gunfold :: forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Joystick
$cgunfold :: forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Joystick
gfoldl :: forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Joystick -> c Joystick
$cgfoldl :: forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Joystick -> c Joystick
Data, Joystick -> Joystick -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Joystick -> Joystick -> Bool
$c/= :: Joystick -> Joystick -> Bool
== :: Joystick -> Joystick -> Bool
$c== :: Joystick -> Joystick -> Bool
Eq, forall x. Rep Joystick x -> Joystick
forall x. Joystick -> Rep Joystick x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep Joystick x -> Joystick
$cfrom :: forall x. Joystick -> Rep Joystick x
Generic, Eq Joystick
Joystick -> Joystick -> Bool
Joystick -> Joystick -> Ordering
Joystick -> Joystick -> Joystick
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: Joystick -> Joystick -> Joystick
$cmin :: Joystick -> Joystick -> Joystick
max :: Joystick -> Joystick -> Joystick
$cmax :: Joystick -> Joystick -> Joystick
>= :: Joystick -> Joystick -> Bool
$c>= :: Joystick -> Joystick -> Bool
> :: Joystick -> Joystick -> Bool
$c> :: Joystick -> Joystick -> Bool
<= :: Joystick -> Joystick -> Bool
$c<= :: Joystick -> Joystick -> Bool
< :: Joystick -> Joystick -> Bool
$c< :: Joystick -> Joystick -> Bool
compare :: Joystick -> Joystick -> Ordering
$ccompare :: Joystick -> Joystick -> Ordering
Ord, Int -> Joystick -> ShowS
[Joystick] -> ShowS
Joystick -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [Joystick] -> ShowS
$cshowList :: [Joystick] -> ShowS
show :: Joystick -> String
$cshow :: Joystick -> String
showsPrec :: Int -> Joystick -> ShowS
$cshowsPrec :: Int -> Joystick -> ShowS
Show, Typeable)

newtype GameController = GameController
  { GameController -> Joystick
gameControllerPtr :: Raw.GameController }
  deriving (Typeable GameController
GameController -> DataType
GameController -> Constr
(forall b. Data b => b -> b) -> GameController -> GameController
forall a.
Typeable a
-> (forall (c :: Type -> Type).
    (forall d b. Data d => c (d -> b) -> d -> c b)
    -> (forall g. g -> c g) -> a -> c a)
-> (forall (c :: Type -> Type).
    (forall b r. Data b => c (b -> r) -> c r)
    -> (forall r. r -> c r) -> Constr -> c a)
-> (a -> Constr)
-> (a -> DataType)
-> (forall (t :: Type -> Type) (c :: Type -> Type).
    Typeable t =>
    (forall d. Data d => c (t d)) -> Maybe (c a))
-> (forall (t :: Type -> Type -> Type) (c :: Type -> Type).
    Typeable t =>
    (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c a))
-> ((forall b. Data b => b -> b) -> a -> a)
-> (forall r r'.
    (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall r r'.
    (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall u. (forall d. Data d => d -> u) -> a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> a -> u)
-> (forall (m :: Type -> Type).
    Monad m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: Type -> Type).
    MonadPlus m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: Type -> Type).
    MonadPlus m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> Data a
forall u.
Int -> (forall d. Data d => d -> u) -> GameController -> u
forall u. (forall d. Data d => d -> u) -> GameController -> [u]
forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> GameController -> r
forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> GameController -> r
forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d)
-> GameController -> m GameController
forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d)
-> GameController -> m GameController
forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c GameController
forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> GameController -> c GameController
forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c GameController)
forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e))
-> Maybe (c GameController)
gmapMo :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d)
-> GameController -> m GameController
$cgmapMo :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d)
-> GameController -> m GameController
gmapMp :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d)
-> GameController -> m GameController
$cgmapMp :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d)
-> GameController -> m GameController
gmapM :: forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d)
-> GameController -> m GameController
$cgmapM :: forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d)
-> GameController -> m GameController
gmapQi :: forall u.
Int -> (forall d. Data d => d -> u) -> GameController -> u
$cgmapQi :: forall u.
Int -> (forall d. Data d => d -> u) -> GameController -> u
gmapQ :: forall u. (forall d. Data d => d -> u) -> GameController -> [u]
$cgmapQ :: forall u. (forall d. Data d => d -> u) -> GameController -> [u]
gmapQr :: forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> GameController -> r
$cgmapQr :: forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> GameController -> r
gmapQl :: forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> GameController -> r
$cgmapQl :: forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> GameController -> r
gmapT :: (forall b. Data b => b -> b) -> GameController -> GameController
$cgmapT :: (forall b. Data b => b -> b) -> GameController -> GameController
dataCast2 :: forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e))
-> Maybe (c GameController)
$cdataCast2 :: forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e))
-> Maybe (c GameController)
dataCast1 :: forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c GameController)
$cdataCast1 :: forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c GameController)
dataTypeOf :: GameController -> DataType
$cdataTypeOf :: GameController -> DataType
toConstr :: GameController -> Constr
$ctoConstr :: GameController -> Constr
gunfold :: forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c GameController
$cgunfold :: forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c GameController
gfoldl :: forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> GameController -> c GameController
$cgfoldl :: forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> GameController -> c GameController
Data, GameController -> GameController -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GameController -> GameController -> Bool
$c/= :: GameController -> GameController -> Bool
== :: GameController -> GameController -> Bool
$c== :: GameController -> GameController -> Bool
Eq, forall x. Rep GameController x -> GameController
forall x. GameController -> Rep GameController x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep GameController x -> GameController
$cfrom :: forall x. GameController -> Rep GameController x
Generic, Eq GameController
GameController -> GameController -> Bool
GameController -> GameController -> Ordering
GameController -> GameController -> GameController
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: GameController -> GameController -> GameController
$cmin :: GameController -> GameController -> GameController
max :: GameController -> GameController -> GameController
$cmax :: GameController -> GameController -> GameController
>= :: GameController -> GameController -> Bool
$c>= :: GameController -> GameController -> Bool
> :: GameController -> GameController -> Bool
$c> :: GameController -> GameController -> Bool
<= :: GameController -> GameController -> Bool
$c<= :: GameController -> GameController -> Bool
< :: GameController -> GameController -> Bool
$c< :: GameController -> GameController -> Bool
compare :: GameController -> GameController -> Ordering
$ccompare :: GameController -> GameController -> Ordering
Ord, Int -> GameController -> ShowS
[GameController] -> ShowS
GameController -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GameController] -> ShowS
$cshowList :: [GameController] -> ShowS
show :: GameController -> String
$cshow :: GameController -> String
showsPrec :: Int -> GameController -> ShowS
$cshowsPrec :: Int -> GameController -> ShowS
Show, Typeable)

newtype Window = Window (Raw.Window)
  deriving (Typeable Window
Window -> DataType
Window -> Constr
(forall b. Data b => b -> b) -> Window -> Window
forall a.
Typeable a
-> (forall (c :: Type -> Type).
    (forall d b. Data d => c (d -> b) -> d -> c b)
    -> (forall g. g -> c g) -> a -> c a)
-> (forall (c :: Type -> Type).
    (forall b r. Data b => c (b -> r) -> c r)
    -> (forall r. r -> c r) -> Constr -> c a)
-> (a -> Constr)
-> (a -> DataType)
-> (forall (t :: Type -> Type) (c :: Type -> Type).
    Typeable t =>
    (forall d. Data d => c (t d)) -> Maybe (c a))
-> (forall (t :: Type -> Type -> Type) (c :: Type -> Type).
    Typeable t =>
    (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c a))
-> ((forall b. Data b => b -> b) -> a -> a)
-> (forall r r'.
    (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall r r'.
    (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall u. (forall d. Data d => d -> u) -> a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> a -> u)
-> (forall (m :: Type -> Type).
    Monad m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: Type -> Type).
    MonadPlus m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: Type -> Type).
    MonadPlus m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> Data a
forall u. Int -> (forall d. Data d => d -> u) -> Window -> u
forall u. (forall d. Data d => d -> u) -> Window -> [u]
forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Window -> r
forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Window -> r
forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Window -> m Window
forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Window -> m Window
forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Window
forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Window -> c Window
forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Window)
forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Window)
gmapMo :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Window -> m Window
$cgmapMo :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Window -> m Window
gmapMp :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Window -> m Window
$cgmapMp :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Window -> m Window
gmapM :: forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Window -> m Window
$cgmapM :: forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Window -> m Window
gmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Window -> u
$cgmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Window -> u
gmapQ :: forall u. (forall d. Data d => d -> u) -> Window -> [u]
$cgmapQ :: forall u. (forall d. Data d => d -> u) -> Window -> [u]
gmapQr :: forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Window -> r
$cgmapQr :: forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Window -> r
gmapQl :: forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Window -> r
$cgmapQl :: forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Window -> r
gmapT :: (forall b. Data b => b -> b) -> Window -> Window
$cgmapT :: (forall b. Data b => b -> b) -> Window -> Window
dataCast2 :: forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Window)
$cdataCast2 :: forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Window)
dataCast1 :: forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Window)
$cdataCast1 :: forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Window)
dataTypeOf :: Window -> DataType
$cdataTypeOf :: Window -> DataType
toConstr :: Window -> Constr
$ctoConstr :: Window -> Constr
gunfold :: forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Window
$cgunfold :: forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Window
gfoldl :: forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Window -> c Window
$cgfoldl :: forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Window -> c Window
Data, Window -> Window -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Window -> Window -> Bool
$c/= :: Window -> Window -> Bool
== :: Window -> Window -> Bool
$c== :: Window -> Window -> Bool
Eq, forall x. Rep Window x -> Window
forall x. Window -> Rep Window x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep Window x -> Window
$cfrom :: forall x. Window -> Rep Window x
Generic, Eq Window
Window -> Window -> Bool
Window -> Window -> Ordering
Window -> Window -> Window
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: Window -> Window -> Window
$cmin :: Window -> Window -> Window
max :: Window -> Window -> Window
$cmax :: Window -> Window -> Window
>= :: Window -> Window -> Bool
$c>= :: Window -> Window -> Bool
> :: Window -> Window -> Bool
$c> :: Window -> Window -> Bool
<= :: Window -> Window -> Bool
$c<= :: Window -> Window -> Bool
< :: Window -> Window -> Bool
$c< :: Window -> Window -> Bool
compare :: Window -> Window -> Ordering
$ccompare :: Window -> Window -> Ordering
Ord, Int -> Window -> ShowS
[Window] -> ShowS
Window -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [Window] -> ShowS
$cshowList :: [Window] -> ShowS
show :: Window -> String
$cshow :: Window -> String
showsPrec :: Int -> Window -> ShowS
$cshowsPrec :: Int -> Window -> ShowS
Show, Typeable)

-- | An SDL rendering device. This can be created with 'SDL.Video.createRenderer'.
newtype Renderer = Renderer Raw.Renderer
  deriving (Typeable Renderer
Renderer -> DataType
Renderer -> Constr
(forall b. Data b => b -> b) -> Renderer -> Renderer
forall a.
Typeable a
-> (forall (c :: Type -> Type).
    (forall d b. Data d => c (d -> b) -> d -> c b)
    -> (forall g. g -> c g) -> a -> c a)
-> (forall (c :: Type -> Type).
    (forall b r. Data b => c (b -> r) -> c r)
    -> (forall r. r -> c r) -> Constr -> c a)
-> (a -> Constr)
-> (a -> DataType)
-> (forall (t :: Type -> Type) (c :: Type -> Type).
    Typeable t =>
    (forall d. Data d => c (t d)) -> Maybe (c a))
-> (forall (t :: Type -> Type -> Type) (c :: Type -> Type).
    Typeable t =>
    (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c a))
-> ((forall b. Data b => b -> b) -> a -> a)
-> (forall r r'.
    (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall r r'.
    (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall u. (forall d. Data d => d -> u) -> a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> a -> u)
-> (forall (m :: Type -> Type).
    Monad m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: Type -> Type).
    MonadPlus m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: Type -> Type).
    MonadPlus m =>
    (forall d. Data d => d -> m d) -> a -> m a)
-> Data a
forall u. Int -> (forall d. Data d => d -> u) -> Renderer -> u
forall u. (forall d. Data d => d -> u) -> Renderer -> [u]
forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> Renderer -> r
forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> Renderer -> r
forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Renderer -> m Renderer
forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Renderer -> m Renderer
forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Renderer
forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Renderer -> c Renderer
forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Renderer)
forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Renderer)
gmapMo :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Renderer -> m Renderer
$cgmapMo :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Renderer -> m Renderer
gmapMp :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Renderer -> m Renderer
$cgmapMp :: forall (m :: Type -> Type).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Renderer -> m Renderer
gmapM :: forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Renderer -> m Renderer
$cgmapM :: forall (m :: Type -> Type).
Monad m =>
(forall d. Data d => d -> m d) -> Renderer -> m Renderer
gmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Renderer -> u
$cgmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Renderer -> u
gmapQ :: forall u. (forall d. Data d => d -> u) -> Renderer -> [u]
$cgmapQ :: forall u. (forall d. Data d => d -> u) -> Renderer -> [u]
gmapQr :: forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> Renderer -> r
$cgmapQr :: forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> Renderer -> r
gmapQl :: forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> Renderer -> r
$cgmapQl :: forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> Renderer -> r
gmapT :: (forall b. Data b => b -> b) -> Renderer -> Renderer
$cgmapT :: (forall b. Data b => b -> b) -> Renderer -> Renderer
dataCast2 :: forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Renderer)
$cdataCast2 :: forall (t :: Type -> Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Renderer)
dataCast1 :: forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Renderer)
$cdataCast1 :: forall (t :: Type -> Type) (c :: Type -> Type).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Renderer)
dataTypeOf :: Renderer -> DataType
$cdataTypeOf :: Renderer -> DataType
toConstr :: Renderer -> Constr
$ctoConstr :: Renderer -> Constr
gunfold :: forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Renderer
$cgunfold :: forall (c :: Type -> Type).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Renderer
gfoldl :: forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Renderer -> c Renderer
$cgfoldl :: forall (c :: Type -> Type).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Renderer -> c Renderer
Data, Renderer -> Renderer -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Renderer -> Renderer -> Bool
$c/= :: Renderer -> Renderer -> Bool
== :: Renderer -> Renderer -> Bool
$c== :: Renderer -> Renderer -> Bool
Eq, forall x. Rep Renderer x -> Renderer
forall x. Renderer -> Rep Renderer x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep Renderer x -> Renderer
$cfrom :: forall x. Renderer -> Rep Renderer x
Generic, Eq Renderer
Renderer -> Renderer -> Bool
Renderer -> Renderer -> Ordering
Renderer -> Renderer -> Renderer
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: Renderer -> Renderer -> Renderer
$cmin :: Renderer -> Renderer -> Renderer
max :: Renderer -> Renderer -> Renderer
$cmax :: Renderer -> Renderer -> Renderer
>= :: Renderer -> Renderer -> Bool
$c>= :: Renderer -> Renderer -> Bool
> :: Renderer -> Renderer -> Bool
$c> :: Renderer -> Renderer -> Bool
<= :: Renderer -> Renderer -> Bool
$c<= :: Renderer -> Renderer -> Bool
< :: Renderer -> Renderer -> Bool
$c< :: Renderer -> Renderer -> Bool
compare :: Renderer -> Renderer -> Ordering
$ccompare :: Renderer -> Renderer -> Ordering
Ord, Int -> Renderer -> ShowS
[Renderer] -> ShowS
Renderer -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [Renderer] -> ShowS
$cshowList :: [Renderer] -> ShowS
show :: Renderer -> String
$cshow :: Renderer -> String
showsPrec :: Int -> Renderer -> ShowS
$cshowsPrec :: Int -> Renderer -> ShowS
Show, Typeable)