module Graphics.XHB.Gen.RandR.Types
       (deserializeError, deserializeEvent, MODE, CRTC, OUTPUT,
        Rotation(..), ScreenSize(..), RefreshRates(..), QueryVersion(..),
        QueryVersionReply(..), SetConfig(..), SetScreenConfig(..),
        SetScreenConfigReply(..), NotifyMask(..), SelectInput(..),
        GetScreenInfo(..), GetScreenInfoReply(..), GetScreenSizeRange(..),
        GetScreenSizeRangeReply(..), SetScreenSize(..), ModeFlag(..),
        ModeInfo(..), GetScreenResources(..), GetScreenResourcesReply(..),
        Connection(..), GetOutputInfo(..), GetOutputInfoReply(..),
        ListOutputProperties(..), ListOutputPropertiesReply(..),
        QueryOutputProperty(..), QueryOutputPropertyReply(..),
        ConfigureOutputProperty(..), ChangeOutputProperty(..),
        DeleteOutputProperty(..), GetOutputProperty(..),
        GetOutputPropertyReply(..), CreateMode(..), CreateModeReply(..),
        DestroyMode(..), AddOutputMode(..), DeleteOutputMode(..),
        GetCrtcInfo(..), GetCrtcInfoReply(..), SetCrtcConfig(..),
        SetCrtcConfigReply(..), GetCrtcGammaSize(..),
        GetCrtcGammaSizeReply(..), GetCrtcGamma(..), GetCrtcGammaReply(..),
        SetCrtcGamma(..), GetScreenResourcesCurrent(..),
        GetScreenResourcesCurrentReply(..), SetCrtcTransform(..),
        GetCrtcTransform(..), GetCrtcTransformReply(..), GetPanning(..),
        GetPanningReply(..), SetPanning(..), SetPanningReply(..),
        SetOutputPrimary(..), GetOutputPrimary(..),
        GetOutputPrimaryReply(..), ScreenChangeNotifyEvent(..), Notify(..),
        CrtcChange(..), OutputChange(..), OutputProperty(..),
        NotifyEvent(..), NotifyData(..))
       where
import Data.Word
import Data.Int
import Foreign.C.Types
import Data.Bits
import Data.Binary.Put
import Data.Binary.Get
import Data.Typeable
import Control.Monad
import Control.Exception
import Data.List
import Graphics.XHB.Shared hiding (Event, Error)
import qualified Graphics.XHB.Shared
import Graphics.XHB.Gen.Xproto.Types
       hiding (deserializeError, deserializeEvent)
import qualified Graphics.XHB.Gen.Xproto.Types
import Graphics.XHB.Gen.Render.Types
       hiding (QueryVersion(..), QueryVersionReply(..), deserializeError,
               deserializeEvent)
import qualified Graphics.XHB.Gen.Render.Types
 
deserializeError :: Word8 -> Maybe (Get SomeError)
deserializeError _ = Nothing
 
deserializeEvent :: Word8 -> Maybe (Get SomeEvent)
deserializeEvent 0
  = return
      (liftM toEvent (deserialize :: Get ScreenChangeNotifyEvent))
deserializeEvent 1
  = return (liftM toEvent (deserialize :: Get NotifyEvent))
deserializeEvent _ = Nothing
 
newtype MODE = MkMODE Xid
               deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype CRTC = MkCRTC Xid
               deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype OUTPUT = MkOUTPUT Xid
                 deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
data Rotation = RotationRotate_0
              | RotationRotate_90
              | RotationRotate_180
              | RotationRotate_270
              | RotationReflect_X
              | RotationReflect_Y
              deriving (Show, Eq, Ord, Enum)
 
instance BitEnum Rotation where
        toBit RotationRotate_0{} = 0
        toBit RotationRotate_90{} = 1
        toBit RotationRotate_180{} = 2
        toBit RotationRotate_270{} = 3
        toBit RotationReflect_X{} = 4
        toBit RotationReflect_Y{} = 5
        fromBit 0 = RotationRotate_0
        fromBit 1 = RotationRotate_90
        fromBit 2 = RotationRotate_180
        fromBit 3 = RotationRotate_270
        fromBit 4 = RotationReflect_X
        fromBit 5 = RotationReflect_Y
 
data ScreenSize = MkScreenSize{width_ScreenSize :: Word16,
                               height_ScreenSize :: Word16, mwidth_ScreenSize :: Word16,
                               mheight_ScreenSize :: Word16}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ScreenSize where
        serialize x
          = do serialize (width_ScreenSize x)
               serialize (height_ScreenSize x)
               serialize (mwidth_ScreenSize x)
               serialize (mheight_ScreenSize x)
        size x
          = size (width_ScreenSize x) + size (height_ScreenSize x) +
              size (mwidth_ScreenSize x)
              + size (mheight_ScreenSize x)
 
instance Deserialize ScreenSize where
        deserialize
          = do width <- deserialize
               height <- deserialize
               mwidth <- deserialize
               mheight <- deserialize
               return (MkScreenSize width height mwidth mheight)
 
data RefreshRates = MkRefreshRates{nRates_RefreshRates :: Word16,
                                   rates_RefreshRates :: [Word16]}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize RefreshRates where
        serialize x
          = do serialize (nRates_RefreshRates x)
               serializeList (rates_RefreshRates x)
        size x
          = size (nRates_RefreshRates x) +
              sum (map size (rates_RefreshRates x))
 
instance Deserialize RefreshRates where
        deserialize
          = do nRates <- deserialize
               rates <- deserializeList (fromIntegral nRates)
               return (MkRefreshRates nRates rates)
 
data QueryVersion = MkQueryVersion{major_version_QueryVersion ::
                                   Word32,
                                   minor_version_QueryVersion :: Word32}
                  deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest QueryVersion where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 0
               let size__
                     = 4 + size (major_version_QueryVersion x) +
                         size (minor_version_QueryVersion x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (major_version_QueryVersion x)
               serialize (minor_version_QueryVersion x)
               putSkip (requiredPadding size__)
 
data QueryVersionReply = MkQueryVersionReply{major_version_QueryVersionReply
                                             :: Word32,
                                             minor_version_QueryVersionReply :: Word32}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryVersionReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               major_version <- deserialize
               minor_version <- deserialize
               skip 16
               let _ = isCard32 length
               return (MkQueryVersionReply major_version minor_version)
 
data SetConfig = SetConfigSuccess
               | SetConfigInvalidConfigTime
               | SetConfigInvalidTime
               | SetConfigFailed
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum SetConfig where
        toValue SetConfigSuccess{} = 0
        toValue SetConfigInvalidConfigTime{} = 1
        toValue SetConfigInvalidTime{} = 2
        toValue SetConfigFailed{} = 3
        fromValue 0 = SetConfigSuccess
        fromValue 1 = SetConfigInvalidConfigTime
        fromValue 2 = SetConfigInvalidTime
        fromValue 3 = SetConfigFailed
 
data SetScreenConfig = MkSetScreenConfig{window_SetScreenConfig ::
                                         WINDOW,
                                         timestamp_SetScreenConfig :: TIMESTAMP,
                                         config_timestamp_SetScreenConfig :: TIMESTAMP,
                                         sizeID_SetScreenConfig :: Word16,
                                         rotation_SetScreenConfig :: [Rotation],
                                         rate_SetScreenConfig :: Word16}
                     deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest SetScreenConfig where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 2
               let size__
                     = 4 + size (window_SetScreenConfig x) +
                         size (timestamp_SetScreenConfig x)
                         + size (config_timestamp_SetScreenConfig x)
                         + size (sizeID_SetScreenConfig x)
                         + size (undefined :: Word16)
                         + size (rate_SetScreenConfig x)
                         + 2
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_SetScreenConfig x)
               serialize (timestamp_SetScreenConfig x)
               serialize (config_timestamp_SetScreenConfig x)
               serialize (sizeID_SetScreenConfig x)
               serialize (toMask (rotation_SetScreenConfig x) :: Word16)
               serialize (rate_SetScreenConfig x)
               putSkip 2
               putSkip (requiredPadding size__)
 
data SetScreenConfigReply = MkSetScreenConfigReply{status_SetScreenConfigReply
                                                   :: SetConfig,
                                                   new_timestamp_SetScreenConfigReply :: TIMESTAMP,
                                                   config_timestamp_SetScreenConfigReply ::
                                                   TIMESTAMP,
                                                   root_SetScreenConfigReply :: WINDOW,
                                                   subpixel_order_SetScreenConfigReply :: SubPixel}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize SetScreenConfigReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               new_timestamp <- deserialize
               config_timestamp <- deserialize
               root <- deserialize
               subpixel_order <- liftM fromValue (deserialize :: Get Word16)
               skip 10
               let _ = isCard32 length
               return
                 (MkSetScreenConfigReply status new_timestamp config_timestamp root
                    subpixel_order)
 
data NotifyMask = NotifyMaskScreenChange
                | NotifyMaskCrtcChange
                | NotifyMaskOutputChange
                | NotifyMaskOutputProperty
                deriving (Show, Eq, Ord, Enum)
 
instance BitEnum NotifyMask where
        toBit NotifyMaskScreenChange{} = 0
        toBit NotifyMaskCrtcChange{} = 1
        toBit NotifyMaskOutputChange{} = 2
        toBit NotifyMaskOutputProperty{} = 3
        fromBit 0 = NotifyMaskScreenChange
        fromBit 1 = NotifyMaskCrtcChange
        fromBit 2 = NotifyMaskOutputChange
        fromBit 3 = NotifyMaskOutputProperty
 
data SelectInput = MkSelectInput{window_SelectInput :: WINDOW,
                                 enable_SelectInput :: [NotifyMask]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest SelectInput where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 4
               let size__
                     = 4 + size (window_SelectInput x) + size (undefined :: Word16) + 2
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_SelectInput x)
               serialize (toMask (enable_SelectInput x) :: Word16)
               putSkip 2
               putSkip (requiredPadding size__)
 
data GetScreenInfo = MkGetScreenInfo{window_GetScreenInfo ::
                                     WINDOW}
                   deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetScreenInfo where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 5
               let size__ = 4 + size (window_GetScreenInfo x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_GetScreenInfo x)
               putSkip (requiredPadding size__)
 
data GetScreenInfoReply = MkGetScreenInfoReply{rotations_GetScreenInfoReply
                                               :: [Rotation],
                                               root_GetScreenInfoReply :: WINDOW,
                                               timestamp_GetScreenInfoReply :: TIMESTAMP,
                                               config_timestamp_GetScreenInfoReply :: TIMESTAMP,
                                               nSizes_GetScreenInfoReply :: Word16,
                                               sizeID_GetScreenInfoReply :: Word16,
                                               rotation_GetScreenInfoReply :: [Rotation],
                                               rate_GetScreenInfoReply :: Word16,
                                               nInfo_GetScreenInfoReply :: Word16,
                                               sizes_GetScreenInfoReply :: [ScreenSize],
                                               rates_GetScreenInfoReply :: [RefreshRates]}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetScreenInfoReply where
        deserialize
          = do skip 1
               rotations <- liftM fromMask (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               root <- deserialize
               timestamp <- deserialize
               config_timestamp <- deserialize
               nSizes <- deserialize
               sizeID <- deserialize
               rotation <- liftM fromMask (deserialize :: Get Word16)
               rate <- deserialize
               nInfo <- deserialize
               skip 2
               sizes <- deserializeList (fromIntegral nSizes)
               rates <- deserializeList
                          (fromIntegral (fromIntegral (nInfo - nSizes)))
               let _ = isCard32 length
               return
                 (MkGetScreenInfoReply rotations root timestamp config_timestamp
                    nSizes
                    sizeID
                    rotation
                    rate
                    nInfo
                    sizes
                    rates)
 
data GetScreenSizeRange = MkGetScreenSizeRange{window_GetScreenSizeRange
                                               :: WINDOW}
                        deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetScreenSizeRange where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 6
               let size__ = 4 + size (window_GetScreenSizeRange x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_GetScreenSizeRange x)
               putSkip (requiredPadding size__)
 
data GetScreenSizeRangeReply = MkGetScreenSizeRangeReply{min_width_GetScreenSizeRangeReply
                                                         :: Word16,
                                                         min_height_GetScreenSizeRangeReply ::
                                                         Word16,
                                                         max_width_GetScreenSizeRangeReply ::
                                                         Word16,
                                                         max_height_GetScreenSizeRangeReply ::
                                                         Word16}
                             deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetScreenSizeRangeReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               min_width <- deserialize
               min_height <- deserialize
               max_width <- deserialize
               max_height <- deserialize
               skip 16
               let _ = isCard32 length
               return
                 (MkGetScreenSizeRangeReply min_width min_height max_width
                    max_height)
 
data SetScreenSize = MkSetScreenSize{window_SetScreenSize ::
                                     WINDOW,
                                     width_SetScreenSize :: Word16, height_SetScreenSize :: Word16,
                                     mm_width_SetScreenSize :: Word32,
                                     mm_height_SetScreenSize :: Word32}
                   deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest SetScreenSize where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 7
               let size__
                     = 4 + size (window_SetScreenSize x) + size (width_SetScreenSize x)
                         + size (height_SetScreenSize x)
                         + size (mm_width_SetScreenSize x)
                         + size (mm_height_SetScreenSize x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_SetScreenSize x)
               serialize (width_SetScreenSize x)
               serialize (height_SetScreenSize x)
               serialize (mm_width_SetScreenSize x)
               serialize (mm_height_SetScreenSize x)
               putSkip (requiredPadding size__)
 
data ModeFlag = ModeFlagHsyncPositive
              | ModeFlagHsyncNegative
              | ModeFlagVsyncPositive
              | ModeFlagVsyncNegative
              | ModeFlagInterlace
              | ModeFlagDoubleScan
              | ModeFlagCsync
              | ModeFlagCsyncPositive
              | ModeFlagCsyncNegative
              | ModeFlagHskewPresent
              | ModeFlagBcast
              | ModeFlagPixelMultiplex
              | ModeFlagDoubleClock
              | ModeFlagHalveClock
              deriving (Show, Eq, Ord, Enum)
 
instance BitEnum ModeFlag where
        toBit ModeFlagHsyncPositive{} = 0
        toBit ModeFlagHsyncNegative{} = 1
        toBit ModeFlagVsyncPositive{} = 2
        toBit ModeFlagVsyncNegative{} = 3
        toBit ModeFlagInterlace{} = 4
        toBit ModeFlagDoubleScan{} = 5
        toBit ModeFlagCsync{} = 6
        toBit ModeFlagCsyncPositive{} = 7
        toBit ModeFlagCsyncNegative{} = 8
        toBit ModeFlagHskewPresent{} = 9
        toBit ModeFlagBcast{} = 10
        toBit ModeFlagPixelMultiplex{} = 11
        toBit ModeFlagDoubleClock{} = 12
        toBit ModeFlagHalveClock{} = 13
        fromBit 0 = ModeFlagHsyncPositive
        fromBit 1 = ModeFlagHsyncNegative
        fromBit 2 = ModeFlagVsyncPositive
        fromBit 3 = ModeFlagVsyncNegative
        fromBit 4 = ModeFlagInterlace
        fromBit 5 = ModeFlagDoubleScan
        fromBit 6 = ModeFlagCsync
        fromBit 7 = ModeFlagCsyncPositive
        fromBit 8 = ModeFlagCsyncNegative
        fromBit 9 = ModeFlagHskewPresent
        fromBit 10 = ModeFlagBcast
        fromBit 11 = ModeFlagPixelMultiplex
        fromBit 12 = ModeFlagDoubleClock
        fromBit 13 = ModeFlagHalveClock
 
data ModeInfo = MkModeInfo{id_ModeInfo :: Word32,
                           width_ModeInfo :: Word16, height_ModeInfo :: Word16,
                           dot_clock_ModeInfo :: Word32, hsync_start_ModeInfo :: Word16,
                           hsync_end_ModeInfo :: Word16, htotal_ModeInfo :: Word16,
                           hskew_ModeInfo :: Word16, vsync_start_ModeInfo :: Word16,
                           vsync_end_ModeInfo :: Word16, vtotal_ModeInfo :: Word16,
                           name_len_ModeInfo :: Word16, mode_flags_ModeInfo :: [ModeFlag]}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ModeInfo where
        serialize x
          = do serialize (id_ModeInfo x)
               serialize (width_ModeInfo x)
               serialize (height_ModeInfo x)
               serialize (dot_clock_ModeInfo x)
               serialize (hsync_start_ModeInfo x)
               serialize (hsync_end_ModeInfo x)
               serialize (htotal_ModeInfo x)
               serialize (hskew_ModeInfo x)
               serialize (vsync_start_ModeInfo x)
               serialize (vsync_end_ModeInfo x)
               serialize (vtotal_ModeInfo x)
               serialize (name_len_ModeInfo x)
               serialize (toMask (mode_flags_ModeInfo x) :: Word32)
        size x
          = size (id_ModeInfo x) + size (width_ModeInfo x) +
              size (height_ModeInfo x)
              + size (dot_clock_ModeInfo x)
              + size (hsync_start_ModeInfo x)
              + size (hsync_end_ModeInfo x)
              + size (htotal_ModeInfo x)
              + size (hskew_ModeInfo x)
              + size (vsync_start_ModeInfo x)
              + size (vsync_end_ModeInfo x)
              + size (vtotal_ModeInfo x)
              + size (name_len_ModeInfo x)
              + size (undefined :: Word32)
 
instance Deserialize ModeInfo where
        deserialize
          = do id <- deserialize
               width <- deserialize
               height <- deserialize
               dot_clock <- deserialize
               hsync_start <- deserialize
               hsync_end <- deserialize
               htotal <- deserialize
               hskew <- deserialize
               vsync_start <- deserialize
               vsync_end <- deserialize
               vtotal <- deserialize
               name_len <- deserialize
               mode_flags <- liftM fromMask (deserialize :: Get Word32)
               return
                 (MkModeInfo id width height dot_clock hsync_start hsync_end htotal
                    hskew
                    vsync_start
                    vsync_end
                    vtotal
                    name_len
                    mode_flags)
 
data GetScreenResources = MkGetScreenResources{window_GetScreenResources
                                               :: WINDOW}
                        deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetScreenResources where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 8
               let size__ = 4 + size (window_GetScreenResources x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_GetScreenResources x)
               putSkip (requiredPadding size__)
 
data GetScreenResourcesReply = MkGetScreenResourcesReply{timestamp_GetScreenResourcesReply
                                                         :: TIMESTAMP,
                                                         config_timestamp_GetScreenResourcesReply ::
                                                         TIMESTAMP,
                                                         num_crtcs_GetScreenResourcesReply ::
                                                         Word16,
                                                         num_outputs_GetScreenResourcesReply ::
                                                         Word16,
                                                         num_modes_GetScreenResourcesReply ::
                                                         Word16,
                                                         names_len_GetScreenResourcesReply ::
                                                         Word16,
                                                         crtcs_GetScreenResourcesReply :: [CRTC],
                                                         outputs_GetScreenResourcesReply ::
                                                         [OUTPUT],
                                                         modes_GetScreenResourcesReply ::
                                                         [ModeInfo],
                                                         names_GetScreenResourcesReply :: [Word8]}
                             deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetScreenResourcesReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               timestamp <- deserialize
               config_timestamp <- deserialize
               num_crtcs <- deserialize
               num_outputs <- deserialize
               num_modes <- deserialize
               names_len <- deserialize
               skip 8
               crtcs <- deserializeList (fromIntegral num_crtcs)
               outputs <- deserializeList (fromIntegral num_outputs)
               modes <- deserializeList (fromIntegral num_modes)
               names <- deserializeList (fromIntegral names_len)
               let _ = isCard32 length
               return
                 (MkGetScreenResourcesReply timestamp config_timestamp num_crtcs
                    num_outputs
                    num_modes
                    names_len
                    crtcs
                    outputs
                    modes
                    names)
 
data Connection = ConnectionConnected
                | ConnectionDisconnected
                | ConnectionUnknown
                deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Connection where
        toValue ConnectionConnected{} = 0
        toValue ConnectionDisconnected{} = 1
        toValue ConnectionUnknown{} = 2
        fromValue 0 = ConnectionConnected
        fromValue 1 = ConnectionDisconnected
        fromValue 2 = ConnectionUnknown
 
data GetOutputInfo = MkGetOutputInfo{output_GetOutputInfo ::
                                     OUTPUT,
                                     config_timestamp_GetOutputInfo :: TIMESTAMP}
                   deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetOutputInfo where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 9
               let size__
                     = 4 + size (output_GetOutputInfo x) +
                         size (config_timestamp_GetOutputInfo x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_GetOutputInfo x)
               serialize (config_timestamp_GetOutputInfo x)
               putSkip (requiredPadding size__)
 
data GetOutputInfoReply = MkGetOutputInfoReply{status_GetOutputInfoReply
                                               :: SetConfig,
                                               timestamp_GetOutputInfoReply :: TIMESTAMP,
                                               crtc_GetOutputInfoReply :: CRTC,
                                               mm_width_GetOutputInfoReply :: Word32,
                                               mm_height_GetOutputInfoReply :: Word32,
                                               connection_GetOutputInfoReply :: Connection,
                                               subpixel_order_GetOutputInfoReply :: SubPixel,
                                               num_crtcs_GetOutputInfoReply :: Word16,
                                               num_modes_GetOutputInfoReply :: Word16,
                                               num_preferred_GetOutputInfoReply :: Word16,
                                               num_clones_GetOutputInfoReply :: Word16,
                                               name_len_GetOutputInfoReply :: Word16,
                                               crtcs_GetOutputInfoReply :: [CRTC],
                                               modes_GetOutputInfoReply :: [MODE],
                                               clones_GetOutputInfoReply :: [OUTPUT],
                                               name_GetOutputInfoReply :: [Word8]}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetOutputInfoReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               timestamp <- deserialize
               crtc <- deserialize
               mm_width <- deserialize
               mm_height <- deserialize
               connection <- liftM fromValue (deserialize :: Get Word8)
               subpixel_order <- liftM fromValue (deserialize :: Get Word8)
               num_crtcs <- deserialize
               num_modes <- deserialize
               num_preferred <- deserialize
               num_clones <- deserialize
               name_len <- deserialize
               crtcs <- deserializeList (fromIntegral num_crtcs)
               modes <- deserializeList (fromIntegral num_modes)
               clones <- deserializeList (fromIntegral num_clones)
               name <- deserializeList (fromIntegral name_len)
               let _ = isCard32 length
               return
                 (MkGetOutputInfoReply status timestamp crtc mm_width mm_height
                    connection
                    subpixel_order
                    num_crtcs
                    num_modes
                    num_preferred
                    num_clones
                    name_len
                    crtcs
                    modes
                    clones
                    name)
 
data ListOutputProperties = MkListOutputProperties{output_ListOutputProperties
                                                   :: OUTPUT}
                          deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest ListOutputProperties where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 10
               let size__ = 4 + size (output_ListOutputProperties x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_ListOutputProperties x)
               putSkip (requiredPadding size__)
 
data ListOutputPropertiesReply = MkListOutputPropertiesReply{num_atoms_ListOutputPropertiesReply
                                                             :: Word16,
                                                             atoms_ListOutputPropertiesReply ::
                                                             [ATOM]}
                               deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize ListOutputPropertiesReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               num_atoms <- deserialize
               skip 22
               atoms <- deserializeList (fromIntegral num_atoms)
               let _ = isCard32 length
               return (MkListOutputPropertiesReply num_atoms atoms)
 
data QueryOutputProperty = MkQueryOutputProperty{output_QueryOutputProperty
                                                 :: OUTPUT,
                                                 property_QueryOutputProperty :: ATOM}
                         deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest QueryOutputProperty where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 11
               let size__
                     = 4 + size (output_QueryOutputProperty x) +
                         size (property_QueryOutputProperty x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_QueryOutputProperty x)
               serialize (property_QueryOutputProperty x)
               putSkip (requiredPadding size__)
 
data QueryOutputPropertyReply = MkQueryOutputPropertyReply{pending_QueryOutputPropertyReply
                                                           :: Bool,
                                                           range_QueryOutputPropertyReply :: Bool,
                                                           immutable_QueryOutputPropertyReply ::
                                                           Bool,
                                                           validValues_QueryOutputPropertyReply ::
                                                           [Int32]}
                              deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryOutputPropertyReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               pending <- deserialize
               range <- deserialize
               immutable <- deserialize
               skip 21
               validValues <- deserializeList (fromIntegral length)
               let _ = isCard32 length
               return
                 (MkQueryOutputPropertyReply pending range immutable validValues)
 
data ConfigureOutputProperty = MkConfigureOutputProperty{output_ConfigureOutputProperty
                                                         :: OUTPUT,
                                                         property_ConfigureOutputProperty :: ATOM,
                                                         pending_ConfigureOutputProperty :: Bool,
                                                         range_ConfigureOutputProperty :: Bool,
                                                         values_ConfigureOutputProperty :: [Int32]}
                             deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest ConfigureOutputProperty where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 12
               let size__
                     = 4 + size (output_ConfigureOutputProperty x) +
                         size (property_ConfigureOutputProperty x)
                         + size (pending_ConfigureOutputProperty x)
                         + size (range_ConfigureOutputProperty x)
                         + 2
                         + sum (map size (values_ConfigureOutputProperty x))
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_ConfigureOutputProperty x)
               serialize (property_ConfigureOutputProperty x)
               serialize (pending_ConfigureOutputProperty x)
               serialize (range_ConfigureOutputProperty x)
               putSkip 2
               serializeList (values_ConfigureOutputProperty x)
               putSkip (requiredPadding size__)
 
data ChangeOutputProperty = MkChangeOutputProperty{output_ChangeOutputProperty
                                                   :: OUTPUT,
                                                   property_ChangeOutputProperty :: ATOM,
                                                   type_ChangeOutputProperty :: ATOM,
                                                   format_ChangeOutputProperty :: Word8,
                                                   mode_ChangeOutputProperty :: PropMode,
                                                   num_units_ChangeOutputProperty :: Word32,
                                                   data_ChangeOutputProperty :: [Word8]}
                          deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest ChangeOutputProperty where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 13
               let size__
                     = 4 + size (output_ChangeOutputProperty x) +
                         size (property_ChangeOutputProperty x)
                         + size (type_ChangeOutputProperty x)
                         + size (format_ChangeOutputProperty x)
                         + size (undefined :: Word8)
                         + 2
                         + size (num_units_ChangeOutputProperty x)
                         + sum (map size (data_ChangeOutputProperty x))
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_ChangeOutputProperty x)
               serialize (property_ChangeOutputProperty x)
               serialize (type_ChangeOutputProperty x)
               serialize (format_ChangeOutputProperty x)
               serialize (toValue (mode_ChangeOutputProperty x) :: Word8)
               putSkip 2
               serialize (num_units_ChangeOutputProperty x)
               serializeList (data_ChangeOutputProperty x)
               putSkip (requiredPadding size__)
 
data DeleteOutputProperty = MkDeleteOutputProperty{output_DeleteOutputProperty
                                                   :: OUTPUT,
                                                   property_DeleteOutputProperty :: ATOM}
                          deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest DeleteOutputProperty where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 14
               let size__
                     = 4 + size (output_DeleteOutputProperty x) +
                         size (property_DeleteOutputProperty x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_DeleteOutputProperty x)
               serialize (property_DeleteOutputProperty x)
               putSkip (requiredPadding size__)
 
data GetOutputProperty = MkGetOutputProperty{output_GetOutputProperty
                                             :: OUTPUT,
                                             property_GetOutputProperty :: ATOM,
                                             type_GetOutputProperty :: ATOM,
                                             long_offset_GetOutputProperty :: Word32,
                                             long_length_GetOutputProperty :: Word32,
                                             delete_GetOutputProperty :: Bool,
                                             pending_GetOutputProperty :: Bool}
                       deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetOutputProperty where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 15
               let size__
                     = 4 + size (output_GetOutputProperty x) +
                         size (property_GetOutputProperty x)
                         + size (type_GetOutputProperty x)
                         + size (long_offset_GetOutputProperty x)
                         + size (long_length_GetOutputProperty x)
                         + size (delete_GetOutputProperty x)
                         + size (pending_GetOutputProperty x)
                         + 2
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_GetOutputProperty x)
               serialize (property_GetOutputProperty x)
               serialize (type_GetOutputProperty x)
               serialize (long_offset_GetOutputProperty x)
               serialize (long_length_GetOutputProperty x)
               serialize (delete_GetOutputProperty x)
               serialize (pending_GetOutputProperty x)
               putSkip 2
               putSkip (requiredPadding size__)
 
data GetOutputPropertyReply = MkGetOutputPropertyReply{format_GetOutputPropertyReply
                                                       :: Word8,
                                                       type_GetOutputPropertyReply :: ATOM,
                                                       bytes_after_GetOutputPropertyReply :: Word32,
                                                       num_items_GetOutputPropertyReply :: Word32,
                                                       data_GetOutputPropertyReply :: [Word8]}
                            deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetOutputPropertyReply where
        deserialize
          = do skip 1
               format <- deserialize
               skip 2
               length <- deserialize
               type_ <- deserialize
               bytes_after <- deserialize
               num_items <- deserialize
               skip 12
               data_ <- deserializeList
                          (fromIntegral
                             (fromIntegral (num_items * (fromIntegral (format `div` 8)))))
               let _ = isCard32 length
               return
                 (MkGetOutputPropertyReply format type_ bytes_after num_items data_)
 
data CreateMode = MkCreateMode{window_CreateMode :: WINDOW,
                               mode_info_CreateMode :: ModeInfo, name_CreateMode :: [CChar]}
                deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest CreateMode where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 16
               let size__
                     = 4 + size (window_CreateMode x) + size (mode_info_CreateMode x) +
                         sum (map size (name_CreateMode x))
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_CreateMode x)
               serialize (mode_info_CreateMode x)
               serializeList (name_CreateMode x)
               putSkip (requiredPadding size__)
 
data CreateModeReply = MkCreateModeReply{mode_CreateModeReply ::
                                         MODE}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize CreateModeReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               mode <- deserialize
               skip 20
               let _ = isCard32 length
               return (MkCreateModeReply mode)
 
data DestroyMode = MkDestroyMode{mode_DestroyMode :: MODE}
                 deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest DestroyMode where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 17
               let size__ = 4 + size (mode_DestroyMode x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (mode_DestroyMode x)
               putSkip (requiredPadding size__)
 
data AddOutputMode = MkAddOutputMode{output_AddOutputMode ::
                                     OUTPUT,
                                     mode_AddOutputMode :: MODE}
                   deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest AddOutputMode where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 18
               let size__
                     = 4 + size (output_AddOutputMode x) + size (mode_AddOutputMode x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_AddOutputMode x)
               serialize (mode_AddOutputMode x)
               putSkip (requiredPadding size__)
 
data DeleteOutputMode = MkDeleteOutputMode{output_DeleteOutputMode
                                           :: OUTPUT,
                                           mode_DeleteOutputMode :: MODE}
                      deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest DeleteOutputMode where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 19
               let size__
                     = 4 + size (output_DeleteOutputMode x) +
                         size (mode_DeleteOutputMode x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (output_DeleteOutputMode x)
               serialize (mode_DeleteOutputMode x)
               putSkip (requiredPadding size__)
 
data GetCrtcInfo = MkGetCrtcInfo{crtc_GetCrtcInfo :: CRTC,
                                 config_timestamp_GetCrtcInfo :: TIMESTAMP}
                 deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetCrtcInfo where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 20
               let size__
                     = 4 + size (crtc_GetCrtcInfo x) +
                         size (config_timestamp_GetCrtcInfo x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_GetCrtcInfo x)
               serialize (config_timestamp_GetCrtcInfo x)
               putSkip (requiredPadding size__)
 
data GetCrtcInfoReply = MkGetCrtcInfoReply{status_GetCrtcInfoReply
                                           :: SetConfig,
                                           timestamp_GetCrtcInfoReply :: TIMESTAMP,
                                           x_GetCrtcInfoReply :: Int16, y_GetCrtcInfoReply :: Int16,
                                           width_GetCrtcInfoReply :: Word16,
                                           height_GetCrtcInfoReply :: Word16,
                                           mode_GetCrtcInfoReply :: MODE,
                                           rotation_GetCrtcInfoReply :: [Rotation],
                                           rotations_GetCrtcInfoReply :: [Rotation],
                                           num_outputs_GetCrtcInfoReply :: Word16,
                                           num_possible_outputs_GetCrtcInfoReply :: Word16,
                                           outputs_GetCrtcInfoReply :: [OUTPUT],
                                           possible_GetCrtcInfoReply :: [OUTPUT]}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetCrtcInfoReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               timestamp <- deserialize
               x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               mode <- deserialize
               rotation <- liftM fromMask (deserialize :: Get Word16)
               rotations <- liftM fromMask (deserialize :: Get Word16)
               num_outputs <- deserialize
               num_possible_outputs <- deserialize
               outputs <- deserializeList (fromIntegral num_outputs)
               possible <- deserializeList (fromIntegral num_possible_outputs)
               let _ = isCard32 length
               return
                 (MkGetCrtcInfoReply status timestamp x y width height mode rotation
                    rotations
                    num_outputs
                    num_possible_outputs
                    outputs
                    possible)
 
data SetCrtcConfig = MkSetCrtcConfig{crtc_SetCrtcConfig :: CRTC,
                                     timestamp_SetCrtcConfig :: TIMESTAMP,
                                     config_timestamp_SetCrtcConfig :: TIMESTAMP,
                                     x_SetCrtcConfig :: Int16, y_SetCrtcConfig :: Int16,
                                     mode_SetCrtcConfig :: MODE,
                                     rotation_SetCrtcConfig :: [Rotation],
                                     outputs_SetCrtcConfig :: [OUTPUT]}
                   deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest SetCrtcConfig where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 21
               let size__
                     = 4 + size (crtc_SetCrtcConfig x) +
                         size (timestamp_SetCrtcConfig x)
                         + size (config_timestamp_SetCrtcConfig x)
                         + size (x_SetCrtcConfig x)
                         + size (y_SetCrtcConfig x)
                         + size (mode_SetCrtcConfig x)
                         + size (undefined :: Word16)
                         + 2
                         + sum (map size (outputs_SetCrtcConfig x))
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_SetCrtcConfig x)
               serialize (timestamp_SetCrtcConfig x)
               serialize (config_timestamp_SetCrtcConfig x)
               serialize (x_SetCrtcConfig x)
               serialize (y_SetCrtcConfig x)
               serialize (mode_SetCrtcConfig x)
               serialize (toMask (rotation_SetCrtcConfig x) :: Word16)
               putSkip 2
               serializeList (outputs_SetCrtcConfig x)
               putSkip (requiredPadding size__)
 
data SetCrtcConfigReply = MkSetCrtcConfigReply{status_SetCrtcConfigReply
                                               :: SetConfig,
                                               timestamp_SetCrtcConfigReply :: TIMESTAMP}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize SetCrtcConfigReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               timestamp <- deserialize
               skip 20
               let _ = isCard32 length
               return (MkSetCrtcConfigReply status timestamp)
 
data GetCrtcGammaSize = MkGetCrtcGammaSize{crtc_GetCrtcGammaSize ::
                                           CRTC}
                      deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetCrtcGammaSize where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 22
               let size__ = 4 + size (crtc_GetCrtcGammaSize x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_GetCrtcGammaSize x)
               putSkip (requiredPadding size__)
 
data GetCrtcGammaSizeReply = MkGetCrtcGammaSizeReply{size_GetCrtcGammaSizeReply
                                                     :: Word16}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetCrtcGammaSizeReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               size <- deserialize
               skip 22
               let _ = isCard32 length
               return (MkGetCrtcGammaSizeReply size)
 
data GetCrtcGamma = MkGetCrtcGamma{crtc_GetCrtcGamma :: CRTC}
                  deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetCrtcGamma where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 23
               let size__ = 4 + size (crtc_GetCrtcGamma x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_GetCrtcGamma x)
               putSkip (requiredPadding size__)
 
data GetCrtcGammaReply = MkGetCrtcGammaReply{size_GetCrtcGammaReply
                                             :: Word16,
                                             red_GetCrtcGammaReply :: [Word16],
                                             green_GetCrtcGammaReply :: [Word16],
                                             blue_GetCrtcGammaReply :: [Word16]}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetCrtcGammaReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               size <- deserialize
               skip 22
               red <- deserializeList (fromIntegral size)
               green <- deserializeList (fromIntegral size)
               blue <- deserializeList (fromIntegral size)
               let _ = isCard32 length
               return (MkGetCrtcGammaReply size red green blue)
 
data SetCrtcGamma = MkSetCrtcGamma{crtc_SetCrtcGamma :: CRTC,
                                   size_SetCrtcGamma :: Word16, red_SetCrtcGamma :: [Word16],
                                   green_SetCrtcGamma :: [Word16], blue_SetCrtcGamma :: [Word16]}
                  deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest SetCrtcGamma where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 24
               let size__
                     = 4 + size (crtc_SetCrtcGamma x) + size (size_SetCrtcGamma x) + 2 +
                         sum (map size (red_SetCrtcGamma x))
                         + sum (map size (green_SetCrtcGamma x))
                         + sum (map size (blue_SetCrtcGamma x))
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_SetCrtcGamma x)
               serialize (size_SetCrtcGamma x)
               putSkip 2
               serializeList (red_SetCrtcGamma x)
               serializeList (green_SetCrtcGamma x)
               serializeList (blue_SetCrtcGamma x)
               putSkip (requiredPadding size__)
 
data GetScreenResourcesCurrent = MkGetScreenResourcesCurrent{window_GetScreenResourcesCurrent
                                                             :: WINDOW}
                               deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetScreenResourcesCurrent where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 25
               let size__ = 4 + size (window_GetScreenResourcesCurrent x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_GetScreenResourcesCurrent x)
               putSkip (requiredPadding size__)
 
data GetScreenResourcesCurrentReply = MkGetScreenResourcesCurrentReply{timestamp_GetScreenResourcesCurrentReply
                                                                       :: TIMESTAMP,
                                                                       config_timestamp_GetScreenResourcesCurrentReply
                                                                       :: TIMESTAMP,
                                                                       num_crtcs_GetScreenResourcesCurrentReply
                                                                       :: Word16,
                                                                       num_outputs_GetScreenResourcesCurrentReply
                                                                       :: Word16,
                                                                       num_modes_GetScreenResourcesCurrentReply
                                                                       :: Word16,
                                                                       names_len_GetScreenResourcesCurrentReply
                                                                       :: Word16,
                                                                       crtcs_GetScreenResourcesCurrentReply
                                                                       :: [CRTC],
                                                                       outputs_GetScreenResourcesCurrentReply
                                                                       :: [OUTPUT],
                                                                       modes_GetScreenResourcesCurrentReply
                                                                       :: [ModeInfo],
                                                                       names_GetScreenResourcesCurrentReply
                                                                       :: [Word8]}
                                    deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetScreenResourcesCurrentReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               timestamp <- deserialize
               config_timestamp <- deserialize
               num_crtcs <- deserialize
               num_outputs <- deserialize
               num_modes <- deserialize
               names_len <- deserialize
               skip 8
               crtcs <- deserializeList (fromIntegral num_crtcs)
               outputs <- deserializeList (fromIntegral num_outputs)
               modes <- deserializeList (fromIntegral num_modes)
               names <- deserializeList (fromIntegral names_len)
               let _ = isCard32 length
               return
                 (MkGetScreenResourcesCurrentReply timestamp config_timestamp
                    num_crtcs
                    num_outputs
                    num_modes
                    names_len
                    crtcs
                    outputs
                    modes
                    names)
 
data SetCrtcTransform = MkSetCrtcTransform{crtc_SetCrtcTransform ::
                                           CRTC,
                                           transform_SetCrtcTransform :: TRANSFORM,
                                           filter_len_SetCrtcTransform :: Word16,
                                           filter_name_SetCrtcTransform :: [CChar],
                                           filter_params_SetCrtcTransform :: [FIXED]}
                      deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest SetCrtcTransform where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 26
               let size__
                     = 4 + size (crtc_SetCrtcTransform x) +
                         size (transform_SetCrtcTransform x)
                         + size (filter_len_SetCrtcTransform x)
                         + 2
                         + sum (map size (filter_name_SetCrtcTransform x))
                         + sum (map size (filter_params_SetCrtcTransform x))
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_SetCrtcTransform x)
               serialize (transform_SetCrtcTransform x)
               serialize (filter_len_SetCrtcTransform x)
               putSkip 2
               serializeList (filter_name_SetCrtcTransform x)
               serializeList (filter_params_SetCrtcTransform x)
               putSkip (requiredPadding size__)
 
data GetCrtcTransform = MkGetCrtcTransform{crtc_GetCrtcTransform ::
                                           CRTC}
                      deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetCrtcTransform where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 27
               let size__ = 4 + size (crtc_GetCrtcTransform x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_GetCrtcTransform x)
               putSkip (requiredPadding size__)
 
data GetCrtcTransformReply = MkGetCrtcTransformReply{pending_transform_GetCrtcTransformReply
                                                     :: TRANSFORM,
                                                     has_transforms_GetCrtcTransformReply :: Bool,
                                                     current_transform_GetCrtcTransformReply ::
                                                     TRANSFORM,
                                                     pending_len_GetCrtcTransformReply :: Word16,
                                                     pending_nparams_GetCrtcTransformReply ::
                                                     Word16,
                                                     current_len_GetCrtcTransformReply :: Word16,
                                                     current_nparams_GetCrtcTransformReply ::
                                                     Word16,
                                                     pending_filter_name_GetCrtcTransformReply ::
                                                     [CChar],
                                                     pending_params_GetCrtcTransformReply ::
                                                     [FIXED],
                                                     current_filter_name_GetCrtcTransformReply ::
                                                     [CChar],
                                                     current_params_GetCrtcTransformReply ::
                                                     [FIXED]}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetCrtcTransformReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               pending_transform <- deserialize
               has_transforms <- deserialize
               skip 3
               current_transform <- deserialize
               skip 4
               pending_len <- deserialize
               pending_nparams <- deserialize
               current_len <- deserialize
               current_nparams <- deserialize
               pending_filter_name <- deserializeList (fromIntegral pending_len)
               pending_params <- deserializeList (fromIntegral pending_nparams)
               current_filter_name <- deserializeList (fromIntegral current_len)
               current_params <- deserializeList (fromIntegral current_nparams)
               let _ = isCard32 length
               return
                 (MkGetCrtcTransformReply pending_transform has_transforms
                    current_transform
                    pending_len
                    pending_nparams
                    current_len
                    current_nparams
                    pending_filter_name
                    pending_params
                    current_filter_name
                    current_params)
 
data GetPanning = MkGetPanning{crtc_GetPanning :: CRTC}
                deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetPanning where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 28
               let size__ = 4 + size (crtc_GetPanning x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_GetPanning x)
               putSkip (requiredPadding size__)
 
data GetPanningReply = MkGetPanningReply{status_GetPanningReply ::
                                         SetConfig,
                                         timestamp_GetPanningReply :: TIMESTAMP,
                                         left_GetPanningReply :: Word16,
                                         top_GetPanningReply :: Word16,
                                         width_GetPanningReply :: Word16,
                                         height_GetPanningReply :: Word16,
                                         track_left_GetPanningReply :: Word16,
                                         track_top_GetPanningReply :: Word16,
                                         track_width_GetPanningReply :: Word16,
                                         track_height_GetPanningReply :: Word16,
                                         border_left_GetPanningReply :: Int16,
                                         border_top_GetPanningReply :: Int16,
                                         border_right_GetPanningReply :: Int16,
                                         border_bottom_GetPanningReply :: Int16}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetPanningReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               timestamp <- deserialize
               left <- deserialize
               top <- deserialize
               width <- deserialize
               height <- deserialize
               track_left <- deserialize
               track_top <- deserialize
               track_width <- deserialize
               track_height <- deserialize
               border_left <- deserialize
               border_top <- deserialize
               border_right <- deserialize
               border_bottom <- deserialize
               let _ = isCard32 length
               return
                 (MkGetPanningReply status timestamp left top width height
                    track_left
                    track_top
                    track_width
                    track_height
                    border_left
                    border_top
                    border_right
                    border_bottom)
 
data SetPanning = MkSetPanning{crtc_SetPanning :: CRTC,
                               timestamp_SetPanning :: TIMESTAMP, left_SetPanning :: Word16,
                               top_SetPanning :: Word16, width_SetPanning :: Word16,
                               height_SetPanning :: Word16, track_left_SetPanning :: Word16,
                               track_top_SetPanning :: Word16, track_width_SetPanning :: Word16,
                               track_height_SetPanning :: Word16, border_left_SetPanning :: Int16,
                               border_top_SetPanning :: Int16, border_right_SetPanning :: Int16,
                               border_bottom_SetPanning :: Int16}
                deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest SetPanning where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 29
               let size__
                     = 4 + size (crtc_SetPanning x) + size (timestamp_SetPanning x) +
                         size (left_SetPanning x)
                         + size (top_SetPanning x)
                         + size (width_SetPanning x)
                         + size (height_SetPanning x)
                         + size (track_left_SetPanning x)
                         + size (track_top_SetPanning x)
                         + size (track_width_SetPanning x)
                         + size (track_height_SetPanning x)
                         + size (border_left_SetPanning x)
                         + size (border_top_SetPanning x)
                         + size (border_right_SetPanning x)
                         + size (border_bottom_SetPanning x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (crtc_SetPanning x)
               serialize (timestamp_SetPanning x)
               serialize (left_SetPanning x)
               serialize (top_SetPanning x)
               serialize (width_SetPanning x)
               serialize (height_SetPanning x)
               serialize (track_left_SetPanning x)
               serialize (track_top_SetPanning x)
               serialize (track_width_SetPanning x)
               serialize (track_height_SetPanning x)
               serialize (border_left_SetPanning x)
               serialize (border_top_SetPanning x)
               serialize (border_right_SetPanning x)
               serialize (border_bottom_SetPanning x)
               putSkip (requiredPadding size__)
 
data SetPanningReply = MkSetPanningReply{status_SetPanningReply ::
                                         SetConfig,
                                         timestamp_SetPanningReply :: TIMESTAMP}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize SetPanningReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               timestamp <- deserialize
               let _ = isCard32 length
               return (MkSetPanningReply status timestamp)
 
data SetOutputPrimary = MkSetOutputPrimary{window_SetOutputPrimary
                                           :: WINDOW,
                                           output_SetOutputPrimary :: OUTPUT}
                      deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest SetOutputPrimary where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 30
               let size__
                     = 4 + size (window_SetOutputPrimary x) +
                         size (output_SetOutputPrimary x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_SetOutputPrimary x)
               serialize (output_SetOutputPrimary x)
               putSkip (requiredPadding size__)
 
data GetOutputPrimary = MkGetOutputPrimary{window_GetOutputPrimary
                                           :: WINDOW}
                      deriving (Show, Typeable, Eq, Ord)
 
instance ExtensionRequest GetOutputPrimary where
        extensionId _ = "RANDR"
        serializeRequest x extOpCode
          = do putWord8 extOpCode
               putWord8 31
               let size__ = 4 + size (window_GetOutputPrimary x)
               serialize (convertBytesToRequestSize size__ :: Int16)
               serialize (window_GetOutputPrimary x)
               putSkip (requiredPadding size__)
 
data GetOutputPrimaryReply = MkGetOutputPrimaryReply{output_GetOutputPrimaryReply
                                                     :: OUTPUT}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetOutputPrimaryReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               output <- deserialize
               let _ = isCard32 length
               return (MkGetOutputPrimaryReply output)
 
data ScreenChangeNotifyEvent = MkScreenChangeNotifyEvent{rotation_ScreenChangeNotifyEvent
                                                         :: [Rotation],
                                                         timestamp_ScreenChangeNotifyEvent ::
                                                         TIMESTAMP,
                                                         config_timestamp_ScreenChangeNotifyEvent ::
                                                         TIMESTAMP,
                                                         root_ScreenChangeNotifyEvent :: WINDOW,
                                                         request_window_ScreenChangeNotifyEvent ::
                                                         WINDOW,
                                                         sizeID_ScreenChangeNotifyEvent :: Word16,
                                                         subpixel_order_ScreenChangeNotifyEvent ::
                                                         SubPixel,
                                                         width_ScreenChangeNotifyEvent :: Word16,
                                                         height_ScreenChangeNotifyEvent :: Word16,
                                                         mwidth_ScreenChangeNotifyEvent :: Word16,
                                                         mheight_ScreenChangeNotifyEvent :: Word16}
                             deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ScreenChangeNotifyEvent
 
instance Deserialize ScreenChangeNotifyEvent where
        deserialize
          = do skip 1
               rotation <- liftM fromMask (deserialize :: Get Word8)
               skip 2
               timestamp <- deserialize
               config_timestamp <- deserialize
               root <- deserialize
               request_window <- deserialize
               sizeID <- deserialize
               subpixel_order <- liftM fromValue (deserialize :: Get Word16)
               width <- deserialize
               height <- deserialize
               mwidth <- deserialize
               mheight <- deserialize
               return
                 (MkScreenChangeNotifyEvent rotation timestamp config_timestamp root
                    request_window
                    sizeID
                    subpixel_order
                    width
                    height
                    mwidth
                    mheight)
 
data Notify = NotifyCrtcChange
            | NotifyOutputChange
            | NotifyOutputProperty
            deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Notify where
        toValue NotifyCrtcChange{} = 0
        toValue NotifyOutputChange{} = 1
        toValue NotifyOutputProperty{} = 2
        fromValue 0 = NotifyCrtcChange
        fromValue 1 = NotifyOutputChange
        fromValue 2 = NotifyOutputProperty
 
data CrtcChange = MkCrtcChange{timestamp_CrtcChange :: TIMESTAMP,
                               window_CrtcChange :: WINDOW, crtc_CrtcChange :: CRTC,
                               mode_CrtcChange :: MODE, rotation_CrtcChange :: [Rotation],
                               x_CrtcChange :: Int16, y_CrtcChange :: Int16,
                               width_CrtcChange :: Word16, height_CrtcChange :: Word16}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CrtcChange where
        serialize x
          = do serialize (timestamp_CrtcChange x)
               serialize (window_CrtcChange x)
               serialize (crtc_CrtcChange x)
               serialize (mode_CrtcChange x)
               serialize (toMask (rotation_CrtcChange x) :: Word16)
               putSkip 2
               serialize (x_CrtcChange x)
               serialize (y_CrtcChange x)
               serialize (width_CrtcChange x)
               serialize (height_CrtcChange x)
        size x
          = size (timestamp_CrtcChange x) + size (window_CrtcChange x) +
              size (crtc_CrtcChange x)
              + size (mode_CrtcChange x)
              + size (undefined :: Word16)
              + 2
              + size (x_CrtcChange x)
              + size (y_CrtcChange x)
              + size (width_CrtcChange x)
              + size (height_CrtcChange x)
 
instance Deserialize CrtcChange where
        deserialize
          = do timestamp <- deserialize
               window <- deserialize
               crtc <- deserialize
               mode <- deserialize
               rotation <- liftM fromMask (deserialize :: Get Word16)
               skip 2
               x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               return
                 (MkCrtcChange timestamp window crtc mode rotation x y width height)
 
data OutputChange = MkOutputChange{timestamp_OutputChange ::
                                   TIMESTAMP,
                                   config_timestamp_OutputChange :: TIMESTAMP,
                                   window_OutputChange :: WINDOW, output_OutputChange :: OUTPUT,
                                   crtc_OutputChange :: CRTC, mode_OutputChange :: MODE,
                                   rotation_OutputChange :: [Rotation],
                                   connection_OutputChange :: Connection,
                                   subpixel_order_OutputChange :: SubPixel}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize OutputChange where
        serialize x
          = do serialize (timestamp_OutputChange x)
               serialize (config_timestamp_OutputChange x)
               serialize (window_OutputChange x)
               serialize (output_OutputChange x)
               serialize (crtc_OutputChange x)
               serialize (mode_OutputChange x)
               serialize (toMask (rotation_OutputChange x) :: Word16)
               serialize (toValue (connection_OutputChange x) :: Word8)
               serialize (toValue (subpixel_order_OutputChange x) :: Word8)
        size x
          = size (timestamp_OutputChange x) +
              size (config_timestamp_OutputChange x)
              + size (window_OutputChange x)
              + size (output_OutputChange x)
              + size (crtc_OutputChange x)
              + size (mode_OutputChange x)
              + size (undefined :: Word16)
              + size (undefined :: Word8)
              + size (undefined :: Word8)
 
instance Deserialize OutputChange where
        deserialize
          = do timestamp <- deserialize
               config_timestamp <- deserialize
               window <- deserialize
               output <- deserialize
               crtc <- deserialize
               mode <- deserialize
               rotation <- liftM fromMask (deserialize :: Get Word16)
               connection <- liftM fromValue (deserialize :: Get Word8)
               subpixel_order <- liftM fromValue (deserialize :: Get Word8)
               return
                 (MkOutputChange timestamp config_timestamp window output crtc mode
                    rotation
                    connection
                    subpixel_order)
 
data OutputProperty = MkOutputProperty{window_OutputProperty ::
                                       WINDOW,
                                       output_OutputProperty :: OUTPUT, atom_OutputProperty :: ATOM,
                                       timestamp_OutputProperty :: TIMESTAMP,
                                       status_OutputProperty :: Property}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize OutputProperty where
        serialize x
          = do serialize (window_OutputProperty x)
               serialize (output_OutputProperty x)
               serialize (atom_OutputProperty x)
               serialize (timestamp_OutputProperty x)
               serialize (toValue (status_OutputProperty x) :: Word8)
               putSkip 11
        size x
          = size (window_OutputProperty x) + size (output_OutputProperty x) +
              size (atom_OutputProperty x)
              + size (timestamp_OutputProperty x)
              + size (undefined :: Word8)
              + 11
 
instance Deserialize OutputProperty where
        deserialize
          = do window <- deserialize
               output <- deserialize
               atom <- deserialize
               timestamp <- deserialize
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 11
               return (MkOutputProperty window output atom timestamp status)


data NotifyData = NotifyDataCrtcChange CrtcChange
                | NotifyDataOutputChange OutputChange
                | NotifyDataOutputProperty OutputProperty
     deriving (Show, Typeable, Eq, Ord)

instance Serialize NotifyData where
    serialize  (NotifyDataCrtcChange x) = serialize x
    serialize  (NotifyDataOutputChange x) = serialize x
    serialize  (NotifyDataOutputProperty x) = serialize x
    size (NotifyDataCrtcChange x) = size x
    size (NotifyDataOutputChange x) = size x
    size (NotifyDataOutputProperty x) = size x

deserializeNotifyData :: Notify -> Get NotifyData
deserializeNotifyData NotifyCrtcChange = NotifyDataCrtcChange `liftM` deserialize
deserializeNotifyData NotifyOutputChange = NotifyDataOutputChange `liftM` deserialize
deserializeNotifyData NotifyOutputProperty = NotifyDataOutputProperty `liftM` deserialize

subCodeToNotifyEnum :: Word8 -> Notify
subCodeToNotifyEnum 0 = NotifyCrtcChange
subCodeToNotifyEnum 1 = NotifyOutputChange
subCodeToNotifyEnum 2 = NotifyOutputProperty

 
data NotifyEvent = MkNotifyEvent{subCode_NotifyEvent :: Notify,
                                 u_NotifyEvent :: NotifyData}
                 deriving (Show, Typeable, Eq, Ord)

instance Graphics.XHB.Shared.Event NotifyEvent
 
instance Deserialize NotifyEvent where
        deserialize
          = do skip 1
               subCode <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               u <- deserializeNotifyData subCode
               return (MkNotifyEvent subCode u)