module Graphics.XHB.Gen.Xproto.Types
       (deserializeError, deserializeEvent, CHAR2B(..), WINDOW, PIXMAP,
        CURSOR, FONT, GCONTEXT, COLORMAP, ATOM, DRAWABLE, FONTABLE,
        VISUALID, TIMESTAMP, KEYSYM, KEYCODE, BUTTON, POINT(..),
        RECTANGLE(..), ARC(..), FORMAT(..), VisualClass(..),
        VISUALTYPE(..), DEPTH(..), EventMask(..), BackingStore(..),
        SCREEN(..), SetupRequest(..), SetupFailed(..),
        SetupAuthenticate(..), ImageOrder(..), Setup(..), ModMask(..),
        KeyButMask(..), Window(..), KeyPressEvent(..), KeyReleaseEvent(..),
        ButtonMask(..), ButtonPressEvent(..), ButtonReleaseEvent(..),
        Motion(..), MotionNotifyEvent(..), NotifyDetail(..),
        NotifyMode(..), EnterNotifyEvent(..), LeaveNotifyEvent(..),
        FocusInEvent(..), FocusOutEvent(..), KeymapNotifyEvent(..),
        ExposeEvent(..), GraphicsExposureEvent(..), NoExposureEvent(..),
        Visibility(..), VisibilityNotifyEvent(..), CreateNotifyEvent(..),
        DestroyNotifyEvent(..), UnmapNotifyEvent(..), MapNotifyEvent(..),
        MapRequestEvent(..), ReparentNotifyEvent(..),
        ConfigureNotifyEvent(..), ConfigureRequestEvent(..),
        GravityNotifyEvent(..), ResizeRequestEvent(..), Place(..),
        CirculateNotifyEvent(..), CirculateRequestEvent(..), Property(..),
        PropertyNotifyEvent(..), SelectionClearEvent(..), Time(..),
        Atom(..), SelectionRequestEvent(..), SelectionNotifyEvent(..),
        ColormapState(..), Colormap(..), ColormapNotifyEvent(..),
        ClientMessageEvent(..), ClientMessageData(..), Mapping(..), MappingNotifyEvent(..),
        RequestError(..), ValueError(..), WindowError(..), PixmapError(..),
        AtomError(..), CursorError(..), FontError(..), MatchError(..),
        DrawableError(..), AccessError(..), AllocError(..),
        ColormapError(..), GContextError(..), IDChoiceError(..),
        NameError(..), LengthError(..), ImplementationError(..),
        WindowClass(..), CW(..), BackPixmap(..), Gravity(..),
        CreateWindow(..), ChangeWindowAttributes(..), MapState(..),
        GetWindowAttributes(..), GetWindowAttributesReply(..),
        DestroyWindow(..), DestroySubwindows(..), SetMode(..),
        ChangeSaveSet(..), ReparentWindow(..), MapWindow(..),
        MapSubwindows(..), UnmapWindow(..), UnmapSubwindows(..),
        ConfigWindow(..), StackMode(..), ConfigureWindow(..),
        Circulate(..), CirculateWindow(..), GetGeometry(..),
        GetGeometryReply(..), QueryTree(..), QueryTreeReply(..),
        InternAtom(..), InternAtomReply(..), GetAtomName(..),
        GetAtomNameReply(..), PropMode(..), ChangeProperty(..),
        DeleteProperty(..), GetPropertyType(..), GetProperty(..),
        GetPropertyReply(..), ListProperties(..), ListPropertiesReply(..),
        SetSelectionOwner(..), GetSelectionOwner(..),
        GetSelectionOwnerReply(..), ConvertSelection(..),
        SendEventDest(..), SendEvent(..), GrabMode(..), GrabStatus(..),
        Cursor(..), GrabPointer(..), GrabPointerReply(..),
        UngrabPointer(..), ButtonIndex(..), GrabButton(..),
        UngrabButton(..), ChangeActivePointerGrab(..), GrabKeyboard(..),
        GrabKeyboardReply(..), UngrabKeyboard(..), Grab(..), GrabKey(..),
        UngrabKey(..), Allow(..), AllowEvents(..), GrabServer(..),
        UngrabServer(..), QueryPointer(..), QueryPointerReply(..),
        TIMECOORD(..), GetMotionEvents(..), GetMotionEventsReply(..),
        TranslateCoordinates(..), TranslateCoordinatesReply(..),
        WarpPointer(..), InputFocus(..), SetInputFocus(..),
        GetInputFocus(..), GetInputFocusReply(..), QueryKeymap(..),
        QueryKeymapReply(..), OpenFont(..), CloseFont(..), FontDraw(..),
        FONTPROP(..), CHARINFO(..), QueryFont(..), QueryFontReply(..),
        odd_length_QueryTextExtents, QueryTextExtents(..),
        QueryTextExtentsReply(..), STR(..), ListFonts(..),
        ListFontsReply(..), ListFontsWithInfo(..),
        ListFontsWithInfoReply(..), SetFontPath(..), GetFontPath(..),
        GetFontPathReply(..), CreatePixmap(..), FreePixmap(..), GC(..),
        GX(..), LineStyle(..), CapStyle(..), JoinStyle(..), FillStyle(..),
        FillRule(..), SubwindowMode(..), ArcMode(..), CreateGC(..),
        ChangeGC(..), CopyGC(..), SetDashes(..), ClipOrdering(..),
        SetClipRectangles(..), FreeGC(..), ClearArea(..), CopyArea(..),
        CopyPlane(..), CoordMode(..), PolyPoint(..), PolyLine(..),
        SEGMENT(..), PolySegment(..), PolyRectangle(..), PolyArc(..),
        PolyShape(..), FillPoly(..), PolyFillRectangle(..),
        PolyFillArc(..), ImageFormat(..), PutImage(..), GetImage(..),
        GetImageReply(..), PolyText8(..), PolyText16(..), ImageText8(..),
        ImageText16(..), ColormapAlloc(..), CreateColormap(..),
        FreeColormap(..), CopyColormapAndFree(..), InstallColormap(..),
        UninstallColormap(..), ListInstalledColormaps(..),
        ListInstalledColormapsReply(..), AllocColor(..),
        AllocColorReply(..), AllocNamedColor(..), AllocNamedColorReply(..),
        AllocColorCells(..), AllocColorCellsReply(..),
        AllocColorPlanes(..), AllocColorPlanesReply(..), FreeColors(..),
        ColorFlag(..), COLORITEM(..), StoreColors(..), StoreNamedColor(..),
        RGB(..), QueryColors(..), QueryColorsReply(..), LookupColor(..),
        LookupColorReply(..), Pixmap(..), CreateCursor(..), Font(..),
        CreateGlyphCursor(..), FreeCursor(..), RecolorCursor(..),
        QueryShapeOf(..), QueryBestSize(..), QueryBestSizeReply(..),
        QueryExtension(..), QueryExtensionReply(..), ListExtensions(..),
        ListExtensionsReply(..), ChangeKeyboardMapping(..),
        GetKeyboardMapping(..), GetKeyboardMappingReply(..), KB(..),
        LedMode(..), AutoRepeatMode(..), ChangeKeyboardControl(..),
        GetKeyboardControl(..), GetKeyboardControlReply(..), Bell(..),
        ChangePointerControl(..), GetPointerControl(..),
        GetPointerControlReply(..), Blanking(..), Exposures(..),
        SetScreenSaver(..), GetScreenSaver(..), GetScreenSaverReply(..),
        HostMode(..), Family(..), ChangeHosts(..), HOST(..), ListHosts(..),
        ListHostsReply(..), AccessControl(..), SetAccessControl(..),
        CloseDown(..), SetCloseDownMode(..), Kill(..), KillClient(..),
        RotateProperties(..), ScreenSaver(..), ForceScreenSaver(..),
        MappingStatus(..), SetPointerMapping(..),
        SetPointerMappingReply(..), GetPointerMapping(..),
        GetPointerMappingReply(..), MapIndex(..), SetModifierMapping(..),
        SetModifierMappingReply(..), GetModifierMapping(..),
        GetModifierMappingReply(..), NoOperation(..))
       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
 
deserializeError :: Word8 -> Maybe (Get SomeError)
deserializeError 1
  = return (liftM toError (deserialize :: Get RequestError))
deserializeError 2
  = return (liftM toError (deserialize :: Get ValueError))
deserializeError 3
  = return (liftM toError (deserialize :: Get WindowError))
deserializeError 4
  = return (liftM toError (deserialize :: Get PixmapError))
deserializeError 5
  = return (liftM toError (deserialize :: Get AtomError))
deserializeError 6
  = return (liftM toError (deserialize :: Get CursorError))
deserializeError 7
  = return (liftM toError (deserialize :: Get FontError))
deserializeError 8
  = return (liftM toError (deserialize :: Get MatchError))
deserializeError 9
  = return (liftM toError (deserialize :: Get DrawableError))
deserializeError 10
  = return (liftM toError (deserialize :: Get AccessError))
deserializeError 11
  = return (liftM toError (deserialize :: Get AllocError))
deserializeError 12
  = return (liftM toError (deserialize :: Get ColormapError))
deserializeError 13
  = return (liftM toError (deserialize :: Get GContextError))
deserializeError 14
  = return (liftM toError (deserialize :: Get IDChoiceError))
deserializeError 15
  = return (liftM toError (deserialize :: Get NameError))
deserializeError 16
  = return (liftM toError (deserialize :: Get LengthError))
deserializeError 17
  = return (liftM toError (deserialize :: Get ImplementationError))
deserializeError _ = Nothing
 
deserializeEvent :: Word8 -> Maybe (Get SomeEvent)
deserializeEvent 2
  = return (liftM toEvent (deserialize :: Get KeyPressEvent))
deserializeEvent 3
  = return (liftM toEvent (deserialize :: Get KeyReleaseEvent))
deserializeEvent 4
  = return (liftM toEvent (deserialize :: Get ButtonPressEvent))
deserializeEvent 5
  = return (liftM toEvent (deserialize :: Get ButtonReleaseEvent))
deserializeEvent 6
  = return (liftM toEvent (deserialize :: Get MotionNotifyEvent))
deserializeEvent 7
  = return (liftM toEvent (deserialize :: Get EnterNotifyEvent))
deserializeEvent 8
  = return (liftM toEvent (deserialize :: Get LeaveNotifyEvent))
deserializeEvent 9
  = return (liftM toEvent (deserialize :: Get FocusInEvent))
deserializeEvent 10
  = return (liftM toEvent (deserialize :: Get FocusOutEvent))
deserializeEvent 11
  = return (liftM toEvent (deserialize :: Get KeymapNotifyEvent))
deserializeEvent 12
  = return (liftM toEvent (deserialize :: Get ExposeEvent))
deserializeEvent 13
  = return (liftM toEvent (deserialize :: Get GraphicsExposureEvent))
deserializeEvent 14
  = return (liftM toEvent (deserialize :: Get NoExposureEvent))
deserializeEvent 15
  = return (liftM toEvent (deserialize :: Get VisibilityNotifyEvent))
deserializeEvent 16
  = return (liftM toEvent (deserialize :: Get CreateNotifyEvent))
deserializeEvent 17
  = return (liftM toEvent (deserialize :: Get DestroyNotifyEvent))
deserializeEvent 18
  = return (liftM toEvent (deserialize :: Get UnmapNotifyEvent))
deserializeEvent 19
  = return (liftM toEvent (deserialize :: Get MapNotifyEvent))
deserializeEvent 20
  = return (liftM toEvent (deserialize :: Get MapRequestEvent))
deserializeEvent 21
  = return (liftM toEvent (deserialize :: Get ReparentNotifyEvent))
deserializeEvent 22
  = return (liftM toEvent (deserialize :: Get ConfigureNotifyEvent))
deserializeEvent 23
  = return (liftM toEvent (deserialize :: Get ConfigureRequestEvent))
deserializeEvent 24
  = return (liftM toEvent (deserialize :: Get GravityNotifyEvent))
deserializeEvent 25
  = return (liftM toEvent (deserialize :: Get ResizeRequestEvent))
deserializeEvent 26
  = return (liftM toEvent (deserialize :: Get CirculateNotifyEvent))
deserializeEvent 27
  = return (liftM toEvent (deserialize :: Get CirculateRequestEvent))
deserializeEvent 28
  = return (liftM toEvent (deserialize :: Get PropertyNotifyEvent))
deserializeEvent 29
  = return (liftM toEvent (deserialize :: Get SelectionClearEvent))
deserializeEvent 30
  = return (liftM toEvent (deserialize :: Get SelectionRequestEvent))
deserializeEvent 31
  = return (liftM toEvent (deserialize :: Get SelectionNotifyEvent))
deserializeEvent 32
  = return (liftM toEvent (deserialize :: Get ColormapNotifyEvent))
deserializeEvent 33
  = return (liftM toEvent (deserialize :: Get ClientMessageEvent))
deserializeEvent 34
  = return (liftM toEvent (deserialize :: Get MappingNotifyEvent))
deserializeEvent _ = Nothing
 
data CHAR2B = MkCHAR2B{byte1_CHAR2B :: Word8,
                       byte2_CHAR2B :: Word8}
            deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CHAR2B where
        serialize x
          = do serialize (byte1_CHAR2B x)
               serialize (byte2_CHAR2B x)
        size x = size (byte1_CHAR2B x) + size (byte2_CHAR2B x)
 
instance Deserialize CHAR2B where
        deserialize
          = do byte1 <- deserialize
               byte2 <- deserialize
               return (MkCHAR2B byte1 byte2)
 
newtype WINDOW = MkWINDOW Xid
                 deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype PIXMAP = MkPIXMAP Xid
                 deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype CURSOR = MkCURSOR Xid
                 deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype FONT = MkFONT Xid
               deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype GCONTEXT = MkGCONTEXT Xid
                   deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype COLORMAP = MkCOLORMAP Xid
                   deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype ATOM = MkATOM Xid
               deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype DRAWABLE = MkDRAWABLE Xid
                   deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
newtype FONTABLE = MkFONTABLE Xid
                   deriving (Eq, Ord, Show, Serialize, Deserialize, XidLike)
 
type VISUALID = Word32
 
type TIMESTAMP = Word32
 
type KEYSYM = Word32
 
type KEYCODE = Word8
 
type BUTTON = Word8
 
data POINT = MkPOINT{x_POINT :: Int16, y_POINT :: Int16}
           deriving (Show, Typeable, Eq, Ord)
 
instance Serialize POINT where
        serialize x
          = do serialize (x_POINT x)
               serialize (y_POINT x)
        size x = size (x_POINT x) + size (y_POINT x)
 
instance Deserialize POINT where
        deserialize
          = do x <- deserialize
               y <- deserialize
               return (MkPOINT x y)
 
data RECTANGLE = MkRECTANGLE{x_RECTANGLE :: Int16,
                             y_RECTANGLE :: Int16, width_RECTANGLE :: Word16,
                             height_RECTANGLE :: Word16}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize RECTANGLE where
        serialize x
          = do serialize (x_RECTANGLE x)
               serialize (y_RECTANGLE x)
               serialize (width_RECTANGLE x)
               serialize (height_RECTANGLE x)
        size x
          = size (x_RECTANGLE x) + size (y_RECTANGLE x) +
              size (width_RECTANGLE x)
              + size (height_RECTANGLE x)
 
instance Deserialize RECTANGLE where
        deserialize
          = do x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               return (MkRECTANGLE x y width height)
 
data ARC = MkARC{x_ARC :: Int16, y_ARC :: Int16,
                 width_ARC :: Word16, height_ARC :: Word16, angle1_ARC :: Int16,
                 angle2_ARC :: Int16}
         deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ARC where
        serialize x
          = do serialize (x_ARC x)
               serialize (y_ARC x)
               serialize (width_ARC x)
               serialize (height_ARC x)
               serialize (angle1_ARC x)
               serialize (angle2_ARC x)
        size x
          = size (x_ARC x) + size (y_ARC x) + size (width_ARC x) +
              size (height_ARC x)
              + size (angle1_ARC x)
              + size (angle2_ARC x)
 
instance Deserialize ARC where
        deserialize
          = do x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               angle1 <- deserialize
               angle2 <- deserialize
               return (MkARC x y width height angle1 angle2)
 
data FORMAT = MkFORMAT{depth_FORMAT :: Word8,
                       bits_per_pixel_FORMAT :: Word8, scanline_pad_FORMAT :: Word8}
            deriving (Show, Typeable, Eq, Ord)
 
instance Serialize FORMAT where
        serialize x
          = do serialize (depth_FORMAT x)
               serialize (bits_per_pixel_FORMAT x)
               serialize (scanline_pad_FORMAT x)
               putSkip 5
        size x
          = size (depth_FORMAT x) + size (bits_per_pixel_FORMAT x) +
              size (scanline_pad_FORMAT x)
              + 5
 
instance Deserialize FORMAT where
        deserialize
          = do depth <- deserialize
               bits_per_pixel <- deserialize
               scanline_pad <- deserialize
               skip 5
               return (MkFORMAT depth bits_per_pixel scanline_pad)
 
data VisualClass = VisualClassStaticGray
                 | VisualClassGrayScale
                 | VisualClassStaticColor
                 | VisualClassPseudoColor
                 | VisualClassTrueColor
                 | VisualClassDirectColor
                 deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum VisualClass where
        toValue VisualClassStaticGray{} = 0
        toValue VisualClassGrayScale{} = 1
        toValue VisualClassStaticColor{} = 2
        toValue VisualClassPseudoColor{} = 3
        toValue VisualClassTrueColor{} = 4
        toValue VisualClassDirectColor{} = 5
        fromValue 0 = VisualClassStaticGray
        fromValue 1 = VisualClassGrayScale
        fromValue 2 = VisualClassStaticColor
        fromValue 3 = VisualClassPseudoColor
        fromValue 4 = VisualClassTrueColor
        fromValue 5 = VisualClassDirectColor
 
data VISUALTYPE = MkVISUALTYPE{visual_id_VISUALTYPE :: VISUALID,
                               class_VISUALTYPE :: VisualClass,
                               bits_per_rgb_value_VISUALTYPE :: Word8,
                               colormap_entries_VISUALTYPE :: Word16,
                               red_mask_VISUALTYPE :: Word32, green_mask_VISUALTYPE :: Word32,
                               blue_mask_VISUALTYPE :: Word32}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize VISUALTYPE where
        serialize x
          = do serialize (visual_id_VISUALTYPE x)
               serialize (toValue (class_VISUALTYPE x) :: Word8)
               serialize (bits_per_rgb_value_VISUALTYPE x)
               serialize (colormap_entries_VISUALTYPE x)
               serialize (red_mask_VISUALTYPE x)
               serialize (green_mask_VISUALTYPE x)
               serialize (blue_mask_VISUALTYPE x)
               putSkip 4
        size x
          = size (visual_id_VISUALTYPE x) + size (undefined :: Word8) +
              size (bits_per_rgb_value_VISUALTYPE x)
              + size (colormap_entries_VISUALTYPE x)
              + size (red_mask_VISUALTYPE x)
              + size (green_mask_VISUALTYPE x)
              + size (blue_mask_VISUALTYPE x)
              + 4
 
instance Deserialize VISUALTYPE where
        deserialize
          = do visual_id <- deserialize
               class_ <- liftM fromValue (deserialize :: Get Word8)
               bits_per_rgb_value <- deserialize
               colormap_entries <- deserialize
               red_mask <- deserialize
               green_mask <- deserialize
               blue_mask <- deserialize
               skip 4
               return
                 (MkVISUALTYPE visual_id class_ bits_per_rgb_value colormap_entries
                    red_mask
                    green_mask
                    blue_mask)
 
data DEPTH = MkDEPTH{depth_DEPTH :: Word8,
                     visuals_len_DEPTH :: Word16, visuals_DEPTH :: [VISUALTYPE]}
           deriving (Show, Typeable, Eq, Ord)
 
instance Serialize DEPTH where
        serialize x
          = do serialize (depth_DEPTH x)
               putSkip 1
               serialize (visuals_len_DEPTH x)
               putSkip 4
               serializeList (visuals_DEPTH x)
        size x
          = size (depth_DEPTH x) + 1 + size (visuals_len_DEPTH x) + 4 +
              sum (map size (visuals_DEPTH x))
 
instance Deserialize DEPTH where
        deserialize
          = do depth <- deserialize
               skip 1
               visuals_len <- deserialize
               skip 4
               visuals <- deserializeList (fromIntegral visuals_len)
               return (MkDEPTH depth visuals_len visuals)
 
data EventMask = EventMaskKeyPress
               | EventMaskKeyRelease
               | EventMaskButtonPress
               | EventMaskButtonRelease
               | EventMaskEnterWindow
               | EventMaskLeaveWindow
               | EventMaskPointerMotion
               | EventMaskPointerMotionHint
               | EventMaskButton1Motion
               | EventMaskButton2Motion
               | EventMaskButton3Motion
               | EventMaskButton4Motion
               | EventMaskButton5Motion
               | EventMaskButtonMotion
               | EventMaskKeymapState
               | EventMaskExposure
               | EventMaskVisibilityChange
               | EventMaskStructureNotify
               | EventMaskResizeRedirect
               | EventMaskSubstructureNotify
               | EventMaskSubstructureRedirect
               | EventMaskFocusChange
               | EventMaskPropertyChange
               | EventMaskColorMapChange
               | EventMaskOwnerGrabButton
               deriving (Show, Eq, Ord, Enum)
 
instance BitEnum EventMask where
        toBit EventMaskKeyPress{} = 0
        toBit EventMaskKeyRelease{} = 1
        toBit EventMaskButtonPress{} = 2
        toBit EventMaskButtonRelease{} = 3
        toBit EventMaskEnterWindow{} = 4
        toBit EventMaskLeaveWindow{} = 5
        toBit EventMaskPointerMotion{} = 6
        toBit EventMaskPointerMotionHint{} = 7
        toBit EventMaskButton1Motion{} = 8
        toBit EventMaskButton2Motion{} = 9
        toBit EventMaskButton3Motion{} = 10
        toBit EventMaskButton4Motion{} = 11
        toBit EventMaskButton5Motion{} = 12
        toBit EventMaskButtonMotion{} = 13
        toBit EventMaskKeymapState{} = 14
        toBit EventMaskExposure{} = 15
        toBit EventMaskVisibilityChange{} = 16
        toBit EventMaskStructureNotify{} = 17
        toBit EventMaskResizeRedirect{} = 18
        toBit EventMaskSubstructureNotify{} = 19
        toBit EventMaskSubstructureRedirect{} = 20
        toBit EventMaskFocusChange{} = 21
        toBit EventMaskPropertyChange{} = 22
        toBit EventMaskColorMapChange{} = 23
        toBit EventMaskOwnerGrabButton{} = 24
        fromBit 0 = EventMaskKeyPress
        fromBit 1 = EventMaskKeyRelease
        fromBit 2 = EventMaskButtonPress
        fromBit 3 = EventMaskButtonRelease
        fromBit 4 = EventMaskEnterWindow
        fromBit 5 = EventMaskLeaveWindow
        fromBit 6 = EventMaskPointerMotion
        fromBit 7 = EventMaskPointerMotionHint
        fromBit 8 = EventMaskButton1Motion
        fromBit 9 = EventMaskButton2Motion
        fromBit 10 = EventMaskButton3Motion
        fromBit 11 = EventMaskButton4Motion
        fromBit 12 = EventMaskButton5Motion
        fromBit 13 = EventMaskButtonMotion
        fromBit 14 = EventMaskKeymapState
        fromBit 15 = EventMaskExposure
        fromBit 16 = EventMaskVisibilityChange
        fromBit 17 = EventMaskStructureNotify
        fromBit 18 = EventMaskResizeRedirect
        fromBit 19 = EventMaskSubstructureNotify
        fromBit 20 = EventMaskSubstructureRedirect
        fromBit 21 = EventMaskFocusChange
        fromBit 22 = EventMaskPropertyChange
        fromBit 23 = EventMaskColorMapChange
        fromBit 24 = EventMaskOwnerGrabButton
 
data BackingStore = BackingStoreNotUseful
                  | BackingStoreWhenMapped
                  | BackingStoreAlways
                  deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum BackingStore where
        toValue BackingStoreNotUseful{} = 0
        toValue BackingStoreWhenMapped{} = 1
        toValue BackingStoreAlways{} = 2
        fromValue 0 = BackingStoreNotUseful
        fromValue 1 = BackingStoreWhenMapped
        fromValue 2 = BackingStoreAlways
 
data SCREEN = MkSCREEN{root_SCREEN :: WINDOW,
                       default_colormap_SCREEN :: COLORMAP, white_pixel_SCREEN :: Word32,
                       black_pixel_SCREEN :: Word32,
                       current_input_masks_SCREEN :: [EventMask],
                       width_in_pixels_SCREEN :: Word16,
                       height_in_pixels_SCREEN :: Word16,
                       width_in_millimeters_SCREEN :: Word16,
                       height_in_millimeters_SCREEN :: Word16,
                       min_installed_maps_SCREEN :: Word16,
                       max_installed_maps_SCREEN :: Word16,
                       root_visual_SCREEN :: VISUALID,
                       backing_stores_SCREEN :: BackingStore, save_unders_SCREEN :: Bool,
                       root_depth_SCREEN :: Word8, allowed_depths_len_SCREEN :: Word8,
                       allowed_depths_SCREEN :: [DEPTH]}
            deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SCREEN where
        serialize x
          = do serialize (root_SCREEN x)
               serialize (default_colormap_SCREEN x)
               serialize (white_pixel_SCREEN x)
               serialize (black_pixel_SCREEN x)
               serialize (toMask (current_input_masks_SCREEN x) :: Word32)
               serialize (width_in_pixels_SCREEN x)
               serialize (height_in_pixels_SCREEN x)
               serialize (width_in_millimeters_SCREEN x)
               serialize (height_in_millimeters_SCREEN x)
               serialize (min_installed_maps_SCREEN x)
               serialize (max_installed_maps_SCREEN x)
               serialize (root_visual_SCREEN x)
               serialize (toValue (backing_stores_SCREEN x) :: Word8)
               serialize (save_unders_SCREEN x)
               serialize (root_depth_SCREEN x)
               serialize (allowed_depths_len_SCREEN x)
               serializeList (allowed_depths_SCREEN x)
        size x
          = size (root_SCREEN x) + size (default_colormap_SCREEN x) +
              size (white_pixel_SCREEN x)
              + size (black_pixel_SCREEN x)
              + size (undefined :: Word32)
              + size (width_in_pixels_SCREEN x)
              + size (height_in_pixels_SCREEN x)
              + size (width_in_millimeters_SCREEN x)
              + size (height_in_millimeters_SCREEN x)
              + size (min_installed_maps_SCREEN x)
              + size (max_installed_maps_SCREEN x)
              + size (root_visual_SCREEN x)
              + size (undefined :: Word8)
              + size (save_unders_SCREEN x)
              + size (root_depth_SCREEN x)
              + size (allowed_depths_len_SCREEN x)
              + sum (map size (allowed_depths_SCREEN x))
 
instance Deserialize SCREEN where
        deserialize
          = do root <- deserialize
               default_colormap <- deserialize
               white_pixel <- deserialize
               black_pixel <- deserialize
               current_input_masks <- liftM fromMask (deserialize :: Get Word32)
               width_in_pixels <- deserialize
               height_in_pixels <- deserialize
               width_in_millimeters <- deserialize
               height_in_millimeters <- deserialize
               min_installed_maps <- deserialize
               max_installed_maps <- deserialize
               root_visual <- deserialize
               backing_stores <- liftM fromValue (deserialize :: Get Word8)
               save_unders <- deserialize
               root_depth <- deserialize
               allowed_depths_len <- deserialize
               allowed_depths <- deserializeList (fromIntegral allowed_depths_len)
               return
                 (MkSCREEN root default_colormap white_pixel black_pixel
                    current_input_masks
                    width_in_pixels
                    height_in_pixels
                    width_in_millimeters
                    height_in_millimeters
                    min_installed_maps
                    max_installed_maps
                    root_visual
                    backing_stores
                    save_unders
                    root_depth
                    allowed_depths_len
                    allowed_depths)
 
data SetupRequest = MkSetupRequest{byte_order_SetupRequest ::
                                   Word8,
                                   protocol_major_version_SetupRequest :: Word16,
                                   protocol_minor_version_SetupRequest :: Word16,
                                   authorization_protocol_name_len_SetupRequest :: Word16,
                                   authorization_protocol_data_len_SetupRequest :: Word16,
                                   authorization_protocol_name_SetupRequest :: [CChar],
                                   authorization_protocol_data_SetupRequest :: [CChar]}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetupRequest where
        serialize x
          = do serialize (byte_order_SetupRequest x)
               putSkip 1
               serialize (protocol_major_version_SetupRequest x)
               serialize (protocol_minor_version_SetupRequest x)
               serialize (authorization_protocol_name_len_SetupRequest x)
               serialize (authorization_protocol_data_len_SetupRequest x)
               putSkip 2
               serializeList (authorization_protocol_name_SetupRequest x)
               serializeList (authorization_protocol_data_SetupRequest x)
        size x
          = size (byte_order_SetupRequest x) + 1 +
              size (protocol_major_version_SetupRequest x)
              + size (protocol_minor_version_SetupRequest x)
              + size (authorization_protocol_name_len_SetupRequest x)
              + size (authorization_protocol_data_len_SetupRequest x)
              + 2
              + sum (map size (authorization_protocol_name_SetupRequest x))
              + sum (map size (authorization_protocol_data_SetupRequest x))
 
instance Deserialize SetupRequest where
        deserialize
          = do byte_order <- deserialize
               skip 1
               protocol_major_version <- deserialize
               protocol_minor_version <- deserialize
               authorization_protocol_name_len <- deserialize
               authorization_protocol_data_len <- deserialize
               skip 2
               authorization_protocol_name <- deserializeList
                                                (fromIntegral authorization_protocol_name_len)
               authorization_protocol_data <- deserializeList
                                                (fromIntegral authorization_protocol_data_len)
               return
                 (MkSetupRequest byte_order protocol_major_version
                    protocol_minor_version
                    authorization_protocol_name_len
                    authorization_protocol_data_len
                    authorization_protocol_name
                    authorization_protocol_data)
 
data SetupFailed = MkSetupFailed{status_SetupFailed :: Word8,
                                 reason_len_SetupFailed :: Word8,
                                 protocol_major_version_SetupFailed :: Word16,
                                 protocol_minor_version_SetupFailed :: Word16,
                                 length_SetupFailed :: Word16, reason_SetupFailed :: [CChar]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetupFailed where
        serialize x
          = do serialize (status_SetupFailed x)
               serialize (reason_len_SetupFailed x)
               serialize (protocol_major_version_SetupFailed x)
               serialize (protocol_minor_version_SetupFailed x)
               serialize (length_SetupFailed x)
               serializeList (reason_SetupFailed x)
        size x
          = size (status_SetupFailed x) + size (reason_len_SetupFailed x) +
              size (protocol_major_version_SetupFailed x)
              + size (protocol_minor_version_SetupFailed x)
              + size (length_SetupFailed x)
              + sum (map size (reason_SetupFailed x))
 
instance Deserialize SetupFailed where
        deserialize
          = do status <- deserialize
               reason_len <- deserialize
               protocol_major_version <- deserialize
               protocol_minor_version <- deserialize
               length <- deserialize
               reason <- deserializeList (fromIntegral reason_len)
               return
                 (MkSetupFailed status reason_len protocol_major_version
                    protocol_minor_version
                    length
                    reason)
 
data SetupAuthenticate = MkSetupAuthenticate{status_SetupAuthenticate
                                             :: Word8,
                                             length_SetupAuthenticate :: Word16,
                                             reason_SetupAuthenticate :: [CChar]}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetupAuthenticate where
        serialize x
          = do serialize (status_SetupAuthenticate x)
               putSkip 5
               serialize (length_SetupAuthenticate x)
               serializeList (reason_SetupAuthenticate x)
        size x
          = size (status_SetupAuthenticate x) + 5 +
              size (length_SetupAuthenticate x)
              + sum (map size (reason_SetupAuthenticate x))
 
instance Deserialize SetupAuthenticate where
        deserialize
          = do status <- deserialize
               skip 5
               length <- deserialize
               reason <- deserializeList
                           (fromIntegral (fromIntegral (length * 4)))
               return (MkSetupAuthenticate status length reason)
 
data ImageOrder = ImageOrderLSBFirst
                | ImageOrderMSBFirst
                deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum ImageOrder where
        toValue ImageOrderLSBFirst{} = 0
        toValue ImageOrderMSBFirst{} = 1
        fromValue 0 = ImageOrderLSBFirst
        fromValue 1 = ImageOrderMSBFirst
 
data Setup = MkSetup{status_Setup :: Word8,
                     protocol_major_version_Setup :: Word16,
                     protocol_minor_version_Setup :: Word16, length_Setup :: Word16,
                     release_number_Setup :: Word32, resource_id_base_Setup :: Word32,
                     resource_id_mask_Setup :: Word32,
                     motion_buffer_size_Setup :: Word32, vendor_len_Setup :: Word16,
                     maximum_request_length_Setup :: Word16, roots_len_Setup :: Word8,
                     pixmap_formats_len_Setup :: Word8,
                     image_byte_order_Setup :: ImageOrder,
                     bitmap_format_bit_order_Setup :: ImageOrder,
                     bitmap_format_scanline_unit_Setup :: Word8,
                     bitmap_format_scanline_pad_Setup :: Word8,
                     min_keycode_Setup :: KEYCODE, max_keycode_Setup :: KEYCODE,
                     vendor_Setup :: [CChar], pixmap_formats_Setup :: [FORMAT],
                     roots_Setup :: [SCREEN]}
           deriving (Show, Typeable, Eq, Ord)
 
instance Serialize Setup where
        serialize x
          = do serialize (status_Setup x)
               putSkip 1
               serialize (protocol_major_version_Setup x)
               serialize (protocol_minor_version_Setup x)
               serialize (length_Setup x)
               serialize (release_number_Setup x)
               serialize (resource_id_base_Setup x)
               serialize (resource_id_mask_Setup x)
               serialize (motion_buffer_size_Setup x)
               serialize (vendor_len_Setup x)
               serialize (maximum_request_length_Setup x)
               serialize (roots_len_Setup x)
               serialize (pixmap_formats_len_Setup x)
               serialize (toValue (image_byte_order_Setup x) :: Word8)
               serialize (toValue (bitmap_format_bit_order_Setup x) :: Word8)
               serialize (bitmap_format_scanline_unit_Setup x)
               serialize (bitmap_format_scanline_pad_Setup x)
               serialize (min_keycode_Setup x)
               serialize (max_keycode_Setup x)
               putSkip 4
               serializeList (vendor_Setup x)
               serializeList (pixmap_formats_Setup x)
               serializeList (roots_Setup x)
        size x
          = size (status_Setup x) + 1 + size (protocol_major_version_Setup x)
              + size (protocol_minor_version_Setup x)
              + size (length_Setup x)
              + size (release_number_Setup x)
              + size (resource_id_base_Setup x)
              + size (resource_id_mask_Setup x)
              + size (motion_buffer_size_Setup x)
              + size (vendor_len_Setup x)
              + size (maximum_request_length_Setup x)
              + size (roots_len_Setup x)
              + size (pixmap_formats_len_Setup x)
              + size (undefined :: Word8)
              + size (undefined :: Word8)
              + size (bitmap_format_scanline_unit_Setup x)
              + size (bitmap_format_scanline_pad_Setup x)
              + size (min_keycode_Setup x)
              + size (max_keycode_Setup x)
              + 4
              + sum (map size (vendor_Setup x))
              + sum (map size (pixmap_formats_Setup x))
              + sum (map size (roots_Setup x))
 
instance Deserialize Setup where
        deserialize
          = do status <- deserialize
               skip 1
               protocol_major_version <- deserialize
               protocol_minor_version <- deserialize
               length <- deserialize
               release_number <- deserialize
               resource_id_base <- deserialize
               resource_id_mask <- deserialize
               motion_buffer_size <- deserialize
               vendor_len <- deserialize
               maximum_request_length <- deserialize
               roots_len <- deserialize
               pixmap_formats_len <- deserialize
               image_byte_order <- liftM fromValue (deserialize :: Get Word8)
               bitmap_format_bit_order <- liftM fromValue
                                            (deserialize :: Get Word8)
               bitmap_format_scanline_unit <- deserialize
               bitmap_format_scanline_pad <- deserialize
               min_keycode <- deserialize
               max_keycode <- deserialize
               skip 4
               vendor <- deserializeList (fromIntegral vendor_len)
               pixmap_formats <- deserializeList (fromIntegral pixmap_formats_len)
               roots <- deserializeList (fromIntegral roots_len)
               return
                 (MkSetup status protocol_major_version protocol_minor_version
                    length
                    release_number
                    resource_id_base
                    resource_id_mask
                    motion_buffer_size
                    vendor_len
                    maximum_request_length
                    roots_len
                    pixmap_formats_len
                    image_byte_order
                    bitmap_format_bit_order
                    bitmap_format_scanline_unit
                    bitmap_format_scanline_pad
                    min_keycode
                    max_keycode
                    vendor
                    pixmap_formats
                    roots)
 
data ModMask = ModMaskShift
             | ModMaskLock
             | ModMaskControl
             | ModMask1
             | ModMask2
             | ModMask3
             | ModMask4
             | ModMask5
             | ModMaskAny
             deriving (Show, Eq, Ord, Enum)
 
instance BitEnum ModMask where
        toBit ModMaskShift{} = 0
        toBit ModMaskLock{} = 1
        toBit ModMaskControl{} = 2
        toBit ModMask1{} = 3
        toBit ModMask2{} = 4
        toBit ModMask3{} = 5
        toBit ModMask4{} = 6
        toBit ModMask5{} = 7
        toBit ModMaskAny{} = 15
        fromBit 0 = ModMaskShift
        fromBit 1 = ModMaskLock
        fromBit 2 = ModMaskControl
        fromBit 3 = ModMask1
        fromBit 4 = ModMask2
        fromBit 5 = ModMask3
        fromBit 6 = ModMask4
        fromBit 7 = ModMask5
        fromBit 15 = ModMaskAny
 
data KeyButMask = KeyButMaskShift
                | KeyButMaskLock
                | KeyButMaskControl
                | KeyButMaskMod1
                | KeyButMaskMod2
                | KeyButMaskMod3
                | KeyButMaskMod4
                | KeyButMaskMod5
                | KeyButMaskButton1
                | KeyButMaskButton2
                | KeyButMaskButton3
                | KeyButMaskButton4
                | KeyButMaskButton5
                deriving (Show, Eq, Ord, Enum)
 
instance BitEnum KeyButMask where
        toBit KeyButMaskShift{} = 0
        toBit KeyButMaskLock{} = 1
        toBit KeyButMaskControl{} = 2
        toBit KeyButMaskMod1{} = 3
        toBit KeyButMaskMod2{} = 4
        toBit KeyButMaskMod3{} = 5
        toBit KeyButMaskMod4{} = 6
        toBit KeyButMaskMod5{} = 7
        toBit KeyButMaskButton1{} = 8
        toBit KeyButMaskButton2{} = 9
        toBit KeyButMaskButton3{} = 10
        toBit KeyButMaskButton4{} = 11
        toBit KeyButMaskButton5{} = 12
        fromBit 0 = KeyButMaskShift
        fromBit 1 = KeyButMaskLock
        fromBit 2 = KeyButMaskControl
        fromBit 3 = KeyButMaskMod1
        fromBit 4 = KeyButMaskMod2
        fromBit 5 = KeyButMaskMod3
        fromBit 6 = KeyButMaskMod4
        fromBit 7 = KeyButMaskMod5
        fromBit 8 = KeyButMaskButton1
        fromBit 9 = KeyButMaskButton2
        fromBit 10 = KeyButMaskButton3
        fromBit 11 = KeyButMaskButton4
        fromBit 12 = KeyButMaskButton5
 
data Window = WindowNone
            deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Window where
        toValue WindowNone{} = 0
        fromValue 0 = WindowNone
 
data KeyPressEvent = MkKeyPressEvent{detail_KeyPressEvent ::
                                     KEYCODE,
                                     time_KeyPressEvent :: TIMESTAMP, root_KeyPressEvent :: WINDOW,
                                     event_KeyPressEvent :: WINDOW, child_KeyPressEvent :: WINDOW,
                                     root_x_KeyPressEvent :: Int16, root_y_KeyPressEvent :: Int16,
                                     event_x_KeyPressEvent :: Int16, event_y_KeyPressEvent :: Int16,
                                     state_KeyPressEvent :: [KeyButMask],
                                     same_screen_KeyPressEvent :: Bool}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event KeyPressEvent
 
instance Deserialize KeyPressEvent where
        deserialize
          = do skip 1
               detail <- deserialize
               skip 2
               time <- deserialize
               root <- deserialize
               event <- deserialize
               child <- deserialize
               root_x <- deserialize
               root_y <- deserialize
               event_x <- deserialize
               event_y <- deserialize
               state <- liftM fromMask (deserialize :: Get Word16)
               same_screen <- deserialize
               skip 1
               return
                 (MkKeyPressEvent detail time root event child root_x root_y event_x
                    event_y
                    state
                    same_screen)
 
data KeyReleaseEvent = MkKeyReleaseEvent{detail_KeyReleaseEvent ::
                                         KEYCODE,
                                         time_KeyReleaseEvent :: TIMESTAMP,
                                         root_KeyReleaseEvent :: WINDOW,
                                         event_KeyReleaseEvent :: WINDOW,
                                         child_KeyReleaseEvent :: WINDOW,
                                         root_x_KeyReleaseEvent :: Int16,
                                         root_y_KeyReleaseEvent :: Int16,
                                         event_x_KeyReleaseEvent :: Int16,
                                         event_y_KeyReleaseEvent :: Int16,
                                         state_KeyReleaseEvent :: [KeyButMask],
                                         same_screen_KeyReleaseEvent :: Bool}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event KeyReleaseEvent
 
instance Deserialize KeyReleaseEvent where
        deserialize
          = do skip 1
               detail <- deserialize
               skip 2
               time <- deserialize
               root <- deserialize
               event <- deserialize
               child <- deserialize
               root_x <- deserialize
               root_y <- deserialize
               event_x <- deserialize
               event_y <- deserialize
               state <- liftM fromMask (deserialize :: Get Word16)
               same_screen <- deserialize
               skip 1
               return
                 (MkKeyReleaseEvent detail time root event child root_x root_y
                    event_x
                    event_y
                    state
                    same_screen)
 
data ButtonMask = ButtonMask1
                | ButtonMask2
                | ButtonMask3
                | ButtonMask4
                | ButtonMask5
                | ButtonMaskAny
                deriving (Show, Eq, Ord, Enum)
 
instance BitEnum ButtonMask where
        toBit ButtonMask1{} = 8
        toBit ButtonMask2{} = 9
        toBit ButtonMask3{} = 10
        toBit ButtonMask4{} = 11
        toBit ButtonMask5{} = 12
        toBit ButtonMaskAny{} = 15
        fromBit 8 = ButtonMask1
        fromBit 9 = ButtonMask2
        fromBit 10 = ButtonMask3
        fromBit 11 = ButtonMask4
        fromBit 12 = ButtonMask5
        fromBit 15 = ButtonMaskAny
 
data ButtonPressEvent = MkButtonPressEvent{detail_ButtonPressEvent
                                           :: BUTTON,
                                           time_ButtonPressEvent :: TIMESTAMP,
                                           root_ButtonPressEvent :: WINDOW,
                                           event_ButtonPressEvent :: WINDOW,
                                           child_ButtonPressEvent :: WINDOW,
                                           root_x_ButtonPressEvent :: Int16,
                                           root_y_ButtonPressEvent :: Int16,
                                           event_x_ButtonPressEvent :: Int16,
                                           event_y_ButtonPressEvent :: Int16,
                                           state_ButtonPressEvent :: [KeyButMask],
                                           same_screen_ButtonPressEvent :: Bool}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ButtonPressEvent
 
instance Deserialize ButtonPressEvent where
        deserialize
          = do skip 1
               detail <- deserialize
               skip 2
               time <- deserialize
               root <- deserialize
               event <- deserialize
               child <- deserialize
               root_x <- deserialize
               root_y <- deserialize
               event_x <- deserialize
               event_y <- deserialize
               state <- liftM fromMask (deserialize :: Get Word16)
               same_screen <- deserialize
               skip 1
               return
                 (MkButtonPressEvent detail time root event child root_x root_y
                    event_x
                    event_y
                    state
                    same_screen)
 
data ButtonReleaseEvent = MkButtonReleaseEvent{detail_ButtonReleaseEvent
                                               :: BUTTON,
                                               time_ButtonReleaseEvent :: TIMESTAMP,
                                               root_ButtonReleaseEvent :: WINDOW,
                                               event_ButtonReleaseEvent :: WINDOW,
                                               child_ButtonReleaseEvent :: WINDOW,
                                               root_x_ButtonReleaseEvent :: Int16,
                                               root_y_ButtonReleaseEvent :: Int16,
                                               event_x_ButtonReleaseEvent :: Int16,
                                               event_y_ButtonReleaseEvent :: Int16,
                                               state_ButtonReleaseEvent :: [KeyButMask],
                                               same_screen_ButtonReleaseEvent :: Bool}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ButtonReleaseEvent
 
instance Deserialize ButtonReleaseEvent where
        deserialize
          = do skip 1
               detail <- deserialize
               skip 2
               time <- deserialize
               root <- deserialize
               event <- deserialize
               child <- deserialize
               root_x <- deserialize
               root_y <- deserialize
               event_x <- deserialize
               event_y <- deserialize
               state <- liftM fromMask (deserialize :: Get Word16)
               same_screen <- deserialize
               skip 1
               return
                 (MkButtonReleaseEvent detail time root event child root_x root_y
                    event_x
                    event_y
                    state
                    same_screen)
 
data Motion = MotionNormal
            | MotionHint
            deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Motion where
        toValue MotionNormal{} = 0
        toValue MotionHint{} = 1
        fromValue 0 = MotionNormal
        fromValue 1 = MotionHint
 
data MotionNotifyEvent = MkMotionNotifyEvent{detail_MotionNotifyEvent
                                             :: Motion,
                                             time_MotionNotifyEvent :: TIMESTAMP,
                                             root_MotionNotifyEvent :: WINDOW,
                                             event_MotionNotifyEvent :: WINDOW,
                                             child_MotionNotifyEvent :: WINDOW,
                                             root_x_MotionNotifyEvent :: Int16,
                                             root_y_MotionNotifyEvent :: Int16,
                                             event_x_MotionNotifyEvent :: Int16,
                                             event_y_MotionNotifyEvent :: Int16,
                                             state_MotionNotifyEvent :: [KeyButMask],
                                             same_screen_MotionNotifyEvent :: Bool}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event MotionNotifyEvent
 
instance Deserialize MotionNotifyEvent where
        deserialize
          = do skip 1
               detail <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               time <- deserialize
               root <- deserialize
               event <- deserialize
               child <- deserialize
               root_x <- deserialize
               root_y <- deserialize
               event_x <- deserialize
               event_y <- deserialize
               state <- liftM fromMask (deserialize :: Get Word16)
               same_screen <- deserialize
               skip 1
               return
                 (MkMotionNotifyEvent detail time root event child root_x root_y
                    event_x
                    event_y
                    state
                    same_screen)
 
data NotifyDetail = NotifyDetailAncestor
                  | NotifyDetailVirtual
                  | NotifyDetailInferior
                  | NotifyDetailNonlinear
                  | NotifyDetailNonlinearVirtual
                  | NotifyDetailPointer
                  | NotifyDetailPointerRoot
                  | NotifyDetailNone
                  deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum NotifyDetail where
        toValue NotifyDetailAncestor{} = 0
        toValue NotifyDetailVirtual{} = 1
        toValue NotifyDetailInferior{} = 2
        toValue NotifyDetailNonlinear{} = 3
        toValue NotifyDetailNonlinearVirtual{} = 4
        toValue NotifyDetailPointer{} = 5
        toValue NotifyDetailPointerRoot{} = 6
        toValue NotifyDetailNone{} = 7
        fromValue 0 = NotifyDetailAncestor
        fromValue 1 = NotifyDetailVirtual
        fromValue 2 = NotifyDetailInferior
        fromValue 3 = NotifyDetailNonlinear
        fromValue 4 = NotifyDetailNonlinearVirtual
        fromValue 5 = NotifyDetailPointer
        fromValue 6 = NotifyDetailPointerRoot
        fromValue 7 = NotifyDetailNone
 
data NotifyMode = NotifyModeNormal
                | NotifyModeGrab
                | NotifyModeUngrab
                | NotifyModeWhileGrabbed
                deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum NotifyMode where
        toValue NotifyModeNormal{} = 0
        toValue NotifyModeGrab{} = 1
        toValue NotifyModeUngrab{} = 2
        toValue NotifyModeWhileGrabbed{} = 3
        fromValue 0 = NotifyModeNormal
        fromValue 1 = NotifyModeGrab
        fromValue 2 = NotifyModeUngrab
        fromValue 3 = NotifyModeWhileGrabbed
 
data EnterNotifyEvent = MkEnterNotifyEvent{detail_EnterNotifyEvent
                                           :: NotifyDetail,
                                           time_EnterNotifyEvent :: TIMESTAMP,
                                           root_EnterNotifyEvent :: WINDOW,
                                           event_EnterNotifyEvent :: WINDOW,
                                           child_EnterNotifyEvent :: WINDOW,
                                           root_x_EnterNotifyEvent :: Int16,
                                           root_y_EnterNotifyEvent :: Int16,
                                           event_x_EnterNotifyEvent :: Int16,
                                           event_y_EnterNotifyEvent :: Int16,
                                           state_EnterNotifyEvent :: [KeyButMask],
                                           mode_EnterNotifyEvent :: NotifyMode,
                                           same_screen_focus_EnterNotifyEvent :: Word8}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event EnterNotifyEvent
 
instance Deserialize EnterNotifyEvent where
        deserialize
          = do skip 1
               detail <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               time <- deserialize
               root <- deserialize
               event <- deserialize
               child <- deserialize
               root_x <- deserialize
               root_y <- deserialize
               event_x <- deserialize
               event_y <- deserialize
               state <- liftM fromMask (deserialize :: Get Word16)
               mode <- liftM fromValue (deserialize :: Get Word8)
               same_screen_focus <- deserialize
               return
                 (MkEnterNotifyEvent detail time root event child root_x root_y
                    event_x
                    event_y
                    state
                    mode
                    same_screen_focus)
 
data LeaveNotifyEvent = MkLeaveNotifyEvent{detail_LeaveNotifyEvent
                                           :: NotifyDetail,
                                           time_LeaveNotifyEvent :: TIMESTAMP,
                                           root_LeaveNotifyEvent :: WINDOW,
                                           event_LeaveNotifyEvent :: WINDOW,
                                           child_LeaveNotifyEvent :: WINDOW,
                                           root_x_LeaveNotifyEvent :: Int16,
                                           root_y_LeaveNotifyEvent :: Int16,
                                           event_x_LeaveNotifyEvent :: Int16,
                                           event_y_LeaveNotifyEvent :: Int16,
                                           state_LeaveNotifyEvent :: [KeyButMask],
                                           mode_LeaveNotifyEvent :: NotifyMode,
                                           same_screen_focus_LeaveNotifyEvent :: Word8}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event LeaveNotifyEvent
 
instance Deserialize LeaveNotifyEvent where
        deserialize
          = do skip 1
               detail <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               time <- deserialize
               root <- deserialize
               event <- deserialize
               child <- deserialize
               root_x <- deserialize
               root_y <- deserialize
               event_x <- deserialize
               event_y <- deserialize
               state <- liftM fromMask (deserialize :: Get Word16)
               mode <- liftM fromValue (deserialize :: Get Word8)
               same_screen_focus <- deserialize
               return
                 (MkLeaveNotifyEvent detail time root event child root_x root_y
                    event_x
                    event_y
                    state
                    mode
                    same_screen_focus)
 
data FocusInEvent = MkFocusInEvent{detail_FocusInEvent ::
                                   NotifyDetail,
                                   event_FocusInEvent :: WINDOW, mode_FocusInEvent :: NotifyMode}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event FocusInEvent
 
instance Deserialize FocusInEvent where
        deserialize
          = do skip 1
               detail <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               event <- deserialize
               mode <- liftM fromValue (deserialize :: Get Word8)
               skip 3
               return (MkFocusInEvent detail event mode)
 
data FocusOutEvent = MkFocusOutEvent{detail_FocusOutEvent ::
                                     NotifyDetail,
                                     event_FocusOutEvent :: WINDOW,
                                     mode_FocusOutEvent :: NotifyMode}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event FocusOutEvent
 
instance Deserialize FocusOutEvent where
        deserialize
          = do skip 1
               detail <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               event <- deserialize
               mode <- liftM fromValue (deserialize :: Get Word8)
               skip 3
               return (MkFocusOutEvent detail event mode)
 
data KeymapNotifyEvent = MkKeymapNotifyEvent{keys_KeymapNotifyEvent
                                             :: [Word8]}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event KeymapNotifyEvent
 
instance Deserialize KeymapNotifyEvent where
        deserialize
          = do skip 1
               keys <- deserializeList (fromIntegral 31)
               return (MkKeymapNotifyEvent keys)
 
data ExposeEvent = MkExposeEvent{window_ExposeEvent :: WINDOW,
                                 x_ExposeEvent :: Word16, y_ExposeEvent :: Word16,
                                 width_ExposeEvent :: Word16, height_ExposeEvent :: Word16,
                                 count_ExposeEvent :: Word16}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ExposeEvent
 
instance Deserialize ExposeEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               window <- deserialize
               x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               count <- deserialize
               skip 2
               return (MkExposeEvent window x y width height count)
 
data GraphicsExposureEvent = MkGraphicsExposureEvent{drawable_GraphicsExposureEvent
                                                     :: DRAWABLE,
                                                     x_GraphicsExposureEvent :: Word16,
                                                     y_GraphicsExposureEvent :: Word16,
                                                     width_GraphicsExposureEvent :: Word16,
                                                     height_GraphicsExposureEvent :: Word16,
                                                     minor_opcode_GraphicsExposureEvent :: Word16,
                                                     count_GraphicsExposureEvent :: Word16,
                                                     major_opcode_GraphicsExposureEvent :: Word8}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event GraphicsExposureEvent
 
instance Deserialize GraphicsExposureEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               drawable <- deserialize
               x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               minor_opcode <- deserialize
               count <- deserialize
               major_opcode <- deserialize
               skip 3
               return
                 (MkGraphicsExposureEvent drawable x y width height minor_opcode
                    count
                    major_opcode)
 
data NoExposureEvent = MkNoExposureEvent{drawable_NoExposureEvent
                                         :: DRAWABLE,
                                         minor_opcode_NoExposureEvent :: Word16,
                                         major_opcode_NoExposureEvent :: Word8}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event NoExposureEvent
 
instance Deserialize NoExposureEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               drawable <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkNoExposureEvent drawable minor_opcode major_opcode)
 
data Visibility = VisibilityUnobscured
                | VisibilityPartiallyObscured
                | VisibilityFullyObscured
                deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Visibility where
        toValue VisibilityUnobscured{} = 0
        toValue VisibilityPartiallyObscured{} = 1
        toValue VisibilityFullyObscured{} = 2
        fromValue 0 = VisibilityUnobscured
        fromValue 1 = VisibilityPartiallyObscured
        fromValue 2 = VisibilityFullyObscured
 
data VisibilityNotifyEvent = MkVisibilityNotifyEvent{window_VisibilityNotifyEvent
                                                     :: WINDOW,
                                                     state_VisibilityNotifyEvent :: Visibility}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event VisibilityNotifyEvent
 
instance Deserialize VisibilityNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               window <- deserialize
               state <- liftM fromValue (deserialize :: Get Word8)
               skip 3
               return (MkVisibilityNotifyEvent window state)
 
data CreateNotifyEvent = MkCreateNotifyEvent{parent_CreateNotifyEvent
                                             :: WINDOW,
                                             window_CreateNotifyEvent :: WINDOW,
                                             x_CreateNotifyEvent :: Int16,
                                             y_CreateNotifyEvent :: Int16,
                                             width_CreateNotifyEvent :: Word16,
                                             height_CreateNotifyEvent :: Word16,
                                             border_width_CreateNotifyEvent :: Word16,
                                             override_redirect_CreateNotifyEvent :: Bool}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event CreateNotifyEvent
 
instance Deserialize CreateNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               parent <- deserialize
               window <- deserialize
               x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               border_width <- deserialize
               override_redirect <- deserialize
               skip 1
               return
                 (MkCreateNotifyEvent parent window x y width height border_width
                    override_redirect)
 
data DestroyNotifyEvent = MkDestroyNotifyEvent{event_DestroyNotifyEvent
                                               :: WINDOW,
                                               window_DestroyNotifyEvent :: WINDOW}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event DestroyNotifyEvent
 
instance Deserialize DestroyNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               event <- deserialize
               window <- deserialize
               return (MkDestroyNotifyEvent event window)
 
data UnmapNotifyEvent = MkUnmapNotifyEvent{event_UnmapNotifyEvent
                                           :: WINDOW,
                                           window_UnmapNotifyEvent :: WINDOW,
                                           from_configure_UnmapNotifyEvent :: Bool}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event UnmapNotifyEvent
 
instance Deserialize UnmapNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               event <- deserialize
               window <- deserialize
               from_configure <- deserialize
               skip 3
               return (MkUnmapNotifyEvent event window from_configure)
 
data MapNotifyEvent = MkMapNotifyEvent{event_MapNotifyEvent ::
                                       WINDOW,
                                       window_MapNotifyEvent :: WINDOW,
                                       override_redirect_MapNotifyEvent :: Bool}
                    deriving (Show, Typeable, Eq, Ord)

 
data ClientMessageData = ClientData8  [Word8]  -- ^length 20
                       | ClientData16 [Word16] -- ^length 10
                       | ClientData32 [Word32] -- ^length 5
                   deriving (Show, Typeable, Eq, Ord)

 
data ClientMessageDataType = CDType8
                           | CDType16
                           | CDType32
 
clientMessageDataType :: ClientMessageData -> ClientMessageDataType
clientMessageDataType ClientData8{}  = CDType8
clientMessageDataType ClientData16{} = CDType16
clientMessageDataType ClientData32{} = CDType32
 
instance Serialize ClientMessageData where
    serialize (ClientData8 xs) = assert (length xs == 20) $
                                    serializeList xs
    serialize (ClientData16 xs) = assert (length xs == 10) $
                                     serializeList xs
    serialize (ClientData32 xs) = assert (length xs == 5) $
                                     serializeList xs
    size cd = assert
         (case cd of
            ClientData8  xs -> length xs == 20
            ClientData16 xs -> length xs == 10
            ClientData32 xs -> length xs == 5)
         20

deserializeClientData :: ClientMessageDataType -> Get ClientMessageData
deserializeClientData CDType8
    = ClientData8 `liftM` deserializeList 20
deserializeClientData CDType16
    = ClientData16 `liftM` deserializeList 10
deserializeClientData CDType32
    = ClientData32 `liftM` deserializeList 5
 
clientDataFormatToType :: Word8 -> ClientMessageDataType
clientDataFormatToType 8 = CDType8
clientDataFormatToType 16 = CDType16
clientDataFormatToType 32 = CDType32
clientDataFormatToType _ = CDType8 -- should we throw an error here?

 
instance Graphics.XHB.Shared.Event MapNotifyEvent
 
instance Deserialize MapNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               event <- deserialize
               window <- deserialize
               override_redirect <- deserialize
               skip 3
               return (MkMapNotifyEvent event window override_redirect)
 
data MapRequestEvent = MkMapRequestEvent{parent_MapRequestEvent ::
                                         WINDOW,
                                         window_MapRequestEvent :: WINDOW}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event MapRequestEvent
 
instance Deserialize MapRequestEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               parent <- deserialize
               window <- deserialize
               return (MkMapRequestEvent parent window)
 
data ReparentNotifyEvent = MkReparentNotifyEvent{event_ReparentNotifyEvent
                                                 :: WINDOW,
                                                 window_ReparentNotifyEvent :: WINDOW,
                                                 parent_ReparentNotifyEvent :: WINDOW,
                                                 x_ReparentNotifyEvent :: Int16,
                                                 y_ReparentNotifyEvent :: Int16,
                                                 override_redirect_ReparentNotifyEvent :: Bool}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ReparentNotifyEvent
 
instance Deserialize ReparentNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               event <- deserialize
               window <- deserialize
               parent <- deserialize
               x <- deserialize
               y <- deserialize
               override_redirect <- deserialize
               skip 3
               return
                 (MkReparentNotifyEvent event window parent x y override_redirect)
 
data ConfigureNotifyEvent = MkConfigureNotifyEvent{event_ConfigureNotifyEvent
                                                   :: WINDOW,
                                                   window_ConfigureNotifyEvent :: WINDOW,
                                                   above_sibling_ConfigureNotifyEvent :: WINDOW,
                                                   x_ConfigureNotifyEvent :: Int16,
                                                   y_ConfigureNotifyEvent :: Int16,
                                                   width_ConfigureNotifyEvent :: Word16,
                                                   height_ConfigureNotifyEvent :: Word16,
                                                   border_width_ConfigureNotifyEvent :: Word16,
                                                   override_redirect_ConfigureNotifyEvent :: Bool}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ConfigureNotifyEvent
 
instance Deserialize ConfigureNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               event <- deserialize
               window <- deserialize
               above_sibling <- deserialize
               x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               border_width <- deserialize
               override_redirect <- deserialize
               skip 1
               return
                 (MkConfigureNotifyEvent event window above_sibling x y width height
                    border_width
                    override_redirect)
 
data ConfigureRequestEvent = MkConfigureRequestEvent{stack_mode_ConfigureRequestEvent
                                                     :: StackMode,
                                                     parent_ConfigureRequestEvent :: WINDOW,
                                                     window_ConfigureRequestEvent :: WINDOW,
                                                     sibling_ConfigureRequestEvent :: WINDOW,
                                                     x_ConfigureRequestEvent :: Int16,
                                                     y_ConfigureRequestEvent :: Int16,
                                                     width_ConfigureRequestEvent :: Word16,
                                                     height_ConfigureRequestEvent :: Word16,
                                                     border_width_ConfigureRequestEvent :: Word16,
                                                     value_mask_ConfigureRequestEvent ::
                                                     [ConfigWindow]}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ConfigureRequestEvent
 
instance Deserialize ConfigureRequestEvent where
        deserialize
          = do skip 1
               stack_mode <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               parent <- deserialize
               window <- deserialize
               sibling <- deserialize
               x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               border_width <- deserialize
               value_mask <- liftM fromMask (deserialize :: Get Word16)
               return
                 (MkConfigureRequestEvent stack_mode parent window sibling x y width
                    height
                    border_width
                    value_mask)
 
data GravityNotifyEvent = MkGravityNotifyEvent{event_GravityNotifyEvent
                                               :: WINDOW,
                                               window_GravityNotifyEvent :: WINDOW,
                                               x_GravityNotifyEvent :: Int16,
                                               y_GravityNotifyEvent :: Int16}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event GravityNotifyEvent
 
instance Deserialize GravityNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               event <- deserialize
               window <- deserialize
               x <- deserialize
               y <- deserialize
               return (MkGravityNotifyEvent event window x y)
 
data ResizeRequestEvent = MkResizeRequestEvent{window_ResizeRequestEvent
                                               :: WINDOW,
                                               width_ResizeRequestEvent :: Word16,
                                               height_ResizeRequestEvent :: Word16}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ResizeRequestEvent
 
instance Deserialize ResizeRequestEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               window <- deserialize
               width <- deserialize
               height <- deserialize
               return (MkResizeRequestEvent window width height)
 
data Place = PlaceOnTop
           | PlaceOnBottom
           deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Place where
        toValue PlaceOnTop{} = 0
        toValue PlaceOnBottom{} = 1
        fromValue 0 = PlaceOnTop
        fromValue 1 = PlaceOnBottom
 
data CirculateNotifyEvent = MkCirculateNotifyEvent{event_CirculateNotifyEvent
                                                   :: WINDOW,
                                                   window_CirculateNotifyEvent :: WINDOW,
                                                   place_CirculateNotifyEvent :: Place}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event CirculateNotifyEvent
 
instance Deserialize CirculateNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               event <- deserialize
               window <- deserialize
               skip 4
               place <- liftM fromValue (deserialize :: Get Word8)
               skip 3
               return (MkCirculateNotifyEvent event window place)
 
data CirculateRequestEvent = MkCirculateRequestEvent{event_CirculateRequestEvent
                                                     :: WINDOW,
                                                     window_CirculateRequestEvent :: WINDOW,
                                                     place_CirculateRequestEvent :: Place}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event CirculateRequestEvent
 
instance Deserialize CirculateRequestEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               event <- deserialize
               window <- deserialize
               skip 4
               place <- liftM fromValue (deserialize :: Get Word8)
               skip 3
               return (MkCirculateRequestEvent event window place)
 
data Property = PropertyNewValue
              | PropertyDelete
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Property where
        toValue PropertyNewValue{} = 0
        toValue PropertyDelete{} = 1
        fromValue 0 = PropertyNewValue
        fromValue 1 = PropertyDelete
 
data PropertyNotifyEvent = MkPropertyNotifyEvent{window_PropertyNotifyEvent
                                                 :: WINDOW,
                                                 atom_PropertyNotifyEvent :: ATOM,
                                                 time_PropertyNotifyEvent :: TIMESTAMP,
                                                 state_PropertyNotifyEvent :: Property}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event PropertyNotifyEvent
 
instance Deserialize PropertyNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               window <- deserialize
               atom <- deserialize
               time <- deserialize
               state <- liftM fromValue (deserialize :: Get Word8)
               skip 3
               return (MkPropertyNotifyEvent window atom time state)
 
data SelectionClearEvent = MkSelectionClearEvent{time_SelectionClearEvent
                                                 :: TIMESTAMP,
                                                 owner_SelectionClearEvent :: WINDOW,
                                                 selection_SelectionClearEvent :: ATOM}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event SelectionClearEvent
 
instance Deserialize SelectionClearEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               time <- deserialize
               owner <- deserialize
               selection <- deserialize
               return (MkSelectionClearEvent time owner selection)
 
data Time = TimeCurrentTime
          deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Time where
        toValue TimeCurrentTime{} = 0
        fromValue 0 = TimeCurrentTime
 
data Atom = AtomNone
          | AtomAny
          | AtomPRIMARY
          | AtomSECONDARY
          | AtomARC
          | AtomATOM
          | AtomBITMAP
          | AtomCARDINAL
          | AtomCOLORMAP
          | AtomCURSOR
          | AtomCUT_BUFFER0
          | AtomCUT_BUFFER1
          | AtomCUT_BUFFER2
          | AtomCUT_BUFFER3
          | AtomCUT_BUFFER4
          | AtomCUT_BUFFER5
          | AtomCUT_BUFFER6
          | AtomCUT_BUFFER7
          | AtomDRAWABLE
          | AtomFONT
          | AtomINTEGER
          | AtomPIXMAP
          | AtomPOINT
          | AtomRECTANGLE
          | AtomRESOURCE_MANAGER
          | AtomRGB_COLOR_MAP
          | AtomRGB_BEST_MAP
          | AtomRGB_BLUE_MAP
          | AtomRGB_DEFAULT_MAP
          | AtomRGB_GRAY_MAP
          | AtomRGB_GREEN_MAP
          | AtomRGB_RED_MAP
          | AtomSTRING
          | AtomVISUALID
          | AtomWINDOW
          | AtomWM_COMMAND
          | AtomWM_HINTS
          | AtomWM_CLIENT_MACHINE
          | AtomWM_ICON_NAME
          | AtomWM_ICON_SIZE
          | AtomWM_NAME
          | AtomWM_NORMAL_HINTS
          | AtomWM_SIZE_HINTS
          | AtomWM_ZOOM_HINTS
          | AtomMIN_SPACE
          | AtomNORM_SPACE
          | AtomMAX_SPACE
          | AtomEND_SPACE
          | AtomSUPERSCRIPT_X
          | AtomSUPERSCRIPT_Y
          | AtomSUBSCRIPT_X
          | AtomSUBSCRIPT_Y
          | AtomUNDERLINE_POSITION
          | AtomUNDERLINE_THICKNESS
          | AtomSTRIKEOUT_ASCENT
          | AtomSTRIKEOUT_DESCENT
          | AtomITALIC_ANGLE
          | AtomX_HEIGHT
          | AtomQUAD_WIDTH
          | AtomWEIGHT
          | AtomPOINT_SIZE
          | AtomRESOLUTION
          | AtomCOPYRIGHT
          | AtomNOTICE
          | AtomFONT_NAME
          | AtomFAMILY_NAME
          | AtomFULL_NAME
          | AtomCAP_HEIGHT
          | AtomWM_CLASS
          | AtomWM_TRANSIENT_FOR
          deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Atom where
        toValue AtomNone{} = 0
        toValue AtomAny{} = 0
        toValue AtomPRIMARY{} = 1
        toValue AtomSECONDARY{} = 2
        toValue AtomARC{} = 3
        toValue AtomATOM{} = 4
        toValue AtomBITMAP{} = 5
        toValue AtomCARDINAL{} = 6
        toValue AtomCOLORMAP{} = 7
        toValue AtomCURSOR{} = 8
        toValue AtomCUT_BUFFER0{} = 9
        toValue AtomCUT_BUFFER1{} = 10
        toValue AtomCUT_BUFFER2{} = 11
        toValue AtomCUT_BUFFER3{} = 12
        toValue AtomCUT_BUFFER4{} = 13
        toValue AtomCUT_BUFFER5{} = 14
        toValue AtomCUT_BUFFER6{} = 15
        toValue AtomCUT_BUFFER7{} = 16
        toValue AtomDRAWABLE{} = 17
        toValue AtomFONT{} = 18
        toValue AtomINTEGER{} = 19
        toValue AtomPIXMAP{} = 20
        toValue AtomPOINT{} = 21
        toValue AtomRECTANGLE{} = 22
        toValue AtomRESOURCE_MANAGER{} = 23
        toValue AtomRGB_COLOR_MAP{} = 24
        toValue AtomRGB_BEST_MAP{} = 25
        toValue AtomRGB_BLUE_MAP{} = 26
        toValue AtomRGB_DEFAULT_MAP{} = 27
        toValue AtomRGB_GRAY_MAP{} = 28
        toValue AtomRGB_GREEN_MAP{} = 29
        toValue AtomRGB_RED_MAP{} = 30
        toValue AtomSTRING{} = 31
        toValue AtomVISUALID{} = 32
        toValue AtomWINDOW{} = 33
        toValue AtomWM_COMMAND{} = 34
        toValue AtomWM_HINTS{} = 35
        toValue AtomWM_CLIENT_MACHINE{} = 36
        toValue AtomWM_ICON_NAME{} = 37
        toValue AtomWM_ICON_SIZE{} = 38
        toValue AtomWM_NAME{} = 39
        toValue AtomWM_NORMAL_HINTS{} = 40
        toValue AtomWM_SIZE_HINTS{} = 41
        toValue AtomWM_ZOOM_HINTS{} = 42
        toValue AtomMIN_SPACE{} = 43
        toValue AtomNORM_SPACE{} = 44
        toValue AtomMAX_SPACE{} = 45
        toValue AtomEND_SPACE{} = 46
        toValue AtomSUPERSCRIPT_X{} = 47
        toValue AtomSUPERSCRIPT_Y{} = 48
        toValue AtomSUBSCRIPT_X{} = 49
        toValue AtomSUBSCRIPT_Y{} = 50
        toValue AtomUNDERLINE_POSITION{} = 51
        toValue AtomUNDERLINE_THICKNESS{} = 52
        toValue AtomSTRIKEOUT_ASCENT{} = 53
        toValue AtomSTRIKEOUT_DESCENT{} = 54
        toValue AtomITALIC_ANGLE{} = 55
        toValue AtomX_HEIGHT{} = 56
        toValue AtomQUAD_WIDTH{} = 57
        toValue AtomWEIGHT{} = 58
        toValue AtomPOINT_SIZE{} = 59
        toValue AtomRESOLUTION{} = 60
        toValue AtomCOPYRIGHT{} = 61
        toValue AtomNOTICE{} = 62
        toValue AtomFONT_NAME{} = 63
        toValue AtomFAMILY_NAME{} = 64
        toValue AtomFULL_NAME{} = 65
        toValue AtomCAP_HEIGHT{} = 66
        toValue AtomWM_CLASS{} = 67
        toValue AtomWM_TRANSIENT_FOR{} = 68
        fromValue 0 = AtomNone
        fromValue 0 = AtomAny
        fromValue 1 = AtomPRIMARY
        fromValue 2 = AtomSECONDARY
        fromValue 3 = AtomARC
        fromValue 4 = AtomATOM
        fromValue 5 = AtomBITMAP
        fromValue 6 = AtomCARDINAL
        fromValue 7 = AtomCOLORMAP
        fromValue 8 = AtomCURSOR
        fromValue 9 = AtomCUT_BUFFER0
        fromValue 10 = AtomCUT_BUFFER1
        fromValue 11 = AtomCUT_BUFFER2
        fromValue 12 = AtomCUT_BUFFER3
        fromValue 13 = AtomCUT_BUFFER4
        fromValue 14 = AtomCUT_BUFFER5
        fromValue 15 = AtomCUT_BUFFER6
        fromValue 16 = AtomCUT_BUFFER7
        fromValue 17 = AtomDRAWABLE
        fromValue 18 = AtomFONT
        fromValue 19 = AtomINTEGER
        fromValue 20 = AtomPIXMAP
        fromValue 21 = AtomPOINT
        fromValue 22 = AtomRECTANGLE
        fromValue 23 = AtomRESOURCE_MANAGER
        fromValue 24 = AtomRGB_COLOR_MAP
        fromValue 25 = AtomRGB_BEST_MAP
        fromValue 26 = AtomRGB_BLUE_MAP
        fromValue 27 = AtomRGB_DEFAULT_MAP
        fromValue 28 = AtomRGB_GRAY_MAP
        fromValue 29 = AtomRGB_GREEN_MAP
        fromValue 30 = AtomRGB_RED_MAP
        fromValue 31 = AtomSTRING
        fromValue 32 = AtomVISUALID
        fromValue 33 = AtomWINDOW
        fromValue 34 = AtomWM_COMMAND
        fromValue 35 = AtomWM_HINTS
        fromValue 36 = AtomWM_CLIENT_MACHINE
        fromValue 37 = AtomWM_ICON_NAME
        fromValue 38 = AtomWM_ICON_SIZE
        fromValue 39 = AtomWM_NAME
        fromValue 40 = AtomWM_NORMAL_HINTS
        fromValue 41 = AtomWM_SIZE_HINTS
        fromValue 42 = AtomWM_ZOOM_HINTS
        fromValue 43 = AtomMIN_SPACE
        fromValue 44 = AtomNORM_SPACE
        fromValue 45 = AtomMAX_SPACE
        fromValue 46 = AtomEND_SPACE
        fromValue 47 = AtomSUPERSCRIPT_X
        fromValue 48 = AtomSUPERSCRIPT_Y
        fromValue 49 = AtomSUBSCRIPT_X
        fromValue 50 = AtomSUBSCRIPT_Y
        fromValue 51 = AtomUNDERLINE_POSITION
        fromValue 52 = AtomUNDERLINE_THICKNESS
        fromValue 53 = AtomSTRIKEOUT_ASCENT
        fromValue 54 = AtomSTRIKEOUT_DESCENT
        fromValue 55 = AtomITALIC_ANGLE
        fromValue 56 = AtomX_HEIGHT
        fromValue 57 = AtomQUAD_WIDTH
        fromValue 58 = AtomWEIGHT
        fromValue 59 = AtomPOINT_SIZE
        fromValue 60 = AtomRESOLUTION
        fromValue 61 = AtomCOPYRIGHT
        fromValue 62 = AtomNOTICE
        fromValue 63 = AtomFONT_NAME
        fromValue 64 = AtomFAMILY_NAME
        fromValue 65 = AtomFULL_NAME
        fromValue 66 = AtomCAP_HEIGHT
        fromValue 67 = AtomWM_CLASS
        fromValue 68 = AtomWM_TRANSIENT_FOR
 
data SelectionRequestEvent = MkSelectionRequestEvent{time_SelectionRequestEvent
                                                     :: TIMESTAMP,
                                                     owner_SelectionRequestEvent :: WINDOW,
                                                     requestor_SelectionRequestEvent :: WINDOW,
                                                     selection_SelectionRequestEvent :: ATOM,
                                                     target_SelectionRequestEvent :: ATOM,
                                                     property_SelectionRequestEvent :: ATOM}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event SelectionRequestEvent
 
instance Deserialize SelectionRequestEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               time <- deserialize
               owner <- deserialize
               requestor <- deserialize
               selection <- deserialize
               target <- deserialize
               property <- deserialize
               return
                 (MkSelectionRequestEvent time owner requestor selection target
                    property)
 
data SelectionNotifyEvent = MkSelectionNotifyEvent{time_SelectionNotifyEvent
                                                   :: TIMESTAMP,
                                                   requestor_SelectionNotifyEvent :: WINDOW,
                                                   selection_SelectionNotifyEvent :: ATOM,
                                                   target_SelectionNotifyEvent :: ATOM,
                                                   property_SelectionNotifyEvent :: ATOM}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event SelectionNotifyEvent
 
instance Deserialize SelectionNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               time <- deserialize
               requestor <- deserialize
               selection <- deserialize
               target <- deserialize
               property <- deserialize
               return
                 (MkSelectionNotifyEvent time requestor selection target property)
 
data ColormapState = ColormapStateUninstalled
                   | ColormapStateInstalled
                   deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum ColormapState where
        toValue ColormapStateUninstalled{} = 0
        toValue ColormapStateInstalled{} = 1
        fromValue 0 = ColormapStateUninstalled
        fromValue 1 = ColormapStateInstalled
 
data Colormap = ColormapNone
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Colormap where
        toValue ColormapNone{} = 0
        fromValue 0 = ColormapNone
 
data ColormapNotifyEvent = MkColormapNotifyEvent{window_ColormapNotifyEvent
                                                 :: WINDOW,
                                                 colormap_ColormapNotifyEvent :: COLORMAP,
                                                 new_ColormapNotifyEvent :: Bool,
                                                 state_ColormapNotifyEvent :: ColormapState}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ColormapNotifyEvent
 
instance Deserialize ColormapNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               window <- deserialize
               colormap <- deserialize
               new <- deserialize
               state <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               return (MkColormapNotifyEvent window colormap new state)
 
data ClientMessageEvent = MkClientMessageEvent{format_ClientMessageEvent
                                               :: Word8,
                                               window_ClientMessageEvent :: WINDOW,
                                               type_ClientMessageEvent :: ATOM,
                                               data_ClientMessageEvent :: ClientMessageData}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event ClientMessageEvent
 
instance Deserialize ClientMessageEvent where
        deserialize
          = do skip 1
               format <- deserialize
               skip 2
               window <- deserialize
               type_ <- deserialize
               data_ <- deserializeClientData (clientDataFormatToType format)
               return (MkClientMessageEvent format window type_ data_)
 
data Mapping = MappingModifier
             | MappingKeyboard
             | MappingPointer
             deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Mapping where
        toValue MappingModifier{} = 0
        toValue MappingKeyboard{} = 1
        toValue MappingPointer{} = 2
        fromValue 0 = MappingModifier
        fromValue 1 = MappingKeyboard
        fromValue 2 = MappingPointer
 
data MappingNotifyEvent = MkMappingNotifyEvent{request_MappingNotifyEvent
                                               :: Mapping,
                                               first_keycode_MappingNotifyEvent :: KEYCODE,
                                               count_MappingNotifyEvent :: Word8}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Event MappingNotifyEvent
 
instance Deserialize MappingNotifyEvent where
        deserialize
          = do skip 1
               skip 1
               skip 2
               request <- liftM fromValue (deserialize :: Get Word8)
               first_keycode <- deserialize
               count <- deserialize
               skip 1
               return (MkMappingNotifyEvent request first_keycode count)
 
data RequestError = MkRequestError{bad_value_RequestError ::
                                   Word32,
                                   minor_opcode_RequestError :: Word16,
                                   major_opcode_RequestError :: Word8}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error RequestError
 
instance Deserialize RequestError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkRequestError bad_value minor_opcode major_opcode)
 
data ValueError = MkValueError{bad_value_ValueError :: Word32,
                               minor_opcode_ValueError :: Word16,
                               major_opcode_ValueError :: Word8}
                deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error ValueError
 
instance Deserialize ValueError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkValueError bad_value minor_opcode major_opcode)
 
data WindowError = MkWindowError{bad_value_WindowError :: Word32,
                                 minor_opcode_WindowError :: Word16,
                                 major_opcode_WindowError :: Word8}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error WindowError
 
instance Deserialize WindowError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkWindowError bad_value minor_opcode major_opcode)
 
data PixmapError = MkPixmapError{bad_value_PixmapError :: Word32,
                                 minor_opcode_PixmapError :: Word16,
                                 major_opcode_PixmapError :: Word8}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error PixmapError
 
instance Deserialize PixmapError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkPixmapError bad_value minor_opcode major_opcode)
 
data AtomError = MkAtomError{bad_value_AtomError :: Word32,
                             minor_opcode_AtomError :: Word16, major_opcode_AtomError :: Word8}
               deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error AtomError
 
instance Deserialize AtomError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkAtomError bad_value minor_opcode major_opcode)
 
data CursorError = MkCursorError{bad_value_CursorError :: Word32,
                                 minor_opcode_CursorError :: Word16,
                                 major_opcode_CursorError :: Word8}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error CursorError
 
instance Deserialize CursorError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkCursorError bad_value minor_opcode major_opcode)
 
data FontError = MkFontError{bad_value_FontError :: Word32,
                             minor_opcode_FontError :: Word16, major_opcode_FontError :: Word8}
               deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error FontError
 
instance Deserialize FontError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkFontError bad_value minor_opcode major_opcode)
 
data MatchError = MkMatchError{bad_value_MatchError :: Word32,
                               minor_opcode_MatchError :: Word16,
                               major_opcode_MatchError :: Word8}
                deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error MatchError
 
instance Deserialize MatchError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkMatchError bad_value minor_opcode major_opcode)
 
data DrawableError = MkDrawableError{bad_value_DrawableError ::
                                     Word32,
                                     minor_opcode_DrawableError :: Word16,
                                     major_opcode_DrawableError :: Word8}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error DrawableError
 
instance Deserialize DrawableError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkDrawableError bad_value minor_opcode major_opcode)
 
data AccessError = MkAccessError{bad_value_AccessError :: Word32,
                                 minor_opcode_AccessError :: Word16,
                                 major_opcode_AccessError :: Word8}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error AccessError
 
instance Deserialize AccessError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkAccessError bad_value minor_opcode major_opcode)
 
data AllocError = MkAllocError{bad_value_AllocError :: Word32,
                               minor_opcode_AllocError :: Word16,
                               major_opcode_AllocError :: Word8}
                deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error AllocError
 
instance Deserialize AllocError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkAllocError bad_value minor_opcode major_opcode)
 
data ColormapError = MkColormapError{bad_value_ColormapError ::
                                     Word32,
                                     minor_opcode_ColormapError :: Word16,
                                     major_opcode_ColormapError :: Word8}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error ColormapError
 
instance Deserialize ColormapError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkColormapError bad_value minor_opcode major_opcode)
 
data GContextError = MkGContextError{bad_value_GContextError ::
                                     Word32,
                                     minor_opcode_GContextError :: Word16,
                                     major_opcode_GContextError :: Word8}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error GContextError
 
instance Deserialize GContextError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkGContextError bad_value minor_opcode major_opcode)
 
data IDChoiceError = MkIDChoiceError{bad_value_IDChoiceError ::
                                     Word32,
                                     minor_opcode_IDChoiceError :: Word16,
                                     major_opcode_IDChoiceError :: Word8}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error IDChoiceError
 
instance Deserialize IDChoiceError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkIDChoiceError bad_value minor_opcode major_opcode)
 
data NameError = MkNameError{bad_value_NameError :: Word32,
                             minor_opcode_NameError :: Word16, major_opcode_NameError :: Word8}
               deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error NameError
 
instance Deserialize NameError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkNameError bad_value minor_opcode major_opcode)
 
data LengthError = MkLengthError{bad_value_LengthError :: Word32,
                                 minor_opcode_LengthError :: Word16,
                                 major_opcode_LengthError :: Word8}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error LengthError
 
instance Deserialize LengthError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkLengthError bad_value minor_opcode major_opcode)
 
data ImplementationError = MkImplementationError{bad_value_ImplementationError
                                                 :: Word32,
                                                 minor_opcode_ImplementationError :: Word16,
                                                 major_opcode_ImplementationError :: Word8}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Graphics.XHB.Shared.Error ImplementationError
 
instance Deserialize ImplementationError where
        deserialize
          = do skip 4
               bad_value <- deserialize
               minor_opcode <- deserialize
               major_opcode <- deserialize
               skip 1
               return (MkImplementationError bad_value minor_opcode major_opcode)
 
data WindowClass = WindowClassCopyFromParent
                 | WindowClassInputOutput
                 | WindowClassInputOnly
                 deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum WindowClass where
        toValue WindowClassCopyFromParent{} = 0
        toValue WindowClassInputOutput{} = 1
        toValue WindowClassInputOnly{} = 2
        fromValue 0 = WindowClassCopyFromParent
        fromValue 1 = WindowClassInputOutput
        fromValue 2 = WindowClassInputOnly
 
data CW = CWBackPixmap
        | CWBackPixel
        | CWBorderPixmap
        | CWBorderPixel
        | CWBitGravity
        | CWWinGravity
        | CWBackingStore
        | CWBackingPlanes
        | CWBackingPixel
        | CWOverrideRedirect
        | CWSaveUnder
        | CWEventMask
        | CWDontPropagate
        | CWColormap
        | CWCursor
        deriving (Show, Eq, Ord, Enum)
 
instance BitEnum CW where
        toBit CWBackPixmap{} = 0
        toBit CWBackPixel{} = 1
        toBit CWBorderPixmap{} = 2
        toBit CWBorderPixel{} = 3
        toBit CWBitGravity{} = 4
        toBit CWWinGravity{} = 5
        toBit CWBackingStore{} = 6
        toBit CWBackingPlanes{} = 7
        toBit CWBackingPixel{} = 8
        toBit CWOverrideRedirect{} = 9
        toBit CWSaveUnder{} = 10
        toBit CWEventMask{} = 11
        toBit CWDontPropagate{} = 12
        toBit CWColormap{} = 13
        toBit CWCursor{} = 14
        fromBit 0 = CWBackPixmap
        fromBit 1 = CWBackPixel
        fromBit 2 = CWBorderPixmap
        fromBit 3 = CWBorderPixel
        fromBit 4 = CWBitGravity
        fromBit 5 = CWWinGravity
        fromBit 6 = CWBackingStore
        fromBit 7 = CWBackingPlanes
        fromBit 8 = CWBackingPixel
        fromBit 9 = CWOverrideRedirect
        fromBit 10 = CWSaveUnder
        fromBit 11 = CWEventMask
        fromBit 12 = CWDontPropagate
        fromBit 13 = CWColormap
        fromBit 14 = CWCursor
 
data BackPixmap = BackPixmapNone
                | BackPixmapParentRelative
                deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum BackPixmap where
        toValue BackPixmapNone{} = 0
        toValue BackPixmapParentRelative{} = 1
        fromValue 0 = BackPixmapNone
        fromValue 1 = BackPixmapParentRelative
 
data Gravity = GravityBitForget
             | GravityWinUnmap
             | GravityNorthWest
             | GravityNorth
             | GravityNorthEast
             | GravityWest
             | GravityCenter
             | GravityEast
             | GravitySouthWest
             | GravitySouth
             | GravitySouthEast
             | GravityStatic
             deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Gravity where
        toValue GravityBitForget{} = 0
        toValue GravityWinUnmap{} = 0
        toValue GravityNorthWest{} = 1
        toValue GravityNorth{} = 2
        toValue GravityNorthEast{} = 3
        toValue GravityWest{} = 4
        toValue GravityCenter{} = 5
        toValue GravityEast{} = 6
        toValue GravitySouthWest{} = 7
        toValue GravitySouth{} = 8
        toValue GravitySouthEast{} = 9
        toValue GravityStatic{} = 10
        fromValue 0 = GravityBitForget
        fromValue 0 = GravityWinUnmap
        fromValue 1 = GravityNorthWest
        fromValue 2 = GravityNorth
        fromValue 3 = GravityNorthEast
        fromValue 4 = GravityWest
        fromValue 5 = GravityCenter
        fromValue 6 = GravityEast
        fromValue 7 = GravitySouthWest
        fromValue 8 = GravitySouth
        fromValue 9 = GravitySouthEast
        fromValue 10 = GravityStatic
 
data CreateWindow = MkCreateWindow{depth_CreateWindow :: Word8,
                                   wid_CreateWindow :: WINDOW, parent_CreateWindow :: WINDOW,
                                   x_CreateWindow :: Int16, y_CreateWindow :: Int16,
                                   width_CreateWindow :: Word16, height_CreateWindow :: Word16,
                                   border_width_CreateWindow :: Word16,
                                   class_CreateWindow :: WindowClass,
                                   visual_CreateWindow :: VISUALID,
                                   value_CreateWindow :: ValueParam Word32}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CreateWindow where
        serialize x
          = do putWord8 1
               serialize (depth_CreateWindow x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (wid_CreateWindow x)
               serialize (parent_CreateWindow x)
               serialize (x_CreateWindow x)
               serialize (y_CreateWindow x)
               serialize (width_CreateWindow x)
               serialize (height_CreateWindow x)
               serialize (border_width_CreateWindow x)
               serialize (toValue (class_CreateWindow x) :: Word16)
               serialize (visual_CreateWindow x)
               serialize (value_CreateWindow x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (depth_CreateWindow x) + size (wid_CreateWindow x) +
              size (parent_CreateWindow x)
              + size (x_CreateWindow x)
              + size (y_CreateWindow x)
              + size (width_CreateWindow x)
              + size (height_CreateWindow x)
              + size (border_width_CreateWindow x)
              + size (undefined :: Word16)
              + size (visual_CreateWindow x)
              + size (value_CreateWindow x)
 
data ChangeWindowAttributes = MkChangeWindowAttributes{window_ChangeWindowAttributes
                                                       :: WINDOW,
                                                       value_ChangeWindowAttributes ::
                                                       ValueParam Word32}
                            deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangeWindowAttributes where
        serialize x
          = do putWord8 2
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_ChangeWindowAttributes x)
               serialize (value_ChangeWindowAttributes x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (window_ChangeWindowAttributes x) +
              size (value_ChangeWindowAttributes x)
 
data MapState = MapStateUnmapped
              | MapStateUnviewable
              | MapStateViewable
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum MapState where
        toValue MapStateUnmapped{} = 0
        toValue MapStateUnviewable{} = 1
        toValue MapStateViewable{} = 2
        fromValue 0 = MapStateUnmapped
        fromValue 1 = MapStateUnviewable
        fromValue 2 = MapStateViewable
 
data GetWindowAttributes = MkGetWindowAttributes{window_GetWindowAttributes
                                                 :: WINDOW}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetWindowAttributes where
        serialize x
          = do putWord8 3
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_GetWindowAttributes x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_GetWindowAttributes x)
 
data GetWindowAttributesReply = MkGetWindowAttributesReply{backing_store_GetWindowAttributesReply
                                                           :: BackingStore,
                                                           visual_GetWindowAttributesReply ::
                                                           VISUALID,
                                                           class_GetWindowAttributesReply ::
                                                           WindowClass,
                                                           bit_gravity_GetWindowAttributesReply ::
                                                           Gravity,
                                                           win_gravity_GetWindowAttributesReply ::
                                                           Gravity,
                                                           backing_planes_GetWindowAttributesReply
                                                           :: Word32,
                                                           backing_pixel_GetWindowAttributesReply ::
                                                           Word32,
                                                           save_under_GetWindowAttributesReply ::
                                                           Bool,
                                                           map_is_installed_GetWindowAttributesReply
                                                           :: Bool,
                                                           map_state_GetWindowAttributesReply ::
                                                           MapState,
                                                           override_redirect_GetWindowAttributesReply
                                                           :: Bool,
                                                           colormap_GetWindowAttributesReply ::
                                                           COLORMAP,
                                                           all_event_masks_GetWindowAttributesReply
                                                           :: [EventMask],
                                                           your_event_mask_GetWindowAttributesReply
                                                           :: [EventMask],
                                                           do_not_propagate_mask_GetWindowAttributesReply
                                                           :: [EventMask]}
                              deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetWindowAttributesReply where
        deserialize
          = do skip 1
               backing_store <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               visual <- deserialize
               class_ <- liftM fromValue (deserialize :: Get Word16)
               bit_gravity <- liftM fromValue (deserialize :: Get Word8)
               win_gravity <- liftM fromValue (deserialize :: Get Word8)
               backing_planes <- deserialize
               backing_pixel <- deserialize
               save_under <- deserialize
               map_is_installed <- deserialize
               map_state <- liftM fromValue (deserialize :: Get Word8)
               override_redirect <- deserialize
               colormap <- deserialize
               all_event_masks <- liftM fromMask (deserialize :: Get Word32)
               your_event_mask <- liftM fromMask (deserialize :: Get Word32)
               do_not_propagate_mask <- liftM fromMask (deserialize :: Get Word16)
               skip 2
               let _ = isCard32 length
               return
                 (MkGetWindowAttributesReply backing_store visual class_ bit_gravity
                    win_gravity
                    backing_planes
                    backing_pixel
                    save_under
                    map_is_installed
                    map_state
                    override_redirect
                    colormap
                    all_event_masks
                    your_event_mask
                    do_not_propagate_mask)
 
data DestroyWindow = MkDestroyWindow{window_DestroyWindow ::
                                     WINDOW}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize DestroyWindow where
        serialize x
          = do putWord8 4
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_DestroyWindow x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_DestroyWindow x)
 
data DestroySubwindows = MkDestroySubwindows{window_DestroySubwindows
                                             :: WINDOW}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize DestroySubwindows where
        serialize x
          = do putWord8 5
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_DestroySubwindows x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_DestroySubwindows x)
 
data SetMode = SetModeInsert
             | SetModeDelete
             deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum SetMode where
        toValue SetModeInsert{} = 0
        toValue SetModeDelete{} = 1
        fromValue 0 = SetModeInsert
        fromValue 1 = SetModeDelete
 
data ChangeSaveSet = MkChangeSaveSet{mode_ChangeSaveSet :: SetMode,
                                     window_ChangeSaveSet :: WINDOW}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangeSaveSet where
        serialize x
          = do putWord8 6
               serialize (toValue (mode_ChangeSaveSet x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_ChangeSaveSet x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (window_ChangeSaveSet x)
 
data ReparentWindow = MkReparentWindow{window_ReparentWindow ::
                                       WINDOW,
                                       parent_ReparentWindow :: WINDOW, x_ReparentWindow :: Int16,
                                       y_ReparentWindow :: Int16}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ReparentWindow where
        serialize x
          = do putWord8 7
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_ReparentWindow x)
               serialize (parent_ReparentWindow x)
               serialize (x_ReparentWindow x)
               serialize (y_ReparentWindow x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (window_ReparentWindow x) +
              size (parent_ReparentWindow x)
              + size (x_ReparentWindow x)
              + size (y_ReparentWindow x)
 
data MapWindow = MkMapWindow{window_MapWindow :: WINDOW}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize MapWindow where
        serialize x
          = do putWord8 8
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_MapWindow x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_MapWindow x)
 
data MapSubwindows = MkMapSubwindows{window_MapSubwindows ::
                                     WINDOW}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize MapSubwindows where
        serialize x
          = do putWord8 9
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_MapSubwindows x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_MapSubwindows x)
 
data UnmapWindow = MkUnmapWindow{window_UnmapWindow :: WINDOW}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize UnmapWindow where
        serialize x
          = do putWord8 10
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_UnmapWindow x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_UnmapWindow x)
 
data UnmapSubwindows = MkUnmapSubwindows{window_UnmapSubwindows ::
                                         WINDOW}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Serialize UnmapSubwindows where
        serialize x
          = do putWord8 11
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_UnmapSubwindows x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_UnmapSubwindows x)
 
data ConfigWindow = ConfigWindowX
                  | ConfigWindowY
                  | ConfigWindowWidth
                  | ConfigWindowHeight
                  | ConfigWindowBorderWidth
                  | ConfigWindowSibling
                  | ConfigWindowStackMode
                  deriving (Show, Eq, Ord, Enum)
 
instance BitEnum ConfigWindow where
        toBit ConfigWindowX{} = 0
        toBit ConfigWindowY{} = 1
        toBit ConfigWindowWidth{} = 2
        toBit ConfigWindowHeight{} = 3
        toBit ConfigWindowBorderWidth{} = 4
        toBit ConfigWindowSibling{} = 5
        toBit ConfigWindowStackMode{} = 6
        fromBit 0 = ConfigWindowX
        fromBit 1 = ConfigWindowY
        fromBit 2 = ConfigWindowWidth
        fromBit 3 = ConfigWindowHeight
        fromBit 4 = ConfigWindowBorderWidth
        fromBit 5 = ConfigWindowSibling
        fromBit 6 = ConfigWindowStackMode
 
data StackMode = StackModeAbove
               | StackModeBelow
               | StackModeTopIf
               | StackModeBottomIf
               | StackModeOpposite
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum StackMode where
        toValue StackModeAbove{} = 0
        toValue StackModeBelow{} = 1
        toValue StackModeTopIf{} = 2
        toValue StackModeBottomIf{} = 3
        toValue StackModeOpposite{} = 4
        fromValue 0 = StackModeAbove
        fromValue 1 = StackModeBelow
        fromValue 2 = StackModeTopIf
        fromValue 3 = StackModeBottomIf
        fromValue 4 = StackModeOpposite
 
data ConfigureWindow = MkConfigureWindow{window_ConfigureWindow ::
                                         WINDOW,
                                         value_ConfigureWindow :: ValueParam Word16}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ConfigureWindow where
        serialize x
          = do putWord8 12
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_ConfigureWindow x)
               serializeValueParam 2 (value_ConfigureWindow x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (window_ConfigureWindow x) +
              (size (value_ConfigureWindow x) + 2)
 
data Circulate = CirculateRaiseLowest
               | CirculateLowerHighest
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Circulate where
        toValue CirculateRaiseLowest{} = 0
        toValue CirculateLowerHighest{} = 1
        fromValue 0 = CirculateRaiseLowest
        fromValue 1 = CirculateLowerHighest
 
data CirculateWindow = MkCirculateWindow{direction_CirculateWindow
                                         :: Circulate,
                                         window_CirculateWindow :: WINDOW}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CirculateWindow where
        serialize x
          = do putWord8 13
               serialize (toValue (direction_CirculateWindow x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_CirculateWindow x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (window_CirculateWindow x)
 
data GetGeometry = MkGetGeometry{drawable_GetGeometry :: DRAWABLE}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetGeometry where
        serialize x
          = do putWord8 14
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_GetGeometry x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (drawable_GetGeometry x)
 
data GetGeometryReply = MkGetGeometryReply{depth_GetGeometryReply
                                           :: Word8,
                                           root_GetGeometryReply :: WINDOW,
                                           x_GetGeometryReply :: Int16, y_GetGeometryReply :: Int16,
                                           width_GetGeometryReply :: Word16,
                                           height_GetGeometryReply :: Word16,
                                           border_width_GetGeometryReply :: Word16}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetGeometryReply where
        deserialize
          = do skip 1
               depth <- deserialize
               skip 2
               length <- deserialize
               root <- deserialize
               x <- deserialize
               y <- deserialize
               width <- deserialize
               height <- deserialize
               border_width <- deserialize
               skip 2
               let _ = isCard32 length
               return
                 (MkGetGeometryReply depth root x y width height border_width)
 
data QueryTree = MkQueryTree{window_QueryTree :: WINDOW}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize QueryTree where
        serialize x
          = do putWord8 15
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_QueryTree x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_QueryTree x)
 
data QueryTreeReply = MkQueryTreeReply{root_QueryTreeReply ::
                                       WINDOW,
                                       parent_QueryTreeReply :: WINDOW,
                                       children_len_QueryTreeReply :: Word16,
                                       children_QueryTreeReply :: [WINDOW]}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryTreeReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               root <- deserialize
               parent <- deserialize
               children_len <- deserialize
               skip 14
               children <- deserializeList (fromIntegral children_len)
               let _ = isCard32 length
               return (MkQueryTreeReply root parent children_len children)
 
data InternAtom = MkInternAtom{only_if_exists_InternAtom :: Bool,
                               name_len_InternAtom :: Word16, name_InternAtom :: [CChar]}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize InternAtom where
        serialize x
          = do putWord8 16
               serialize (only_if_exists_InternAtom x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (name_len_InternAtom x)
               putSkip 2
               serializeList (name_InternAtom x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (only_if_exists_InternAtom x) +
              size (name_len_InternAtom x)
              + 2
              + sum (map size (name_InternAtom x))
 
data InternAtomReply = MkInternAtomReply{atom_InternAtomReply ::
                                         ATOM}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize InternAtomReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               atom <- deserialize
               let _ = isCard32 length
               return (MkInternAtomReply atom)
 
data GetAtomName = MkGetAtomName{atom_GetAtomName :: ATOM}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetAtomName where
        serialize x
          = do putWord8 17
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (atom_GetAtomName x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (atom_GetAtomName x)
 
data GetAtomNameReply = MkGetAtomNameReply{name_len_GetAtomNameReply
                                           :: Word16,
                                           name_GetAtomNameReply :: [CChar]}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetAtomNameReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               name_len <- deserialize
               skip 22
               name <- deserializeList (fromIntegral name_len)
               let _ = isCard32 length
               return (MkGetAtomNameReply name_len name)
 
data PropMode = PropModeReplace
              | PropModePrepend
              | PropModeAppend
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum PropMode where
        toValue PropModeReplace{} = 0
        toValue PropModePrepend{} = 1
        toValue PropModeAppend{} = 2
        fromValue 0 = PropModeReplace
        fromValue 1 = PropModePrepend
        fromValue 2 = PropModeAppend
 
data ChangeProperty = MkChangeProperty{mode_ChangeProperty ::
                                       PropMode,
                                       window_ChangeProperty :: WINDOW,
                                       property_ChangeProperty :: ATOM, type_ChangeProperty :: ATOM,
                                       format_ChangeProperty :: Word8,
                                       data_len_ChangeProperty :: Word32,
                                       data_ChangeProperty :: [Word8]}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangeProperty where
        serialize x
          = do putWord8 18
               serialize (toValue (mode_ChangeProperty x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_ChangeProperty x)
               serialize (property_ChangeProperty x)
               serialize (type_ChangeProperty x)
               serialize (format_ChangeProperty x)
               putSkip 3
               serialize (data_len_ChangeProperty x)
               serializeList (data_ChangeProperty x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (window_ChangeProperty x) +
              size (property_ChangeProperty x)
              + size (type_ChangeProperty x)
              + size (format_ChangeProperty x)
              + 3
              + size (data_len_ChangeProperty x)
              + sum (map size (data_ChangeProperty x))
 
data DeleteProperty = MkDeleteProperty{window_DeleteProperty ::
                                       WINDOW,
                                       property_DeleteProperty :: ATOM}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize DeleteProperty where
        serialize x
          = do putWord8 19
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_DeleteProperty x)
               serialize (property_DeleteProperty x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (window_DeleteProperty x) +
              size (property_DeleteProperty x)
 
data GetPropertyType = GetPropertyTypeAny
                     deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum GetPropertyType where
        toValue GetPropertyTypeAny{} = 0
        fromValue 0 = GetPropertyTypeAny
 
data GetProperty = MkGetProperty{delete_GetProperty :: Bool,
                                 window_GetProperty :: WINDOW, property_GetProperty :: ATOM,
                                 type_GetProperty :: ATOM, long_offset_GetProperty :: Word32,
                                 long_length_GetProperty :: Word32}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetProperty where
        serialize x
          = do putWord8 20
               serialize (delete_GetProperty x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_GetProperty x)
               serialize (property_GetProperty x)
               serialize (type_GetProperty x)
               serialize (long_offset_GetProperty x)
               serialize (long_length_GetProperty x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (delete_GetProperty x) + size (window_GetProperty x) +
              size (property_GetProperty x)
              + size (type_GetProperty x)
              + size (long_offset_GetProperty x)
              + size (long_length_GetProperty x)
 
data GetPropertyReply = MkGetPropertyReply{format_GetPropertyReply
                                           :: Word8,
                                           type_GetPropertyReply :: ATOM,
                                           bytes_after_GetPropertyReply :: Word32,
                                           value_len_GetPropertyReply :: Word32,
                                           value_GetPropertyReply :: [Word8]}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetPropertyReply where
        deserialize
          = do skip 1
               format <- deserialize
               skip 2
               length <- deserialize
               type_ <- deserialize
               bytes_after <- deserialize
               value_len <- deserialize
               skip 12
               value <- deserializeList
                          (fromIntegral
                             (fromIntegral (value_len * (fromIntegral (format `div` 8)))))
               let _ = isCard32 length
               return
                 (MkGetPropertyReply format type_ bytes_after value_len value)
 
data ListProperties = MkListProperties{window_ListProperties ::
                                       WINDOW}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ListProperties where
        serialize x
          = do putWord8 21
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_ListProperties x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_ListProperties x)
 
data ListPropertiesReply = MkListPropertiesReply{atoms_len_ListPropertiesReply
                                                 :: Word16,
                                                 atoms_ListPropertiesReply :: [ATOM]}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize ListPropertiesReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               atoms_len <- deserialize
               skip 22
               atoms <- deserializeList (fromIntegral atoms_len)
               let _ = isCard32 length
               return (MkListPropertiesReply atoms_len atoms)
 
data SetSelectionOwner = MkSetSelectionOwner{owner_SetSelectionOwner
                                             :: WINDOW,
                                             selection_SetSelectionOwner :: ATOM,
                                             time_SetSelectionOwner :: TIMESTAMP}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetSelectionOwner where
        serialize x
          = do putWord8 22
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (owner_SetSelectionOwner x)
               serialize (selection_SetSelectionOwner x)
               serialize (time_SetSelectionOwner x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (owner_SetSelectionOwner x) +
              size (selection_SetSelectionOwner x)
              + size (time_SetSelectionOwner x)
 
data GetSelectionOwner = MkGetSelectionOwner{selection_GetSelectionOwner
                                             :: ATOM}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetSelectionOwner where
        serialize x
          = do putWord8 23
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (selection_GetSelectionOwner x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (selection_GetSelectionOwner x)
 
data GetSelectionOwnerReply = MkGetSelectionOwnerReply{owner_GetSelectionOwnerReply
                                                       :: WINDOW}
                            deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetSelectionOwnerReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               owner <- deserialize
               let _ = isCard32 length
               return (MkGetSelectionOwnerReply owner)
 
data ConvertSelection = MkConvertSelection{requestor_ConvertSelection
                                           :: WINDOW,
                                           selection_ConvertSelection :: ATOM,
                                           target_ConvertSelection :: ATOM,
                                           property_ConvertSelection :: ATOM,
                                           time_ConvertSelection :: TIMESTAMP}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ConvertSelection where
        serialize x
          = do putWord8 24
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (requestor_ConvertSelection x)
               serialize (selection_ConvertSelection x)
               serialize (target_ConvertSelection x)
               serialize (property_ConvertSelection x)
               serialize (time_ConvertSelection x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (requestor_ConvertSelection x) +
              size (selection_ConvertSelection x)
              + size (target_ConvertSelection x)
              + size (property_ConvertSelection x)
              + size (time_ConvertSelection x)
 
data SendEventDest = SendEventDestPointerWindow
                   | SendEventDestItemFocus
                   deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum SendEventDest where
        toValue SendEventDestPointerWindow{} = 0
        toValue SendEventDestItemFocus{} = 1
        fromValue 0 = SendEventDestPointerWindow
        fromValue 1 = SendEventDestItemFocus
 
data SendEvent = MkSendEvent{propagate_SendEvent :: Bool,
                             destination_SendEvent :: WINDOW,
                             event_mask_SendEvent :: [EventMask], event_SendEvent :: [CChar]}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SendEvent where
        serialize x
          = do putWord8 25
               serialize (propagate_SendEvent x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (destination_SendEvent x)
               serialize (toMask (event_mask_SendEvent x) :: Word32)
               serializeList (event_SendEvent x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (propagate_SendEvent x) + size (destination_SendEvent x)
              + size (undefined :: Word32)
              + sum (map size (event_SendEvent x))
 
data GrabMode = GrabModeSync
              | GrabModeAsync
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum GrabMode where
        toValue GrabModeSync{} = 0
        toValue GrabModeAsync{} = 1
        fromValue 0 = GrabModeSync
        fromValue 1 = GrabModeAsync
 
data GrabStatus = GrabStatusSuccess
                | GrabStatusAlreadyGrabbed
                | GrabStatusInvalidTime
                | GrabStatusNotViewable
                | GrabStatusFrozen
                deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum GrabStatus where
        toValue GrabStatusSuccess{} = 0
        toValue GrabStatusAlreadyGrabbed{} = 1
        toValue GrabStatusInvalidTime{} = 2
        toValue GrabStatusNotViewable{} = 3
        toValue GrabStatusFrozen{} = 4
        fromValue 0 = GrabStatusSuccess
        fromValue 1 = GrabStatusAlreadyGrabbed
        fromValue 2 = GrabStatusInvalidTime
        fromValue 3 = GrabStatusNotViewable
        fromValue 4 = GrabStatusFrozen
 
data Cursor = CursorNone
            deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Cursor where
        toValue CursorNone{} = 0
        fromValue 0 = CursorNone
 
data GrabPointer = MkGrabPointer{owner_events_GrabPointer :: Bool,
                                 grab_window_GrabPointer :: WINDOW,
                                 event_mask_GrabPointer :: [EventMask],
                                 pointer_mode_GrabPointer :: GrabMode,
                                 keyboard_mode_GrabPointer :: GrabMode,
                                 confine_to_GrabPointer :: WINDOW, cursor_GrabPointer :: CURSOR,
                                 time_GrabPointer :: TIMESTAMP}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GrabPointer where
        serialize x
          = do putWord8 26
               serialize (owner_events_GrabPointer x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (grab_window_GrabPointer x)
               serialize (toMask (event_mask_GrabPointer x) :: Word16)
               serialize (toValue (pointer_mode_GrabPointer x) :: Word8)
               serialize (toValue (keyboard_mode_GrabPointer x) :: Word8)
               serialize (confine_to_GrabPointer x)
               serialize (cursor_GrabPointer x)
               serialize (time_GrabPointer x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (owner_events_GrabPointer x) +
              size (grab_window_GrabPointer x)
              + size (undefined :: Word16)
              + size (undefined :: Word8)
              + size (undefined :: Word8)
              + size (confine_to_GrabPointer x)
              + size (cursor_GrabPointer x)
              + size (time_GrabPointer x)
 
data GrabPointerReply = MkGrabPointerReply{status_GrabPointerReply
                                           :: GrabStatus}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GrabPointerReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               let _ = isCard32 length
               return (MkGrabPointerReply status)
 
data UngrabPointer = MkUngrabPointer{time_UngrabPointer ::
                                     TIMESTAMP}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize UngrabPointer where
        serialize x
          = do putWord8 27
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (time_UngrabPointer x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (time_UngrabPointer x)
 
data ButtonIndex = ButtonIndexAny
                 | ButtonIndex1
                 | ButtonIndex2
                 | ButtonIndex3
                 | ButtonIndex4
                 | ButtonIndex5
                 deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum ButtonIndex where
        toValue ButtonIndexAny{} = 0
        toValue ButtonIndex1{} = 1
        toValue ButtonIndex2{} = 2
        toValue ButtonIndex3{} = 3
        toValue ButtonIndex4{} = 4
        toValue ButtonIndex5{} = 5
        fromValue 0 = ButtonIndexAny
        fromValue 1 = ButtonIndex1
        fromValue 2 = ButtonIndex2
        fromValue 3 = ButtonIndex3
        fromValue 4 = ButtonIndex4
        fromValue 5 = ButtonIndex5
 
data GrabButton = MkGrabButton{owner_events_GrabButton :: Bool,
                               grab_window_GrabButton :: WINDOW,
                               event_mask_GrabButton :: [EventMask],
                               pointer_mode_GrabButton :: GrabMode,
                               keyboard_mode_GrabButton :: GrabMode,
                               confine_to_GrabButton :: WINDOW, cursor_GrabButton :: CURSOR,
                               button_GrabButton :: ButtonIndex,
                               modifiers_GrabButton :: [ModMask]}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GrabButton where
        serialize x
          = do putWord8 28
               serialize (owner_events_GrabButton x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (grab_window_GrabButton x)
               serialize (toMask (event_mask_GrabButton x) :: Word16)
               serialize (toValue (pointer_mode_GrabButton x) :: Word8)
               serialize (toValue (keyboard_mode_GrabButton x) :: Word8)
               serialize (confine_to_GrabButton x)
               serialize (cursor_GrabButton x)
               serialize (toValue (button_GrabButton x) :: Word8)
               putSkip 1
               serialize (toMask (modifiers_GrabButton x) :: Word16)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (owner_events_GrabButton x) +
              size (grab_window_GrabButton x)
              + size (undefined :: Word16)
              + size (undefined :: Word8)
              + size (undefined :: Word8)
              + size (confine_to_GrabButton x)
              + size (cursor_GrabButton x)
              + size (undefined :: Word8)
              + 1
              + size (undefined :: Word16)
 
data UngrabButton = MkUngrabButton{button_UngrabButton ::
                                   ButtonIndex,
                                   grab_window_UngrabButton :: WINDOW,
                                   modifiers_UngrabButton :: [ModMask]}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize UngrabButton where
        serialize x
          = do putWord8 29
               serialize (toValue (button_UngrabButton x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (grab_window_UngrabButton x)
               serialize (toMask (modifiers_UngrabButton x) :: Word16)
               putSkip 2
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (grab_window_UngrabButton x)
              + size (undefined :: Word16)
              + 2
 
data ChangeActivePointerGrab = MkChangeActivePointerGrab{cursor_ChangeActivePointerGrab
                                                         :: CURSOR,
                                                         time_ChangeActivePointerGrab :: TIMESTAMP,
                                                         event_mask_ChangeActivePointerGrab ::
                                                         [EventMask]}
                             deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangeActivePointerGrab where
        serialize x
          = do putWord8 30
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cursor_ChangeActivePointerGrab x)
               serialize (time_ChangeActivePointerGrab x)
               serialize (toMask (event_mask_ChangeActivePointerGrab x) :: Word16)
               putSkip 2
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cursor_ChangeActivePointerGrab x) +
              size (time_ChangeActivePointerGrab x)
              + size (undefined :: Word16)
              + 2
 
data GrabKeyboard = MkGrabKeyboard{owner_events_GrabKeyboard ::
                                   Bool,
                                   grab_window_GrabKeyboard :: WINDOW,
                                   time_GrabKeyboard :: TIMESTAMP,
                                   pointer_mode_GrabKeyboard :: GrabMode,
                                   keyboard_mode_GrabKeyboard :: GrabMode}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GrabKeyboard where
        serialize x
          = do putWord8 31
               serialize (owner_events_GrabKeyboard x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (grab_window_GrabKeyboard x)
               serialize (time_GrabKeyboard x)
               serialize (toValue (pointer_mode_GrabKeyboard x) :: Word8)
               serialize (toValue (keyboard_mode_GrabKeyboard x) :: Word8)
               putSkip 2
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (owner_events_GrabKeyboard x) +
              size (grab_window_GrabKeyboard x)
              + size (time_GrabKeyboard x)
              + size (undefined :: Word8)
              + size (undefined :: Word8)
              + 2
 
data GrabKeyboardReply = MkGrabKeyboardReply{status_GrabKeyboardReply
                                             :: GrabStatus}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GrabKeyboardReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               let _ = isCard32 length
               return (MkGrabKeyboardReply status)
 
data UngrabKeyboard = MkUngrabKeyboard{time_UngrabKeyboard ::
                                       TIMESTAMP}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize UngrabKeyboard where
        serialize x
          = do putWord8 32
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (time_UngrabKeyboard x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (time_UngrabKeyboard x)
 
data Grab = GrabAny
          deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Grab where
        toValue GrabAny{} = 0
        fromValue 0 = GrabAny
 
data GrabKey = MkGrabKey{owner_events_GrabKey :: Bool,
                         grab_window_GrabKey :: WINDOW, modifiers_GrabKey :: [ModMask],
                         key_GrabKey :: KEYCODE, pointer_mode_GrabKey :: GrabMode,
                         keyboard_mode_GrabKey :: GrabMode}
             deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GrabKey where
        serialize x
          = do putWord8 33
               serialize (owner_events_GrabKey x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (grab_window_GrabKey x)
               serialize (toMask (modifiers_GrabKey x) :: Word16)
               serialize (key_GrabKey x)
               serialize (toValue (pointer_mode_GrabKey x) :: Word8)
               serialize (toValue (keyboard_mode_GrabKey x) :: Word8)
               putSkip 3
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (owner_events_GrabKey x) + size (grab_window_GrabKey x)
              + size (undefined :: Word16)
              + size (key_GrabKey x)
              + size (undefined :: Word8)
              + size (undefined :: Word8)
              + 3
 
data UngrabKey = MkUngrabKey{key_UngrabKey :: KEYCODE,
                             grab_window_UngrabKey :: WINDOW, modifiers_UngrabKey :: [ModMask]}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize UngrabKey where
        serialize x
          = do putWord8 34
               serialize (key_UngrabKey x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (grab_window_UngrabKey x)
               serialize (toMask (modifiers_UngrabKey x) :: Word16)
               putSkip 2
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (key_UngrabKey x) + size (grab_window_UngrabKey x) +
              size (undefined :: Word16)
              + 2
 
data Allow = AllowAsyncPointer
           | AllowSyncPointer
           | AllowReplayPointer
           | AllowAsyncKeyboard
           | AllowSyncKeyboard
           | AllowReplayKeyboard
           | AllowAsyncBoth
           | AllowSyncBoth
           deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Allow where
        toValue AllowAsyncPointer{} = 0
        toValue AllowSyncPointer{} = 1
        toValue AllowReplayPointer{} = 2
        toValue AllowAsyncKeyboard{} = 3
        toValue AllowSyncKeyboard{} = 4
        toValue AllowReplayKeyboard{} = 5
        toValue AllowAsyncBoth{} = 6
        toValue AllowSyncBoth{} = 7
        fromValue 0 = AllowAsyncPointer
        fromValue 1 = AllowSyncPointer
        fromValue 2 = AllowReplayPointer
        fromValue 3 = AllowAsyncKeyboard
        fromValue 4 = AllowSyncKeyboard
        fromValue 5 = AllowReplayKeyboard
        fromValue 6 = AllowAsyncBoth
        fromValue 7 = AllowSyncBoth
 
data AllowEvents = MkAllowEvents{mode_AllowEvents :: Allow,
                                 time_AllowEvents :: TIMESTAMP}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize AllowEvents where
        serialize x
          = do putWord8 35
               serialize (toValue (mode_AllowEvents x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (time_AllowEvents x)
               putSkip (requiredPadding (size x))
        size x = 3 + size (undefined :: Word8) + size (time_AllowEvents x)
 
data GrabServer = MkGrabServer{}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GrabServer where
        serialize x
          = do putWord8 36
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data UngrabServer = MkUngrabServer{}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize UngrabServer where
        serialize x
          = do putWord8 37
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data QueryPointer = MkQueryPointer{window_QueryPointer :: WINDOW}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize QueryPointer where
        serialize x
          = do putWord8 38
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_QueryPointer x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_QueryPointer x)
 
data QueryPointerReply = MkQueryPointerReply{same_screen_QueryPointerReply
                                             :: Bool,
                                             root_QueryPointerReply :: WINDOW,
                                             child_QueryPointerReply :: WINDOW,
                                             root_x_QueryPointerReply :: Int16,
                                             root_y_QueryPointerReply :: Int16,
                                             win_x_QueryPointerReply :: Int16,
                                             win_y_QueryPointerReply :: Int16,
                                             mask_QueryPointerReply :: [KeyButMask]}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryPointerReply where
        deserialize
          = do skip 1
               same_screen <- deserialize
               skip 2
               length <- deserialize
               root <- deserialize
               child <- deserialize
               root_x <- deserialize
               root_y <- deserialize
               win_x <- deserialize
               win_y <- deserialize
               mask <- liftM fromMask (deserialize :: Get Word16)
               skip 2
               let _ = isCard32 length
               return
                 (MkQueryPointerReply same_screen root child root_x root_y win_x
                    win_y
                    mask)
 
data TIMECOORD = MkTIMECOORD{time_TIMECOORD :: TIMESTAMP,
                             x_TIMECOORD :: Int16, y_TIMECOORD :: Int16}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize TIMECOORD where
        serialize x
          = do serialize (time_TIMECOORD x)
               serialize (x_TIMECOORD x)
               serialize (y_TIMECOORD x)
        size x
          = size (time_TIMECOORD x) + size (x_TIMECOORD x) +
              size (y_TIMECOORD x)
 
instance Deserialize TIMECOORD where
        deserialize
          = do time <- deserialize
               x <- deserialize
               y <- deserialize
               return (MkTIMECOORD time x y)
 
data GetMotionEvents = MkGetMotionEvents{window_GetMotionEvents ::
                                         WINDOW,
                                         start_GetMotionEvents :: TIMESTAMP,
                                         stop_GetMotionEvents :: TIMESTAMP}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetMotionEvents where
        serialize x
          = do putWord8 39
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_GetMotionEvents x)
               serialize (start_GetMotionEvents x)
               serialize (stop_GetMotionEvents x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (window_GetMotionEvents x) +
              size (start_GetMotionEvents x)
              + size (stop_GetMotionEvents x)
 
data GetMotionEventsReply = MkGetMotionEventsReply{events_len_GetMotionEventsReply
                                                   :: Word32,
                                                   events_GetMotionEventsReply :: [TIMECOORD]}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetMotionEventsReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               events_len <- deserialize
               skip 20
               events <- deserializeList (fromIntegral events_len)
               let _ = isCard32 length
               return (MkGetMotionEventsReply events_len events)
 
data TranslateCoordinates = MkTranslateCoordinates{src_window_TranslateCoordinates
                                                   :: WINDOW,
                                                   dst_window_TranslateCoordinates :: WINDOW,
                                                   src_x_TranslateCoordinates :: Int16,
                                                   src_y_TranslateCoordinates :: Int16}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Serialize TranslateCoordinates where
        serialize x
          = do putWord8 40
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (src_window_TranslateCoordinates x)
               serialize (dst_window_TranslateCoordinates x)
               serialize (src_x_TranslateCoordinates x)
               serialize (src_y_TranslateCoordinates x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (src_window_TranslateCoordinates x) +
              size (dst_window_TranslateCoordinates x)
              + size (src_x_TranslateCoordinates x)
              + size (src_y_TranslateCoordinates x)
 
data TranslateCoordinatesReply = MkTranslateCoordinatesReply{same_screen_TranslateCoordinatesReply
                                                             :: Bool,
                                                             child_TranslateCoordinatesReply ::
                                                             WINDOW,
                                                             dst_x_TranslateCoordinatesReply ::
                                                             Word16,
                                                             dst_y_TranslateCoordinatesReply ::
                                                             Word16}
                               deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize TranslateCoordinatesReply where
        deserialize
          = do skip 1
               same_screen <- deserialize
               skip 2
               length <- deserialize
               child <- deserialize
               dst_x <- deserialize
               dst_y <- deserialize
               let _ = isCard32 length
               return (MkTranslateCoordinatesReply same_screen child dst_x dst_y)
 
data WarpPointer = MkWarpPointer{src_window_WarpPointer :: WINDOW,
                                 dst_window_WarpPointer :: WINDOW, src_x_WarpPointer :: Int16,
                                 src_y_WarpPointer :: Int16, src_width_WarpPointer :: Word16,
                                 src_height_WarpPointer :: Word16, dst_x_WarpPointer :: Int16,
                                 dst_y_WarpPointer :: Int16}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize WarpPointer where
        serialize x
          = do putWord8 41
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (src_window_WarpPointer x)
               serialize (dst_window_WarpPointer x)
               serialize (src_x_WarpPointer x)
               serialize (src_y_WarpPointer x)
               serialize (src_width_WarpPointer x)
               serialize (src_height_WarpPointer x)
               serialize (dst_x_WarpPointer x)
               serialize (dst_y_WarpPointer x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (src_window_WarpPointer x) +
              size (dst_window_WarpPointer x)
              + size (src_x_WarpPointer x)
              + size (src_y_WarpPointer x)
              + size (src_width_WarpPointer x)
              + size (src_height_WarpPointer x)
              + size (dst_x_WarpPointer x)
              + size (dst_y_WarpPointer x)
 
data InputFocus = InputFocusNone
                | InputFocusPointerRoot
                | InputFocusParent
                | InputFocusFollowKeyboard
                deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum InputFocus where
        toValue InputFocusNone{} = 0
        toValue InputFocusPointerRoot{} = 1
        toValue InputFocusParent{} = 2
        toValue InputFocusFollowKeyboard{} = 3
        fromValue 0 = InputFocusNone
        fromValue 1 = InputFocusPointerRoot
        fromValue 2 = InputFocusParent
        fromValue 3 = InputFocusFollowKeyboard
 
data SetInputFocus = MkSetInputFocus{revert_to_SetInputFocus ::
                                     InputFocus,
                                     focus_SetInputFocus :: WINDOW, time_SetInputFocus :: TIMESTAMP}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetInputFocus where
        serialize x
          = do putWord8 42
               serialize (toValue (revert_to_SetInputFocus x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (focus_SetInputFocus x)
               serialize (time_SetInputFocus x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (focus_SetInputFocus x) +
              size (time_SetInputFocus x)
 
data GetInputFocus = MkGetInputFocus{}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetInputFocus where
        serialize x
          = do putWord8 43
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data GetInputFocusReply = MkGetInputFocusReply{revert_to_GetInputFocusReply
                                               :: InputFocus,
                                               focus_GetInputFocusReply :: WINDOW}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetInputFocusReply where
        deserialize
          = do skip 1
               revert_to <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               focus <- deserialize
               let _ = isCard32 length
               return (MkGetInputFocusReply revert_to focus)
 
data QueryKeymap = MkQueryKeymap{}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize QueryKeymap where
        serialize x
          = do putWord8 44
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data QueryKeymapReply = MkQueryKeymapReply{keys_QueryKeymapReply ::
                                           [Word8]}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryKeymapReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               keys <- deserializeList (fromIntegral 32)
               let _ = isCard32 length
               return (MkQueryKeymapReply keys)
 
data OpenFont = MkOpenFont{fid_OpenFont :: FONT,
                           name_len_OpenFont :: Word16, name_OpenFont :: [CChar]}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize OpenFont where
        serialize x
          = do putWord8 45
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (fid_OpenFont x)
               serialize (name_len_OpenFont x)
               putSkip 2
               serializeList (name_OpenFont x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (fid_OpenFont x) + size (name_len_OpenFont x) + 2 +
              sum (map size (name_OpenFont x))
 
data CloseFont = MkCloseFont{font_CloseFont :: FONT}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CloseFont where
        serialize x
          = do putWord8 46
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (font_CloseFont x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (font_CloseFont x)
 
data FontDraw = FontDrawLeftToRight
              | FontDrawRightToLeft
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum FontDraw where
        toValue FontDrawLeftToRight{} = 0
        toValue FontDrawRightToLeft{} = 1
        fromValue 0 = FontDrawLeftToRight
        fromValue 1 = FontDrawRightToLeft
 
data FONTPROP = MkFONTPROP{name_FONTPROP :: ATOM,
                           value_FONTPROP :: Word32}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize FONTPROP where
        serialize x
          = do serialize (name_FONTPROP x)
               serialize (value_FONTPROP x)
        size x = size (name_FONTPROP x) + size (value_FONTPROP x)
 
instance Deserialize FONTPROP where
        deserialize
          = do name <- deserialize
               value <- deserialize
               return (MkFONTPROP name value)
 
data CHARINFO = MkCHARINFO{left_side_bearing_CHARINFO :: Int16,
                           right_side_bearing_CHARINFO :: Int16,
                           character_width_CHARINFO :: Int16, ascent_CHARINFO :: Int16,
                           descent_CHARINFO :: Int16, attributes_CHARINFO :: Word16}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CHARINFO where
        serialize x
          = do serialize (left_side_bearing_CHARINFO x)
               serialize (right_side_bearing_CHARINFO x)
               serialize (character_width_CHARINFO x)
               serialize (ascent_CHARINFO x)
               serialize (descent_CHARINFO x)
               serialize (attributes_CHARINFO x)
        size x
          = size (left_side_bearing_CHARINFO x) +
              size (right_side_bearing_CHARINFO x)
              + size (character_width_CHARINFO x)
              + size (ascent_CHARINFO x)
              + size (descent_CHARINFO x)
              + size (attributes_CHARINFO x)
 
instance Deserialize CHARINFO where
        deserialize
          = do left_side_bearing <- deserialize
               right_side_bearing <- deserialize
               character_width <- deserialize
               ascent <- deserialize
               descent <- deserialize
               attributes <- deserialize
               return
                 (MkCHARINFO left_side_bearing right_side_bearing character_width
                    ascent
                    descent
                    attributes)
 
data QueryFont = MkQueryFont{font_QueryFont :: FONTABLE}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize QueryFont where
        serialize x
          = do putWord8 47
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (font_QueryFont x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (font_QueryFont x)
 
data QueryFontReply = MkQueryFontReply{min_bounds_QueryFontReply ::
                                       CHARINFO,
                                       max_bounds_QueryFontReply :: CHARINFO,
                                       min_char_or_byte2_QueryFontReply :: Word16,
                                       max_char_or_byte2_QueryFontReply :: Word16,
                                       default_char_QueryFontReply :: Word16,
                                       properties_len_QueryFontReply :: Word16,
                                       draw_direction_QueryFontReply :: FontDraw,
                                       min_byte1_QueryFontReply :: Word8,
                                       max_byte1_QueryFontReply :: Word8,
                                       all_chars_exist_QueryFontReply :: Bool,
                                       font_ascent_QueryFontReply :: Int16,
                                       font_descent_QueryFontReply :: Int16,
                                       char_infos_len_QueryFontReply :: Word32,
                                       properties_QueryFontReply :: [FONTPROP],
                                       char_infos_QueryFontReply :: [CHARINFO]}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryFontReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               min_bounds <- deserialize
               skip 4
               max_bounds <- deserialize
               skip 4
               min_char_or_byte2 <- deserialize
               max_char_or_byte2 <- deserialize
               default_char <- deserialize
               properties_len <- deserialize
               draw_direction <- liftM fromValue (deserialize :: Get Word8)
               min_byte1 <- deserialize
               max_byte1 <- deserialize
               all_chars_exist <- deserialize
               font_ascent <- deserialize
               font_descent <- deserialize
               char_infos_len <- deserialize
               properties <- deserializeList (fromIntegral properties_len)
               char_infos <- deserializeList (fromIntegral char_infos_len)
               let _ = isCard32 length
               return
                 (MkQueryFontReply min_bounds max_bounds min_char_or_byte2
                    max_char_or_byte2
                    default_char
                    properties_len
                    draw_direction
                    min_byte1
                    max_byte1
                    all_chars_exist
                    font_ascent
                    font_descent
                    char_infos_len
                    properties
                    char_infos)
 
data QueryTextExtents = MkQueryTextExtents{font_QueryTextExtents ::
                                           FONTABLE,
                                           string_QueryTextExtents :: [CHAR2B]}
                      deriving (Show, Typeable, Eq, Ord)
 
odd_length_QueryTextExtents :: QueryTextExtents -> Bool
odd_length_QueryTextExtents x
  = wordToBool (string_len_QueryTextExtents x .&. 1)

string_len_QueryTextExtents :: QueryTextExtents -> Word8
string_len_QueryTextExtents x = genericLength $ string_QueryTextExtents x
 
instance Serialize QueryTextExtents where
        serialize x
          = do putWord8 48
               serialize (odd_length_QueryTextExtents x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (font_QueryTextExtents x)
               serializeList (string_QueryTextExtents x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (odd_length_QueryTextExtents x) +
              size (font_QueryTextExtents x)
              + sum (map size (string_QueryTextExtents x))
 
data QueryTextExtentsReply = MkQueryTextExtentsReply{draw_direction_QueryTextExtentsReply
                                                     :: FontDraw,
                                                     font_ascent_QueryTextExtentsReply :: Int16,
                                                     font_descent_QueryTextExtentsReply :: Int16,
                                                     overall_ascent_QueryTextExtentsReply :: Int16,
                                                     overall_descent_QueryTextExtentsReply :: Int16,
                                                     overall_width_QueryTextExtentsReply :: Int32,
                                                     overall_left_QueryTextExtentsReply :: Int32,
                                                     overall_right_QueryTextExtentsReply :: Int32}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryTextExtentsReply where
        deserialize
          = do skip 1
               draw_direction <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               font_ascent <- deserialize
               font_descent <- deserialize
               overall_ascent <- deserialize
               overall_descent <- deserialize
               overall_width <- deserialize
               overall_left <- deserialize
               overall_right <- deserialize
               let _ = isCard32 length
               return
                 (MkQueryTextExtentsReply draw_direction font_ascent font_descent
                    overall_ascent
                    overall_descent
                    overall_width
                    overall_left
                    overall_right)
 
data STR = MkSTR{name_len_STR :: Word8, name_STR :: [CChar]}
         deriving (Show, Typeable, Eq, Ord)
 
instance Serialize STR where
        serialize x
          = do serialize (name_len_STR x)
               serializeList (name_STR x)
        size x = size (name_len_STR x) + sum (map size (name_STR x))
 
instance Deserialize STR where
        deserialize
          = do name_len <- deserialize
               name <- deserializeList (fromIntegral name_len)
               return (MkSTR name_len name)
 
data ListFonts = MkListFonts{max_names_ListFonts :: Word16,
                             pattern_len_ListFonts :: Word16, pattern_ListFonts :: [CChar]}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ListFonts where
        serialize x
          = do putWord8 49
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (max_names_ListFonts x)
               serialize (pattern_len_ListFonts x)
               serializeList (pattern_ListFonts x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (max_names_ListFonts x) +
              size (pattern_len_ListFonts x)
              + sum (map size (pattern_ListFonts x))
 
data ListFontsReply = MkListFontsReply{names_len_ListFontsReply ::
                                       Word16,
                                       names_ListFontsReply :: [STR]}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize ListFontsReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               names_len <- deserialize
               skip 22
               names <- deserializeList (fromIntegral names_len)
               let _ = isCard32 length
               return (MkListFontsReply names_len names)
 
data ListFontsWithInfo = MkListFontsWithInfo{max_names_ListFontsWithInfo
                                             :: Word16,
                                             pattern_len_ListFontsWithInfo :: Word16,
                                             pattern_ListFontsWithInfo :: [CChar]}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ListFontsWithInfo where
        serialize x
          = do putWord8 50
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (max_names_ListFontsWithInfo x)
               serialize (pattern_len_ListFontsWithInfo x)
               serializeList (pattern_ListFontsWithInfo x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (max_names_ListFontsWithInfo x) +
              size (pattern_len_ListFontsWithInfo x)
              + sum (map size (pattern_ListFontsWithInfo x))
 
data ListFontsWithInfoReply = MkListFontsWithInfoReply{name_len_ListFontsWithInfoReply
                                                       :: Word8,
                                                       min_bounds_ListFontsWithInfoReply ::
                                                       CHARINFO,
                                                       max_bounds_ListFontsWithInfoReply ::
                                                       CHARINFO,
                                                       min_char_or_byte2_ListFontsWithInfoReply ::
                                                       Word16,
                                                       max_char_or_byte2_ListFontsWithInfoReply ::
                                                       Word16,
                                                       default_char_ListFontsWithInfoReply ::
                                                       Word16,
                                                       properties_len_ListFontsWithInfoReply ::
                                                       Word16,
                                                       draw_direction_ListFontsWithInfoReply ::
                                                       FontDraw,
                                                       min_byte1_ListFontsWithInfoReply :: Word8,
                                                       max_byte1_ListFontsWithInfoReply :: Word8,
                                                       all_chars_exist_ListFontsWithInfoReply ::
                                                       Bool,
                                                       font_ascent_ListFontsWithInfoReply :: Int16,
                                                       font_descent_ListFontsWithInfoReply :: Int16,
                                                       replies_hint_ListFontsWithInfoReply ::
                                                       Word32,
                                                       properties_ListFontsWithInfoReply ::
                                                       [FONTPROP],
                                                       name_ListFontsWithInfoReply :: [CChar]}
                            deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize ListFontsWithInfoReply where
        deserialize
          = do skip 1
               name_len <- deserialize
               skip 2
               length <- deserialize
               min_bounds <- deserialize
               skip 4
               max_bounds <- deserialize
               skip 4
               min_char_or_byte2 <- deserialize
               max_char_or_byte2 <- deserialize
               default_char <- deserialize
               properties_len <- deserialize
               draw_direction <- liftM fromValue (deserialize :: Get Word8)
               min_byte1 <- deserialize
               max_byte1 <- deserialize
               all_chars_exist <- deserialize
               font_ascent <- deserialize
               font_descent <- deserialize
               replies_hint <- deserialize
               properties <- deserializeList (fromIntegral properties_len)
               name <- deserializeList (fromIntegral name_len)
               let _ = isCard32 length
               return
                 (MkListFontsWithInfoReply name_len min_bounds max_bounds
                    min_char_or_byte2
                    max_char_or_byte2
                    default_char
                    properties_len
                    draw_direction
                    min_byte1
                    max_byte1
                    all_chars_exist
                    font_ascent
                    font_descent
                    replies_hint
                    properties
                    name)
 
data SetFontPath = MkSetFontPath{font_qty_SetFontPath :: Word16,
                                 path_SetFontPath :: [CChar]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetFontPath where
        serialize x
          = do putWord8 51
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (font_qty_SetFontPath x)
               serializeList (path_SetFontPath x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (font_qty_SetFontPath x) +
              sum (map size (path_SetFontPath x))
 
data GetFontPath = MkGetFontPath{}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetFontPath where
        serialize x
          = do putWord8 52
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data GetFontPathReply = MkGetFontPathReply{path_len_GetFontPathReply
                                           :: Word16,
                                           path_GetFontPathReply :: [STR]}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetFontPathReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               path_len <- deserialize
               skip 22
               path <- deserializeList (fromIntegral path_len)
               let _ = isCard32 length
               return (MkGetFontPathReply path_len path)
 
data CreatePixmap = MkCreatePixmap{depth_CreatePixmap :: Word8,
                                   pid_CreatePixmap :: PIXMAP, drawable_CreatePixmap :: DRAWABLE,
                                   width_CreatePixmap :: Word16, height_CreatePixmap :: Word16}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CreatePixmap where
        serialize x
          = do putWord8 53
               serialize (depth_CreatePixmap x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (pid_CreatePixmap x)
               serialize (drawable_CreatePixmap x)
               serialize (width_CreatePixmap x)
               serialize (height_CreatePixmap x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (depth_CreatePixmap x) + size (pid_CreatePixmap x) +
              size (drawable_CreatePixmap x)
              + size (width_CreatePixmap x)
              + size (height_CreatePixmap x)
 
data FreePixmap = MkFreePixmap{pixmap_FreePixmap :: PIXMAP}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize FreePixmap where
        serialize x
          = do putWord8 54
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (pixmap_FreePixmap x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (pixmap_FreePixmap x)
 
data GC = GCFunction
        | GCPlaneMask
        | GCForeground
        | GCBackground
        | GCLineWidth
        | GCLineStyle
        | GCCapStyle
        | GCJoinStyle
        | GCFillStyle
        | GCFillRule
        | GCTile
        | GCStipple
        | GCTileStippleOriginX
        | GCTileStippleOriginY
        | GCFont
        | GCSubwindowMode
        | GCGraphicsExposures
        | GCClipOriginX
        | GCClipOriginY
        | GCClipMask
        | GCDashOffset
        | GCDashList
        | GCArcMode
        deriving (Show, Eq, Ord, Enum)
 
instance BitEnum GC where
        toBit GCFunction{} = 0
        toBit GCPlaneMask{} = 1
        toBit GCForeground{} = 2
        toBit GCBackground{} = 3
        toBit GCLineWidth{} = 4
        toBit GCLineStyle{} = 5
        toBit GCCapStyle{} = 6
        toBit GCJoinStyle{} = 7
        toBit GCFillStyle{} = 8
        toBit GCFillRule{} = 9
        toBit GCTile{} = 10
        toBit GCStipple{} = 11
        toBit GCTileStippleOriginX{} = 12
        toBit GCTileStippleOriginY{} = 13
        toBit GCFont{} = 14
        toBit GCSubwindowMode{} = 15
        toBit GCGraphicsExposures{} = 16
        toBit GCClipOriginX{} = 17
        toBit GCClipOriginY{} = 18
        toBit GCClipMask{} = 19
        toBit GCDashOffset{} = 20
        toBit GCDashList{} = 21
        toBit GCArcMode{} = 22
        fromBit 0 = GCFunction
        fromBit 1 = GCPlaneMask
        fromBit 2 = GCForeground
        fromBit 3 = GCBackground
        fromBit 4 = GCLineWidth
        fromBit 5 = GCLineStyle
        fromBit 6 = GCCapStyle
        fromBit 7 = GCJoinStyle
        fromBit 8 = GCFillStyle
        fromBit 9 = GCFillRule
        fromBit 10 = GCTile
        fromBit 11 = GCStipple
        fromBit 12 = GCTileStippleOriginX
        fromBit 13 = GCTileStippleOriginY
        fromBit 14 = GCFont
        fromBit 15 = GCSubwindowMode
        fromBit 16 = GCGraphicsExposures
        fromBit 17 = GCClipOriginX
        fromBit 18 = GCClipOriginY
        fromBit 19 = GCClipMask
        fromBit 20 = GCDashOffset
        fromBit 21 = GCDashList
        fromBit 22 = GCArcMode
 
data GX = GXclear
        | GXand
        | GXandReverse
        | GXcopy
        | GXandInverted
        | GXnoop
        | GXxor
        | GXor
        | GXnor
        | GXequiv
        | GXinvert
        | GXorReverse
        | GXcopyInverted
        | GXorInverted
        | GXnand
        | GXset
        deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum GX where
        toValue GXclear{} = 0
        toValue GXand{} = 1
        toValue GXandReverse{} = 2
        toValue GXcopy{} = 3
        toValue GXandInverted{} = 4
        toValue GXnoop{} = 5
        toValue GXxor{} = 6
        toValue GXor{} = 7
        toValue GXnor{} = 8
        toValue GXequiv{} = 9
        toValue GXinvert{} = 10
        toValue GXorReverse{} = 11
        toValue GXcopyInverted{} = 12
        toValue GXorInverted{} = 13
        toValue GXnand{} = 14
        toValue GXset{} = 15
        fromValue 0 = GXclear
        fromValue 1 = GXand
        fromValue 2 = GXandReverse
        fromValue 3 = GXcopy
        fromValue 4 = GXandInverted
        fromValue 5 = GXnoop
        fromValue 6 = GXxor
        fromValue 7 = GXor
        fromValue 8 = GXnor
        fromValue 9 = GXequiv
        fromValue 10 = GXinvert
        fromValue 11 = GXorReverse
        fromValue 12 = GXcopyInverted
        fromValue 13 = GXorInverted
        fromValue 14 = GXnand
        fromValue 15 = GXset
 
data LineStyle = LineStyleSolid
               | LineStyleOnOffDash
               | LineStyleDoubleDash
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum LineStyle where
        toValue LineStyleSolid{} = 0
        toValue LineStyleOnOffDash{} = 1
        toValue LineStyleDoubleDash{} = 2
        fromValue 0 = LineStyleSolid
        fromValue 1 = LineStyleOnOffDash
        fromValue 2 = LineStyleDoubleDash
 
data CapStyle = CapStyleNotLast
              | CapStyleButt
              | CapStyleRound
              | CapStyleProjecting
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum CapStyle where
        toValue CapStyleNotLast{} = 0
        toValue CapStyleButt{} = 1
        toValue CapStyleRound{} = 2
        toValue CapStyleProjecting{} = 3
        fromValue 0 = CapStyleNotLast
        fromValue 1 = CapStyleButt
        fromValue 2 = CapStyleRound
        fromValue 3 = CapStyleProjecting
 
data JoinStyle = JoinStyleMiter
               | JoinStyleRound
               | JoinStyleBevel
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum JoinStyle where
        toValue JoinStyleMiter{} = 0
        toValue JoinStyleRound{} = 1
        toValue JoinStyleBevel{} = 2
        fromValue 0 = JoinStyleMiter
        fromValue 1 = JoinStyleRound
        fromValue 2 = JoinStyleBevel
 
data FillStyle = FillStyleSolid
               | FillStyleTiled
               | FillStyleStippled
               | FillStyleOpaqueStippled
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum FillStyle where
        toValue FillStyleSolid{} = 0
        toValue FillStyleTiled{} = 1
        toValue FillStyleStippled{} = 2
        toValue FillStyleOpaqueStippled{} = 3
        fromValue 0 = FillStyleSolid
        fromValue 1 = FillStyleTiled
        fromValue 2 = FillStyleStippled
        fromValue 3 = FillStyleOpaqueStippled
 
data FillRule = FillRuleEvenOdd
              | FillRuleWinding
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum FillRule where
        toValue FillRuleEvenOdd{} = 0
        toValue FillRuleWinding{} = 1
        fromValue 0 = FillRuleEvenOdd
        fromValue 1 = FillRuleWinding
 
data SubwindowMode = SubwindowModeClipByChildren
                   | SubwindowModeIncludeInferiors
                   deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum SubwindowMode where
        toValue SubwindowModeClipByChildren{} = 0
        toValue SubwindowModeIncludeInferiors{} = 1
        fromValue 0 = SubwindowModeClipByChildren
        fromValue 1 = SubwindowModeIncludeInferiors
 
data ArcMode = ArcModeChord
             | ArcModePieSlice
             deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum ArcMode where
        toValue ArcModeChord{} = 0
        toValue ArcModePieSlice{} = 1
        fromValue 0 = ArcModeChord
        fromValue 1 = ArcModePieSlice
 
data CreateGC = MkCreateGC{cid_CreateGC :: GCONTEXT,
                           drawable_CreateGC :: DRAWABLE, value_CreateGC :: ValueParam Word32}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CreateGC where
        serialize x
          = do putWord8 55
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cid_CreateGC x)
               serialize (drawable_CreateGC x)
               serialize (value_CreateGC x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cid_CreateGC x) + size (drawable_CreateGC x) +
              size (value_CreateGC x)
 
data ChangeGC = MkChangeGC{gc_ChangeGC :: GCONTEXT,
                           value_ChangeGC :: ValueParam Word32}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangeGC where
        serialize x
          = do putWord8 56
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (gc_ChangeGC x)
               serialize (value_ChangeGC x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (gc_ChangeGC x) + size (value_ChangeGC x)
 
data CopyGC = MkCopyGC{src_gc_CopyGC :: GCONTEXT,
                       dst_gc_CopyGC :: GCONTEXT, value_mask_CopyGC :: [GC]}
            deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CopyGC where
        serialize x
          = do putWord8 57
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (src_gc_CopyGC x)
               serialize (dst_gc_CopyGC x)
               serialize (toMask (value_mask_CopyGC x) :: Word32)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (src_gc_CopyGC x) + size (dst_gc_CopyGC x) +
              size (undefined :: Word32)
 
data SetDashes = MkSetDashes{gc_SetDashes :: GCONTEXT,
                             dash_offset_SetDashes :: Word16, dashes_len_SetDashes :: Word16,
                             dashes_SetDashes :: [Word8]}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetDashes where
        serialize x
          = do putWord8 58
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (gc_SetDashes x)
               serialize (dash_offset_SetDashes x)
               serialize (dashes_len_SetDashes x)
               serializeList (dashes_SetDashes x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (gc_SetDashes x) + size (dash_offset_SetDashes x) +
              size (dashes_len_SetDashes x)
              + sum (map size (dashes_SetDashes x))
 
data ClipOrdering = ClipOrderingUnsorted
                  | ClipOrderingYSorted
                  | ClipOrderingYXSorted
                  | ClipOrderingYXBanded
                  deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum ClipOrdering where
        toValue ClipOrderingUnsorted{} = 0
        toValue ClipOrderingYSorted{} = 1
        toValue ClipOrderingYXSorted{} = 2
        toValue ClipOrderingYXBanded{} = 3
        fromValue 0 = ClipOrderingUnsorted
        fromValue 1 = ClipOrderingYSorted
        fromValue 2 = ClipOrderingYXSorted
        fromValue 3 = ClipOrderingYXBanded
 
data SetClipRectangles = MkSetClipRectangles{ordering_SetClipRectangles
                                             :: ClipOrdering,
                                             gc_SetClipRectangles :: GCONTEXT,
                                             clip_x_origin_SetClipRectangles :: Int16,
                                             clip_y_origin_SetClipRectangles :: Int16,
                                             rectangles_SetClipRectangles :: [RECTANGLE]}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetClipRectangles where
        serialize x
          = do putWord8 59
               serialize (toValue (ordering_SetClipRectangles x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (gc_SetClipRectangles x)
               serialize (clip_x_origin_SetClipRectangles x)
               serialize (clip_y_origin_SetClipRectangles x)
               serializeList (rectangles_SetClipRectangles x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (gc_SetClipRectangles x) +
              size (clip_x_origin_SetClipRectangles x)
              + size (clip_y_origin_SetClipRectangles x)
              + sum (map size (rectangles_SetClipRectangles x))
 
data FreeGC = MkFreeGC{gc_FreeGC :: GCONTEXT}
            deriving (Show, Typeable, Eq, Ord)
 
instance Serialize FreeGC where
        serialize x
          = do putWord8 60
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (gc_FreeGC x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (gc_FreeGC x)
 
data ClearArea = MkClearArea{exposures_ClearArea :: Bool,
                             window_ClearArea :: WINDOW, x_ClearArea :: Int16,
                             y_ClearArea :: Int16, width_ClearArea :: Word16,
                             height_ClearArea :: Word16}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ClearArea where
        serialize x
          = do putWord8 61
               serialize (exposures_ClearArea x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_ClearArea x)
               serialize (x_ClearArea x)
               serialize (y_ClearArea x)
               serialize (width_ClearArea x)
               serialize (height_ClearArea x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (exposures_ClearArea x) + size (window_ClearArea x) +
              size (x_ClearArea x)
              + size (y_ClearArea x)
              + size (width_ClearArea x)
              + size (height_ClearArea x)
 
data CopyArea = MkCopyArea{src_drawable_CopyArea :: DRAWABLE,
                           dst_drawable_CopyArea :: DRAWABLE, gc_CopyArea :: GCONTEXT,
                           src_x_CopyArea :: Int16, src_y_CopyArea :: Int16,
                           dst_x_CopyArea :: Int16, dst_y_CopyArea :: Int16,
                           width_CopyArea :: Word16, height_CopyArea :: Word16}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CopyArea where
        serialize x
          = do putWord8 62
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (src_drawable_CopyArea x)
               serialize (dst_drawable_CopyArea x)
               serialize (gc_CopyArea x)
               serialize (src_x_CopyArea x)
               serialize (src_y_CopyArea x)
               serialize (dst_x_CopyArea x)
               serialize (dst_y_CopyArea x)
               serialize (width_CopyArea x)
               serialize (height_CopyArea x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (src_drawable_CopyArea x) +
              size (dst_drawable_CopyArea x)
              + size (gc_CopyArea x)
              + size (src_x_CopyArea x)
              + size (src_y_CopyArea x)
              + size (dst_x_CopyArea x)
              + size (dst_y_CopyArea x)
              + size (width_CopyArea x)
              + size (height_CopyArea x)
 
data CopyPlane = MkCopyPlane{src_drawable_CopyPlane :: DRAWABLE,
                             dst_drawable_CopyPlane :: DRAWABLE, gc_CopyPlane :: GCONTEXT,
                             src_x_CopyPlane :: Int16, src_y_CopyPlane :: Int16,
                             dst_x_CopyPlane :: Int16, dst_y_CopyPlane :: Int16,
                             width_CopyPlane :: Word16, height_CopyPlane :: Word16,
                             bit_plane_CopyPlane :: Word32}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CopyPlane where
        serialize x
          = do putWord8 63
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (src_drawable_CopyPlane x)
               serialize (dst_drawable_CopyPlane x)
               serialize (gc_CopyPlane x)
               serialize (src_x_CopyPlane x)
               serialize (src_y_CopyPlane x)
               serialize (dst_x_CopyPlane x)
               serialize (dst_y_CopyPlane x)
               serialize (width_CopyPlane x)
               serialize (height_CopyPlane x)
               serialize (bit_plane_CopyPlane x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (src_drawable_CopyPlane x) +
              size (dst_drawable_CopyPlane x)
              + size (gc_CopyPlane x)
              + size (src_x_CopyPlane x)
              + size (src_y_CopyPlane x)
              + size (dst_x_CopyPlane x)
              + size (dst_y_CopyPlane x)
              + size (width_CopyPlane x)
              + size (height_CopyPlane x)
              + size (bit_plane_CopyPlane x)
 
data CoordMode = CoordModeOrigin
               | CoordModePrevious
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum CoordMode where
        toValue CoordModeOrigin{} = 0
        toValue CoordModePrevious{} = 1
        fromValue 0 = CoordModeOrigin
        fromValue 1 = CoordModePrevious
 
data PolyPoint = MkPolyPoint{coordinate_mode_PolyPoint ::
                             CoordMode,
                             drawable_PolyPoint :: DRAWABLE, gc_PolyPoint :: GCONTEXT,
                             points_PolyPoint :: [POINT]}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolyPoint where
        serialize x
          = do putWord8 64
               serialize (toValue (coordinate_mode_PolyPoint x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolyPoint x)
               serialize (gc_PolyPoint x)
               serializeList (points_PolyPoint x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (drawable_PolyPoint x) +
              size (gc_PolyPoint x)
              + sum (map size (points_PolyPoint x))
 
data PolyLine = MkPolyLine{coordinate_mode_PolyLine :: CoordMode,
                           drawable_PolyLine :: DRAWABLE, gc_PolyLine :: GCONTEXT,
                           points_PolyLine :: [POINT]}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolyLine where
        serialize x
          = do putWord8 65
               serialize (toValue (coordinate_mode_PolyLine x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolyLine x)
               serialize (gc_PolyLine x)
               serializeList (points_PolyLine x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (drawable_PolyLine x) +
              size (gc_PolyLine x)
              + sum (map size (points_PolyLine x))
 
data SEGMENT = MkSEGMENT{x1_SEGMENT :: Int16, y1_SEGMENT :: Int16,
                         x2_SEGMENT :: Int16, y2_SEGMENT :: Int16}
             deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SEGMENT where
        serialize x
          = do serialize (x1_SEGMENT x)
               serialize (y1_SEGMENT x)
               serialize (x2_SEGMENT x)
               serialize (y2_SEGMENT x)
        size x
          = size (x1_SEGMENT x) + size (y1_SEGMENT x) + size (x2_SEGMENT x) +
              size (y2_SEGMENT x)
 
instance Deserialize SEGMENT where
        deserialize
          = do x1 <- deserialize
               y1 <- deserialize
               x2 <- deserialize
               y2 <- deserialize
               return (MkSEGMENT x1 y1 x2 y2)
 
data PolySegment = MkPolySegment{drawable_PolySegment :: DRAWABLE,
                                 gc_PolySegment :: GCONTEXT, segments_PolySegment :: [SEGMENT]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolySegment where
        serialize x
          = do putWord8 66
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolySegment x)
               serialize (gc_PolySegment x)
               serializeList (segments_PolySegment x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (drawable_PolySegment x) + size (gc_PolySegment x) +
              sum (map size (segments_PolySegment x))
 
data PolyRectangle = MkPolyRectangle{drawable_PolyRectangle ::
                                     DRAWABLE,
                                     gc_PolyRectangle :: GCONTEXT,
                                     rectangles_PolyRectangle :: [RECTANGLE]}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolyRectangle where
        serialize x
          = do putWord8 67
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolyRectangle x)
               serialize (gc_PolyRectangle x)
               serializeList (rectangles_PolyRectangle x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (drawable_PolyRectangle x) +
              size (gc_PolyRectangle x)
              + sum (map size (rectangles_PolyRectangle x))
 
data PolyArc = MkPolyArc{drawable_PolyArc :: DRAWABLE,
                         gc_PolyArc :: GCONTEXT, arcs_PolyArc :: [ARC]}
             deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolyArc where
        serialize x
          = do putWord8 68
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolyArc x)
               serialize (gc_PolyArc x)
               serializeList (arcs_PolyArc x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (drawable_PolyArc x) + size (gc_PolyArc x) +
              sum (map size (arcs_PolyArc x))
 
data PolyShape = PolyShapeComplex
               | PolyShapeNonconvex
               | PolyShapeConvex
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum PolyShape where
        toValue PolyShapeComplex{} = 0
        toValue PolyShapeNonconvex{} = 1
        toValue PolyShapeConvex{} = 2
        fromValue 0 = PolyShapeComplex
        fromValue 1 = PolyShapeNonconvex
        fromValue 2 = PolyShapeConvex
 
data FillPoly = MkFillPoly{drawable_FillPoly :: DRAWABLE,
                           gc_FillPoly :: GCONTEXT, shape_FillPoly :: PolyShape,
                           coordinate_mode_FillPoly :: CoordMode, points_FillPoly :: [POINT]}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize FillPoly where
        serialize x
          = do putWord8 69
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_FillPoly x)
               serialize (gc_FillPoly x)
               serialize (toValue (shape_FillPoly x) :: Word8)
               serialize (toValue (coordinate_mode_FillPoly x) :: Word8)
               putSkip 2
               serializeList (points_FillPoly x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (drawable_FillPoly x) + size (gc_FillPoly x) +
              size (undefined :: Word8)
              + size (undefined :: Word8)
              + 2
              + sum (map size (points_FillPoly x))
 
data PolyFillRectangle = MkPolyFillRectangle{drawable_PolyFillRectangle
                                             :: DRAWABLE,
                                             gc_PolyFillRectangle :: GCONTEXT,
                                             rectangles_PolyFillRectangle :: [RECTANGLE]}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolyFillRectangle where
        serialize x
          = do putWord8 70
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolyFillRectangle x)
               serialize (gc_PolyFillRectangle x)
               serializeList (rectangles_PolyFillRectangle x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (drawable_PolyFillRectangle x) +
              size (gc_PolyFillRectangle x)
              + sum (map size (rectangles_PolyFillRectangle x))
 
data PolyFillArc = MkPolyFillArc{drawable_PolyFillArc :: DRAWABLE,
                                 gc_PolyFillArc :: GCONTEXT, arcs_PolyFillArc :: [ARC]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolyFillArc where
        serialize x
          = do putWord8 71
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolyFillArc x)
               serialize (gc_PolyFillArc x)
               serializeList (arcs_PolyFillArc x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (drawable_PolyFillArc x) + size (gc_PolyFillArc x) +
              sum (map size (arcs_PolyFillArc x))
 
data ImageFormat = ImageFormatXYBitmap
                 | ImageFormatXYPixmap
                 | ImageFormatZPixmap
                 deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum ImageFormat where
        toValue ImageFormatXYBitmap{} = 0
        toValue ImageFormatXYPixmap{} = 1
        toValue ImageFormatZPixmap{} = 2
        fromValue 0 = ImageFormatXYBitmap
        fromValue 1 = ImageFormatXYPixmap
        fromValue 2 = ImageFormatZPixmap
 
data PutImage = MkPutImage{format_PutImage :: ImageFormat,
                           drawable_PutImage :: DRAWABLE, gc_PutImage :: GCONTEXT,
                           width_PutImage :: Word16, height_PutImage :: Word16,
                           dst_x_PutImage :: Int16, dst_y_PutImage :: Int16,
                           left_pad_PutImage :: Word8, depth_PutImage :: Word8,
                           data_PutImage :: [Word8]}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PutImage where
        serialize x
          = do putWord8 72
               serialize (toValue (format_PutImage x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PutImage x)
               serialize (gc_PutImage x)
               serialize (width_PutImage x)
               serialize (height_PutImage x)
               serialize (dst_x_PutImage x)
               serialize (dst_y_PutImage x)
               serialize (left_pad_PutImage x)
               serialize (depth_PutImage x)
               putSkip 2
               serializeList (data_PutImage x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (drawable_PutImage x) +
              size (gc_PutImage x)
              + size (width_PutImage x)
              + size (height_PutImage x)
              + size (dst_x_PutImage x)
              + size (dst_y_PutImage x)
              + size (left_pad_PutImage x)
              + size (depth_PutImage x)
              + 2
              + sum (map size (data_PutImage x))
 
data GetImage = MkGetImage{format_GetImage :: ImageFormat,
                           drawable_GetImage :: DRAWABLE, x_GetImage :: Int16,
                           y_GetImage :: Int16, width_GetImage :: Word16,
                           height_GetImage :: Word16, plane_mask_GetImage :: Word32}
              deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetImage where
        serialize x
          = do putWord8 73
               serialize (toValue (format_GetImage x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_GetImage x)
               serialize (x_GetImage x)
               serialize (y_GetImage x)
               serialize (width_GetImage x)
               serialize (height_GetImage x)
               serialize (plane_mask_GetImage x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (drawable_GetImage x) +
              size (x_GetImage x)
              + size (y_GetImage x)
              + size (width_GetImage x)
              + size (height_GetImage x)
              + size (plane_mask_GetImage x)
 
data GetImageReply = MkGetImageReply{depth_GetImageReply :: Word8,
                                     visual_GetImageReply :: VISUALID,
                                     data_GetImageReply :: [Word8]}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetImageReply where
        deserialize
          = do skip 1
               depth <- deserialize
               skip 2
               length <- deserialize
               visual <- deserialize
               skip 20
               data_ <- deserializeList (fromIntegral (fromIntegral (length * 4)))
               let _ = isCard32 length
               return (MkGetImageReply depth visual data_)
 
data PolyText8 = MkPolyText8{drawable_PolyText8 :: DRAWABLE,
                             gc_PolyText8 :: GCONTEXT, x_PolyText8 :: Int16,
                             y_PolyText8 :: Int16, items_PolyText8 :: [Word8]}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolyText8 where
        serialize x
          = do putWord8 74
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolyText8 x)
               serialize (gc_PolyText8 x)
               serialize (x_PolyText8 x)
               serialize (y_PolyText8 x)
               serializeList (items_PolyText8 x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (drawable_PolyText8 x) + size (gc_PolyText8 x) +
              size (x_PolyText8 x)
              + size (y_PolyText8 x)
              + sum (map size (items_PolyText8 x))
 
data PolyText16 = MkPolyText16{drawable_PolyText16 :: DRAWABLE,
                               gc_PolyText16 :: GCONTEXT, x_PolyText16 :: Int16,
                               y_PolyText16 :: Int16, items_PolyText16 :: [Word8]}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize PolyText16 where
        serialize x
          = do putWord8 75
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_PolyText16 x)
               serialize (gc_PolyText16 x)
               serialize (x_PolyText16 x)
               serialize (y_PolyText16 x)
               serializeList (items_PolyText16 x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (drawable_PolyText16 x) + size (gc_PolyText16 x) +
              size (x_PolyText16 x)
              + size (y_PolyText16 x)
              + sum (map size (items_PolyText16 x))
 
data ImageText8 = MkImageText8{string_len_ImageText8 :: Word8,
                               drawable_ImageText8 :: DRAWABLE, gc_ImageText8 :: GCONTEXT,
                               x_ImageText8 :: Int16, y_ImageText8 :: Int16,
                               string_ImageText8 :: [CChar]}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ImageText8 where
        serialize x
          = do putWord8 76
               serialize (string_len_ImageText8 x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_ImageText8 x)
               serialize (gc_ImageText8 x)
               serialize (x_ImageText8 x)
               serialize (y_ImageText8 x)
               serializeList (string_ImageText8 x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (string_len_ImageText8 x) + size (drawable_ImageText8 x)
              + size (gc_ImageText8 x)
              + size (x_ImageText8 x)
              + size (y_ImageText8 x)
              + sum (map size (string_ImageText8 x))
 
data ImageText16 = MkImageText16{string_len_ImageText16 :: Word8,
                                 drawable_ImageText16 :: DRAWABLE, gc_ImageText16 :: GCONTEXT,
                                 x_ImageText16 :: Int16, y_ImageText16 :: Int16,
                                 string_ImageText16 :: [CHAR2B]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ImageText16 where
        serialize x
          = do putWord8 77
               serialize (string_len_ImageText16 x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_ImageText16 x)
               serialize (gc_ImageText16 x)
               serialize (x_ImageText16 x)
               serialize (y_ImageText16 x)
               serializeList (string_ImageText16 x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (string_len_ImageText16 x) +
              size (drawable_ImageText16 x)
              + size (gc_ImageText16 x)
              + size (x_ImageText16 x)
              + size (y_ImageText16 x)
              + sum (map size (string_ImageText16 x))
 
data ColormapAlloc = ColormapAllocNone
                   | ColormapAllocAll
                   deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum ColormapAlloc where
        toValue ColormapAllocNone{} = 0
        toValue ColormapAllocAll{} = 1
        fromValue 0 = ColormapAllocNone
        fromValue 1 = ColormapAllocAll
 
data CreateColormap = MkCreateColormap{alloc_CreateColormap ::
                                       ColormapAlloc,
                                       mid_CreateColormap :: COLORMAP,
                                       window_CreateColormap :: WINDOW,
                                       visual_CreateColormap :: VISUALID}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CreateColormap where
        serialize x
          = do putWord8 78
               serialize (toValue (alloc_CreateColormap x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (mid_CreateColormap x)
               serialize (window_CreateColormap x)
               serialize (visual_CreateColormap x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (mid_CreateColormap x) +
              size (window_CreateColormap x)
              + size (visual_CreateColormap x)
 
data FreeColormap = MkFreeColormap{cmap_FreeColormap :: COLORMAP}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize FreeColormap where
        serialize x
          = do putWord8 79
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_FreeColormap x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (cmap_FreeColormap x)
 
data CopyColormapAndFree = MkCopyColormapAndFree{mid_CopyColormapAndFree
                                                 :: COLORMAP,
                                                 src_cmap_CopyColormapAndFree :: COLORMAP}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CopyColormapAndFree where
        serialize x
          = do putWord8 80
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (mid_CopyColormapAndFree x)
               serialize (src_cmap_CopyColormapAndFree x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (mid_CopyColormapAndFree x) +
              size (src_cmap_CopyColormapAndFree x)
 
data InstallColormap = MkInstallColormap{cmap_InstallColormap ::
                                         COLORMAP}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Serialize InstallColormap where
        serialize x
          = do putWord8 81
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_InstallColormap x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (cmap_InstallColormap x)
 
data UninstallColormap = MkUninstallColormap{cmap_UninstallColormap
                                             :: COLORMAP}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize UninstallColormap where
        serialize x
          = do putWord8 82
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_UninstallColormap x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (cmap_UninstallColormap x)
 
data ListInstalledColormaps = MkListInstalledColormaps{window_ListInstalledColormaps
                                                       :: WINDOW}
                            deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ListInstalledColormaps where
        serialize x
          = do putWord8 83
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_ListInstalledColormaps x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (window_ListInstalledColormaps x)
 
data ListInstalledColormapsReply = MkListInstalledColormapsReply{cmaps_len_ListInstalledColormapsReply
                                                                 :: Word16,
                                                                 cmaps_ListInstalledColormapsReply
                                                                 :: [COLORMAP]}
                                 deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize ListInstalledColormapsReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               cmaps_len <- deserialize
               skip 22
               cmaps <- deserializeList (fromIntegral cmaps_len)
               let _ = isCard32 length
               return (MkListInstalledColormapsReply cmaps_len cmaps)
 
data AllocColor = MkAllocColor{cmap_AllocColor :: COLORMAP,
                               red_AllocColor :: Word16, green_AllocColor :: Word16,
                               blue_AllocColor :: Word16}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize AllocColor where
        serialize x
          = do putWord8 84
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_AllocColor x)
               serialize (red_AllocColor x)
               serialize (green_AllocColor x)
               serialize (blue_AllocColor x)
               putSkip 2
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cmap_AllocColor x) + size (red_AllocColor x) +
              size (green_AllocColor x)
              + size (blue_AllocColor x)
              + 2
 
data AllocColorReply = MkAllocColorReply{red_AllocColorReply ::
                                         Word16,
                                         green_AllocColorReply :: Word16,
                                         blue_AllocColorReply :: Word16,
                                         pixel_AllocColorReply :: Word32}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize AllocColorReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               red <- deserialize
               green <- deserialize
               blue <- deserialize
               skip 2
               pixel <- deserialize
               let _ = isCard32 length
               return (MkAllocColorReply red green blue pixel)
 
data AllocNamedColor = MkAllocNamedColor{cmap_AllocNamedColor ::
                                         COLORMAP,
                                         name_len_AllocNamedColor :: Word16,
                                         name_AllocNamedColor :: [CChar]}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Serialize AllocNamedColor where
        serialize x
          = do putWord8 85
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_AllocNamedColor x)
               serialize (name_len_AllocNamedColor x)
               putSkip 2
               serializeList (name_AllocNamedColor x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cmap_AllocNamedColor x) +
              size (name_len_AllocNamedColor x)
              + 2
              + sum (map size (name_AllocNamedColor x))
 
data AllocNamedColorReply = MkAllocNamedColorReply{pixel_AllocNamedColorReply
                                                   :: Word32,
                                                   exact_red_AllocNamedColorReply :: Word16,
                                                   exact_green_AllocNamedColorReply :: Word16,
                                                   exact_blue_AllocNamedColorReply :: Word16,
                                                   visual_red_AllocNamedColorReply :: Word16,
                                                   visual_green_AllocNamedColorReply :: Word16,
                                                   visual_blue_AllocNamedColorReply :: Word16}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize AllocNamedColorReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               pixel <- deserialize
               exact_red <- deserialize
               exact_green <- deserialize
               exact_blue <- deserialize
               visual_red <- deserialize
               visual_green <- deserialize
               visual_blue <- deserialize
               let _ = isCard32 length
               return
                 (MkAllocNamedColorReply pixel exact_red exact_green exact_blue
                    visual_red
                    visual_green
                    visual_blue)
 
data AllocColorCells = MkAllocColorCells{contiguous_AllocColorCells
                                         :: Bool,
                                         cmap_AllocColorCells :: COLORMAP,
                                         colors_AllocColorCells :: Word16,
                                         planes_AllocColorCells :: Word16}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Serialize AllocColorCells where
        serialize x
          = do putWord8 86
               serialize (contiguous_AllocColorCells x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_AllocColorCells x)
               serialize (colors_AllocColorCells x)
               serialize (planes_AllocColorCells x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (contiguous_AllocColorCells x) +
              size (cmap_AllocColorCells x)
              + size (colors_AllocColorCells x)
              + size (planes_AllocColorCells x)
 
data AllocColorCellsReply = MkAllocColorCellsReply{pixels_len_AllocColorCellsReply
                                                   :: Word16,
                                                   masks_len_AllocColorCellsReply :: Word16,
                                                   pixels_AllocColorCellsReply :: [Word32],
                                                   masks_AllocColorCellsReply :: [Word32]}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize AllocColorCellsReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               pixels_len <- deserialize
               masks_len <- deserialize
               skip 20
               pixels <- deserializeList (fromIntegral pixels_len)
               masks <- deserializeList (fromIntegral masks_len)
               let _ = isCard32 length
               return (MkAllocColorCellsReply pixels_len masks_len pixels masks)
 
data AllocColorPlanes = MkAllocColorPlanes{contiguous_AllocColorPlanes
                                           :: Bool,
                                           cmap_AllocColorPlanes :: COLORMAP,
                                           colors_AllocColorPlanes :: Word16,
                                           reds_AllocColorPlanes :: Word16,
                                           greens_AllocColorPlanes :: Word16,
                                           blues_AllocColorPlanes :: Word16}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Serialize AllocColorPlanes where
        serialize x
          = do putWord8 87
               serialize (contiguous_AllocColorPlanes x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_AllocColorPlanes x)
               serialize (colors_AllocColorPlanes x)
               serialize (reds_AllocColorPlanes x)
               serialize (greens_AllocColorPlanes x)
               serialize (blues_AllocColorPlanes x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (contiguous_AllocColorPlanes x) +
              size (cmap_AllocColorPlanes x)
              + size (colors_AllocColorPlanes x)
              + size (reds_AllocColorPlanes x)
              + size (greens_AllocColorPlanes x)
              + size (blues_AllocColorPlanes x)
 
data AllocColorPlanesReply = MkAllocColorPlanesReply{pixels_len_AllocColorPlanesReply
                                                     :: Word16,
                                                     red_mask_AllocColorPlanesReply :: Word32,
                                                     green_mask_AllocColorPlanesReply :: Word32,
                                                     blue_mask_AllocColorPlanesReply :: Word32,
                                                     pixels_AllocColorPlanesReply :: [Word32]}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize AllocColorPlanesReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               pixels_len <- deserialize
               skip 2
               red_mask <- deserialize
               green_mask <- deserialize
               blue_mask <- deserialize
               skip 8
               pixels <- deserializeList (fromIntegral pixels_len)
               let _ = isCard32 length
               return
                 (MkAllocColorPlanesReply pixels_len red_mask green_mask blue_mask
                    pixels)
 
data FreeColors = MkFreeColors{cmap_FreeColors :: COLORMAP,
                               plane_mask_FreeColors :: Word32, pixels_FreeColors :: [Word32]}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize FreeColors where
        serialize x
          = do putWord8 88
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_FreeColors x)
               serialize (plane_mask_FreeColors x)
               serializeList (pixels_FreeColors x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cmap_FreeColors x) + size (plane_mask_FreeColors x)
              + sum (map size (pixels_FreeColors x))
 
data ColorFlag = ColorFlagRed
               | ColorFlagGreen
               | ColorFlagBlue
               deriving (Show, Eq, Ord, Enum)
 
instance BitEnum ColorFlag where
        toBit ColorFlagRed{} = 0
        toBit ColorFlagGreen{} = 1
        toBit ColorFlagBlue{} = 2
        fromBit 0 = ColorFlagRed
        fromBit 1 = ColorFlagGreen
        fromBit 2 = ColorFlagBlue
 
data COLORITEM = MkCOLORITEM{pixel_COLORITEM :: Word32,
                             red_COLORITEM :: Word16, green_COLORITEM :: Word16,
                             blue_COLORITEM :: Word16, flags_COLORITEM :: [ColorFlag]}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize COLORITEM where
        serialize x
          = do serialize (pixel_COLORITEM x)
               serialize (red_COLORITEM x)
               serialize (green_COLORITEM x)
               serialize (blue_COLORITEM x)
               serialize (toMask (flags_COLORITEM x) :: Word8)
               putSkip 1
        size x
          = size (pixel_COLORITEM x) + size (red_COLORITEM x) +
              size (green_COLORITEM x)
              + size (blue_COLORITEM x)
              + size (undefined :: Word8)
              + 1
 
instance Deserialize COLORITEM where
        deserialize
          = do pixel <- deserialize
               red <- deserialize
               green <- deserialize
               blue <- deserialize
               flags <- liftM fromMask (deserialize :: Get Word8)
               skip 1
               return (MkCOLORITEM pixel red green blue flags)
 
data StoreColors = MkStoreColors{cmap_StoreColors :: COLORMAP,
                                 items_StoreColors :: [COLORITEM]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize StoreColors where
        serialize x
          = do putWord8 89
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_StoreColors x)
               serializeList (items_StoreColors x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cmap_StoreColors x) +
              sum (map size (items_StoreColors x))
 
data StoreNamedColor = MkStoreNamedColor{flags_StoreNamedColor ::
                                         [ColorFlag],
                                         cmap_StoreNamedColor :: COLORMAP,
                                         pixel_StoreNamedColor :: Word32,
                                         name_len_StoreNamedColor :: Word16,
                                         name_StoreNamedColor :: [CChar]}
                     deriving (Show, Typeable, Eq, Ord)
 
instance Serialize StoreNamedColor where
        serialize x
          = do putWord8 90
               serialize (toMask (flags_StoreNamedColor x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_StoreNamedColor x)
               serialize (pixel_StoreNamedColor x)
               serialize (name_len_StoreNamedColor x)
               putSkip 2
               serializeList (name_StoreNamedColor x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (cmap_StoreNamedColor x) +
              size (pixel_StoreNamedColor x)
              + size (name_len_StoreNamedColor x)
              + 2
              + sum (map size (name_StoreNamedColor x))
 
data RGB = MkRGB{red_RGB :: Word16, green_RGB :: Word16,
                 blue_RGB :: Word16}
         deriving (Show, Typeable, Eq, Ord)
 
instance Serialize RGB where
        serialize x
          = do serialize (red_RGB x)
               serialize (green_RGB x)
               serialize (blue_RGB x)
               putSkip 2
        size x
          = size (red_RGB x) + size (green_RGB x) + size (blue_RGB x) + 2
 
instance Deserialize RGB where
        deserialize
          = do red <- deserialize
               green <- deserialize
               blue <- deserialize
               skip 2
               return (MkRGB red green blue)
 
data QueryColors = MkQueryColors{cmap_QueryColors :: COLORMAP,
                                 pixels_QueryColors :: [Word32]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize QueryColors where
        serialize x
          = do putWord8 91
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_QueryColors x)
               serializeList (pixels_QueryColors x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cmap_QueryColors x) +
              sum (map size (pixels_QueryColors x))
 
data QueryColorsReply = MkQueryColorsReply{colors_len_QueryColorsReply
                                           :: Word16,
                                           colors_QueryColorsReply :: [RGB]}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryColorsReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               colors_len <- deserialize
               skip 22
               colors <- deserializeList (fromIntegral colors_len)
               let _ = isCard32 length
               return (MkQueryColorsReply colors_len colors)
 
data LookupColor = MkLookupColor{cmap_LookupColor :: COLORMAP,
                                 name_len_LookupColor :: Word16, name_LookupColor :: [CChar]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize LookupColor where
        serialize x
          = do putWord8 92
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cmap_LookupColor x)
               serialize (name_len_LookupColor x)
               putSkip 2
               serializeList (name_LookupColor x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cmap_LookupColor x) + size (name_len_LookupColor x)
              + 2
              + sum (map size (name_LookupColor x))
 
data LookupColorReply = MkLookupColorReply{exact_red_LookupColorReply
                                           :: Word16,
                                           exact_green_LookupColorReply :: Word16,
                                           exact_blue_LookupColorReply :: Word16,
                                           visual_red_LookupColorReply :: Word16,
                                           visual_green_LookupColorReply :: Word16,
                                           visual_blue_LookupColorReply :: Word16}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize LookupColorReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               exact_red <- deserialize
               exact_green <- deserialize
               exact_blue <- deserialize
               visual_red <- deserialize
               visual_green <- deserialize
               visual_blue <- deserialize
               let _ = isCard32 length
               return
                 (MkLookupColorReply exact_red exact_green exact_blue visual_red
                    visual_green
                    visual_blue)
 
data Pixmap = PixmapNone
            deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Pixmap where
        toValue PixmapNone{} = 0
        fromValue 0 = PixmapNone
 
data CreateCursor = MkCreateCursor{cid_CreateCursor :: CURSOR,
                                   source_CreateCursor :: PIXMAP, mask_CreateCursor :: PIXMAP,
                                   fore_red_CreateCursor :: Word16,
                                   fore_green_CreateCursor :: Word16,
                                   fore_blue_CreateCursor :: Word16,
                                   back_red_CreateCursor :: Word16,
                                   back_green_CreateCursor :: Word16,
                                   back_blue_CreateCursor :: Word16, x_CreateCursor :: Word16,
                                   y_CreateCursor :: Word16}
                  deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CreateCursor where
        serialize x
          = do putWord8 93
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cid_CreateCursor x)
               serialize (source_CreateCursor x)
               serialize (mask_CreateCursor x)
               serialize (fore_red_CreateCursor x)
               serialize (fore_green_CreateCursor x)
               serialize (fore_blue_CreateCursor x)
               serialize (back_red_CreateCursor x)
               serialize (back_green_CreateCursor x)
               serialize (back_blue_CreateCursor x)
               serialize (x_CreateCursor x)
               serialize (y_CreateCursor x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cid_CreateCursor x) + size (source_CreateCursor x)
              + size (mask_CreateCursor x)
              + size (fore_red_CreateCursor x)
              + size (fore_green_CreateCursor x)
              + size (fore_blue_CreateCursor x)
              + size (back_red_CreateCursor x)
              + size (back_green_CreateCursor x)
              + size (back_blue_CreateCursor x)
              + size (x_CreateCursor x)
              + size (y_CreateCursor x)
 
data Font = FontNone
          deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Font where
        toValue FontNone{} = 0
        fromValue 0 = FontNone
 
data CreateGlyphCursor = MkCreateGlyphCursor{cid_CreateGlyphCursor
                                             :: CURSOR,
                                             source_font_CreateGlyphCursor :: FONT,
                                             mask_font_CreateGlyphCursor :: FONT,
                                             source_char_CreateGlyphCursor :: Word16,
                                             mask_char_CreateGlyphCursor :: Word16,
                                             fore_red_CreateGlyphCursor :: Word16,
                                             fore_green_CreateGlyphCursor :: Word16,
                                             fore_blue_CreateGlyphCursor :: Word16,
                                             back_red_CreateGlyphCursor :: Word16,
                                             back_green_CreateGlyphCursor :: Word16,
                                             back_blue_CreateGlyphCursor :: Word16}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize CreateGlyphCursor where
        serialize x
          = do putWord8 94
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cid_CreateGlyphCursor x)
               serialize (source_font_CreateGlyphCursor x)
               serialize (mask_font_CreateGlyphCursor x)
               serialize (source_char_CreateGlyphCursor x)
               serialize (mask_char_CreateGlyphCursor x)
               serialize (fore_red_CreateGlyphCursor x)
               serialize (fore_green_CreateGlyphCursor x)
               serialize (fore_blue_CreateGlyphCursor x)
               serialize (back_red_CreateGlyphCursor x)
               serialize (back_green_CreateGlyphCursor x)
               serialize (back_blue_CreateGlyphCursor x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cid_CreateGlyphCursor x) +
              size (source_font_CreateGlyphCursor x)
              + size (mask_font_CreateGlyphCursor x)
              + size (source_char_CreateGlyphCursor x)
              + size (mask_char_CreateGlyphCursor x)
              + size (fore_red_CreateGlyphCursor x)
              + size (fore_green_CreateGlyphCursor x)
              + size (fore_blue_CreateGlyphCursor x)
              + size (back_red_CreateGlyphCursor x)
              + size (back_green_CreateGlyphCursor x)
              + size (back_blue_CreateGlyphCursor x)
 
data FreeCursor = MkFreeCursor{cursor_FreeCursor :: CURSOR}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize FreeCursor where
        serialize x
          = do putWord8 95
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cursor_FreeCursor x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (cursor_FreeCursor x)
 
data RecolorCursor = MkRecolorCursor{cursor_RecolorCursor ::
                                     CURSOR,
                                     fore_red_RecolorCursor :: Word16,
                                     fore_green_RecolorCursor :: Word16,
                                     fore_blue_RecolorCursor :: Word16,
                                     back_red_RecolorCursor :: Word16,
                                     back_green_RecolorCursor :: Word16,
                                     back_blue_RecolorCursor :: Word16}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize RecolorCursor where
        serialize x
          = do putWord8 96
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (cursor_RecolorCursor x)
               serialize (fore_red_RecolorCursor x)
               serialize (fore_green_RecolorCursor x)
               serialize (fore_blue_RecolorCursor x)
               serialize (back_red_RecolorCursor x)
               serialize (back_green_RecolorCursor x)
               serialize (back_blue_RecolorCursor x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (cursor_RecolorCursor x) +
              size (fore_red_RecolorCursor x)
              + size (fore_green_RecolorCursor x)
              + size (fore_blue_RecolorCursor x)
              + size (back_red_RecolorCursor x)
              + size (back_green_RecolorCursor x)
              + size (back_blue_RecolorCursor x)
 
data QueryShapeOf = QueryShapeOfLargestCursor
                  | QueryShapeOfFastestTile
                  | QueryShapeOfFastestStipple
                  deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum QueryShapeOf where
        toValue QueryShapeOfLargestCursor{} = 0
        toValue QueryShapeOfFastestTile{} = 1
        toValue QueryShapeOfFastestStipple{} = 2
        fromValue 0 = QueryShapeOfLargestCursor
        fromValue 1 = QueryShapeOfFastestTile
        fromValue 2 = QueryShapeOfFastestStipple
 
data QueryBestSize = MkQueryBestSize{class_QueryBestSize ::
                                     QueryShapeOf,
                                     drawable_QueryBestSize :: DRAWABLE,
                                     width_QueryBestSize :: Word16, height_QueryBestSize :: Word16}
                   deriving (Show, Typeable, Eq, Ord)
 
instance Serialize QueryBestSize where
        serialize x
          = do putWord8 97
               serialize (toValue (class_QueryBestSize x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (drawable_QueryBestSize x)
               serialize (width_QueryBestSize x)
               serialize (height_QueryBestSize x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (drawable_QueryBestSize x) +
              size (width_QueryBestSize x)
              + size (height_QueryBestSize x)
 
data QueryBestSizeReply = MkQueryBestSizeReply{width_QueryBestSizeReply
                                               :: Word16,
                                               height_QueryBestSizeReply :: Word16}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryBestSizeReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               width <- deserialize
               height <- deserialize
               let _ = isCard32 length
               return (MkQueryBestSizeReply width height)
 
data QueryExtension = MkQueryExtension{name_len_QueryExtension ::
                                       Word16,
                                       name_QueryExtension :: [CChar]}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize QueryExtension where
        serialize x
          = do putWord8 98
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (name_len_QueryExtension x)
               putSkip 2
               serializeList (name_QueryExtension x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (name_len_QueryExtension x) + 2 +
              sum (map size (name_QueryExtension x))
 
data QueryExtensionReply = MkQueryExtensionReply{present_QueryExtensionReply
                                                 :: Bool,
                                                 major_opcode_QueryExtensionReply :: Word8,
                                                 first_event_QueryExtensionReply :: Word8,
                                                 first_error_QueryExtensionReply :: Word8}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize QueryExtensionReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               present <- deserialize
               major_opcode <- deserialize
               first_event <- deserialize
               first_error <- deserialize
               let _ = isCard32 length
               return
                 (MkQueryExtensionReply present major_opcode first_event
                    first_error)
 
data ListExtensions = MkListExtensions{}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ListExtensions where
        serialize x
          = do putWord8 99
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data ListExtensionsReply = MkListExtensionsReply{names_len_ListExtensionsReply
                                                 :: Word8,
                                                 names_ListExtensionsReply :: [STR]}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize ListExtensionsReply where
        deserialize
          = do skip 1
               names_len <- deserialize
               skip 2
               length <- deserialize
               skip 24
               names <- deserializeList (fromIntegral names_len)
               let _ = isCard32 length
               return (MkListExtensionsReply names_len names)
 
data ChangeKeyboardMapping = MkChangeKeyboardMapping{keycode_count_ChangeKeyboardMapping
                                                     :: Word8,
                                                     first_keycode_ChangeKeyboardMapping :: KEYCODE,
                                                     keysyms_per_keycode_ChangeKeyboardMapping ::
                                                     Word8,
                                                     keysyms_ChangeKeyboardMapping :: [KEYSYM]}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangeKeyboardMapping where
        serialize x
          = do putWord8 100
               serialize (keycode_count_ChangeKeyboardMapping x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (first_keycode_ChangeKeyboardMapping x)
               serialize (keysyms_per_keycode_ChangeKeyboardMapping x)
               serializeList (keysyms_ChangeKeyboardMapping x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (keycode_count_ChangeKeyboardMapping x) +
              size (first_keycode_ChangeKeyboardMapping x)
              + size (keysyms_per_keycode_ChangeKeyboardMapping x)
              + sum (map size (keysyms_ChangeKeyboardMapping x))
 
data GetKeyboardMapping = MkGetKeyboardMapping{first_keycode_GetKeyboardMapping
                                               :: KEYCODE,
                                               count_GetKeyboardMapping :: Word8}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetKeyboardMapping where
        serialize x
          = do putWord8 101
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (first_keycode_GetKeyboardMapping x)
               serialize (count_GetKeyboardMapping x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (first_keycode_GetKeyboardMapping x) +
              size (count_GetKeyboardMapping x)
 
data GetKeyboardMappingReply = MkGetKeyboardMappingReply{keysyms_per_keycode_GetKeyboardMappingReply
                                                         :: Word8,
                                                         keysyms_GetKeyboardMappingReply ::
                                                         [KEYSYM]}
                             deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetKeyboardMappingReply where
        deserialize
          = do skip 1
               keysyms_per_keycode <- deserialize
               skip 2
               length <- deserialize
               skip 24
               keysyms <- deserializeList (fromIntegral length)
               let _ = isCard32 length
               return (MkGetKeyboardMappingReply keysyms_per_keycode keysyms)
 
data KB = KBKeyClickPercent
        | KBBellPercent
        | KBBellPitch
        | KBBellDuration
        | KBLed
        | KBLedMode
        | KBKey
        | KBAutoRepeatMode
        deriving (Show, Eq, Ord, Enum)
 
instance BitEnum KB where
        toBit KBKeyClickPercent{} = 0
        toBit KBBellPercent{} = 1
        toBit KBBellPitch{} = 2
        toBit KBBellDuration{} = 3
        toBit KBLed{} = 4
        toBit KBLedMode{} = 5
        toBit KBKey{} = 6
        toBit KBAutoRepeatMode{} = 7
        fromBit 0 = KBKeyClickPercent
        fromBit 1 = KBBellPercent
        fromBit 2 = KBBellPitch
        fromBit 3 = KBBellDuration
        fromBit 4 = KBLed
        fromBit 5 = KBLedMode
        fromBit 6 = KBKey
        fromBit 7 = KBAutoRepeatMode
 
data LedMode = LedModeOff
             | LedModeOn
             deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum LedMode where
        toValue LedModeOff{} = 0
        toValue LedModeOn{} = 1
        fromValue 0 = LedModeOff
        fromValue 1 = LedModeOn
 
data AutoRepeatMode = AutoRepeatModeOff
                    | AutoRepeatModeOn
                    | AutoRepeatModeDefault
                    deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum AutoRepeatMode where
        toValue AutoRepeatModeOff{} = 0
        toValue AutoRepeatModeOn{} = 1
        toValue AutoRepeatModeDefault{} = 2
        fromValue 0 = AutoRepeatModeOff
        fromValue 1 = AutoRepeatModeOn
        fromValue 2 = AutoRepeatModeDefault
 
data ChangeKeyboardControl = MkChangeKeyboardControl{value_ChangeKeyboardControl
                                                     :: ValueParam Word32}
                           deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangeKeyboardControl where
        serialize x
          = do putWord8 102
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (value_ChangeKeyboardControl x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (value_ChangeKeyboardControl x)
 
data GetKeyboardControl = MkGetKeyboardControl{}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetKeyboardControl where
        serialize x
          = do putWord8 103
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data GetKeyboardControlReply = MkGetKeyboardControlReply{global_auto_repeat_GetKeyboardControlReply
                                                         :: AutoRepeatMode,
                                                         led_mask_GetKeyboardControlReply :: Word32,
                                                         key_click_percent_GetKeyboardControlReply
                                                         :: Word8,
                                                         bell_percent_GetKeyboardControlReply ::
                                                         Word8,
                                                         bell_pitch_GetKeyboardControlReply ::
                                                         Word16,
                                                         bell_duration_GetKeyboardControlReply ::
                                                         Word16,
                                                         auto_repeats_GetKeyboardControlReply ::
                                                         [Word8]}
                             deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetKeyboardControlReply where
        deserialize
          = do skip 1
               global_auto_repeat <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               led_mask <- deserialize
               key_click_percent <- deserialize
               bell_percent <- deserialize
               bell_pitch <- deserialize
               bell_duration <- deserialize
               skip 2
               auto_repeats <- deserializeList (fromIntegral 32)
               let _ = isCard32 length
               return
                 (MkGetKeyboardControlReply global_auto_repeat led_mask
                    key_click_percent
                    bell_percent
                    bell_pitch
                    bell_duration
                    auto_repeats)
 
data Bell = MkBell{percent_Bell :: Int8}
          deriving (Show, Typeable, Eq, Ord)
 
instance Serialize Bell where
        serialize x
          = do putWord8 104
               serialize (percent_Bell x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 3 + size (percent_Bell x)
 
data ChangePointerControl = MkChangePointerControl{acceleration_numerator_ChangePointerControl
                                                   :: Int16,
                                                   acceleration_denominator_ChangePointerControl ::
                                                   Int16,
                                                   threshold_ChangePointerControl :: Int16,
                                                   do_acceleration_ChangePointerControl :: Bool,
                                                   do_threshold_ChangePointerControl :: Bool}
                          deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangePointerControl where
        serialize x
          = do putWord8 105
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (acceleration_numerator_ChangePointerControl x)
               serialize (acceleration_denominator_ChangePointerControl x)
               serialize (threshold_ChangePointerControl x)
               serialize (do_acceleration_ChangePointerControl x)
               serialize (do_threshold_ChangePointerControl x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (acceleration_numerator_ChangePointerControl x) +
              size (acceleration_denominator_ChangePointerControl x)
              + size (threshold_ChangePointerControl x)
              + size (do_acceleration_ChangePointerControl x)
              + size (do_threshold_ChangePointerControl x)
 
data GetPointerControl = MkGetPointerControl{}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetPointerControl where
        serialize x
          = do putWord8 106
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data GetPointerControlReply = MkGetPointerControlReply{acceleration_numerator_GetPointerControlReply
                                                       :: Word16,
                                                       acceleration_denominator_GetPointerControlReply
                                                       :: Word16,
                                                       threshold_GetPointerControlReply :: Word16}
                            deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetPointerControlReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               acceleration_numerator <- deserialize
               acceleration_denominator <- deserialize
               threshold <- deserialize
               skip 18
               let _ = isCard32 length
               return
                 (MkGetPointerControlReply acceleration_numerator
                    acceleration_denominator
                    threshold)
 
data Blanking = BlankingNotPreferred
              | BlankingPreferred
              | BlankingDefault
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Blanking where
        toValue BlankingNotPreferred{} = 0
        toValue BlankingPreferred{} = 1
        toValue BlankingDefault{} = 2
        fromValue 0 = BlankingNotPreferred
        fromValue 1 = BlankingPreferred
        fromValue 2 = BlankingDefault
 
data Exposures = ExposuresNotAllowed
               | ExposuresAllowed
               | ExposuresDefault
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Exposures where
        toValue ExposuresNotAllowed{} = 0
        toValue ExposuresAllowed{} = 1
        toValue ExposuresDefault{} = 2
        fromValue 0 = ExposuresNotAllowed
        fromValue 1 = ExposuresAllowed
        fromValue 2 = ExposuresDefault
 
data SetScreenSaver = MkSetScreenSaver{timeout_SetScreenSaver ::
                                       Int16,
                                       interval_SetScreenSaver :: Int16,
                                       prefer_blanking_SetScreenSaver :: Blanking,
                                       allow_exposures_SetScreenSaver :: Exposures}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetScreenSaver where
        serialize x
          = do putWord8 107
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (timeout_SetScreenSaver x)
               serialize (interval_SetScreenSaver x)
               serialize (toValue (prefer_blanking_SetScreenSaver x) :: Word8)
               serialize (toValue (allow_exposures_SetScreenSaver x) :: Word8)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (timeout_SetScreenSaver x) +
              size (interval_SetScreenSaver x)
              + size (undefined :: Word8)
              + size (undefined :: Word8)
 
data GetScreenSaver = MkGetScreenSaver{}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetScreenSaver where
        serialize x
          = do putWord8 108
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data GetScreenSaverReply = MkGetScreenSaverReply{timeout_GetScreenSaverReply
                                                 :: Word16,
                                                 interval_GetScreenSaverReply :: Word16,
                                                 prefer_blanking_GetScreenSaverReply :: Blanking,
                                                 allow_exposures_GetScreenSaverReply :: Exposures}
                         deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetScreenSaverReply where
        deserialize
          = do skip 1
               skip 1
               skip 2
               length <- deserialize
               timeout <- deserialize
               interval <- deserialize
               prefer_blanking <- liftM fromValue (deserialize :: Get Word8)
               allow_exposures <- liftM fromValue (deserialize :: Get Word8)
               skip 18
               let _ = isCard32 length
               return
                 (MkGetScreenSaverReply timeout interval prefer_blanking
                    allow_exposures)
 
data HostMode = HostModeInsert
              | HostModeDelete
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum HostMode where
        toValue HostModeInsert{} = 0
        toValue HostModeDelete{} = 1
        fromValue 0 = HostModeInsert
        fromValue 1 = HostModeDelete
 
data Family = FamilyInternet
            | FamilyDECnet
            | FamilyChaos
            | FamilyServerInterpreted
            | FamilyInternet6
            deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Family where
        toValue FamilyInternet{} = 0
        toValue FamilyDECnet{} = 1
        toValue FamilyChaos{} = 2
        toValue FamilyServerInterpreted{} = 5
        toValue FamilyInternet6{} = 6
        fromValue 0 = FamilyInternet
        fromValue 1 = FamilyDECnet
        fromValue 2 = FamilyChaos
        fromValue 5 = FamilyServerInterpreted
        fromValue 6 = FamilyInternet6
 
data ChangeHosts = MkChangeHosts{mode_ChangeHosts :: HostMode,
                                 family_ChangeHosts :: Family, address_len_ChangeHosts :: Word16,
                                 address_ChangeHosts :: [CChar]}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ChangeHosts where
        serialize x
          = do putWord8 109
               serialize (toValue (mode_ChangeHosts x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (toValue (family_ChangeHosts x) :: Word8)
               putSkip 1
               serialize (address_len_ChangeHosts x)
               serializeList (address_ChangeHosts x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (undefined :: Word8) + size (undefined :: Word8) + 1 +
              size (address_len_ChangeHosts x)
              + sum (map size (address_ChangeHosts x))
 
data HOST = MkHOST{family_HOST :: Family,
                   address_len_HOST :: Word16, address_HOST :: [Word8]}
          deriving (Show, Typeable, Eq, Ord)
 
instance Serialize HOST where
        serialize x
          = do serialize (toValue (family_HOST x) :: Word8)
               putSkip 1
               serialize (address_len_HOST x)
               serializeList (address_HOST x)
        size x
          = size (undefined :: Word8) + 1 + size (address_len_HOST x) +
              sum (map size (address_HOST x))
 
instance Deserialize HOST where
        deserialize
          = do family <- liftM fromValue (deserialize :: Get Word8)
               skip 1
               address_len <- deserialize
               address <- deserializeList (fromIntegral address_len)
               return (MkHOST family address_len address)
 
data ListHosts = MkListHosts{}
               deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ListHosts where
        serialize x
          = do putWord8 110
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data ListHostsReply = MkListHostsReply{mode_ListHostsReply ::
                                       AccessControl,
                                       hosts_len_ListHostsReply :: Word16,
                                       hosts_ListHostsReply :: [HOST]}
                    deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize ListHostsReply where
        deserialize
          = do skip 1
               mode <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               hosts_len <- deserialize
               skip 22
               hosts <- deserializeList (fromIntegral hosts_len)
               let _ = isCard32 length
               return (MkListHostsReply mode hosts_len hosts)
 
data AccessControl = AccessControlDisable
                   | AccessControlEnable
                   deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum AccessControl where
        toValue AccessControlDisable{} = 0
        toValue AccessControlEnable{} = 1
        fromValue 0 = AccessControlDisable
        fromValue 1 = AccessControlEnable
 
data SetAccessControl = MkSetAccessControl{mode_SetAccessControl ::
                                           AccessControl}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetAccessControl where
        serialize x
          = do putWord8 111
               serialize (toValue (mode_SetAccessControl x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 3 + size (undefined :: Word8)
 
data CloseDown = CloseDownDestroyAll
               | CloseDownRetainPermanent
               | CloseDownRetainTemporary
               deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum CloseDown where
        toValue CloseDownDestroyAll{} = 0
        toValue CloseDownRetainPermanent{} = 1
        toValue CloseDownRetainTemporary{} = 2
        fromValue 0 = CloseDownDestroyAll
        fromValue 1 = CloseDownRetainPermanent
        fromValue 2 = CloseDownRetainTemporary
 
data SetCloseDownMode = MkSetCloseDownMode{mode_SetCloseDownMode ::
                                           CloseDown}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetCloseDownMode where
        serialize x
          = do putWord8 112
               serialize (toValue (mode_SetCloseDownMode x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 3 + size (undefined :: Word8)
 
data Kill = KillAllTemporary
          deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum Kill where
        toValue KillAllTemporary{} = 0
        fromValue 0 = KillAllTemporary
 
data KillClient = MkKillClient{resource_KillClient :: Word32}
                deriving (Show, Typeable, Eq, Ord)
 
instance Serialize KillClient where
        serialize x
          = do putWord8 113
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (resource_KillClient x)
               putSkip (requiredPadding (size x))
        size x = 3 + 1 + size (resource_KillClient x)
 
data RotateProperties = MkRotateProperties{window_RotateProperties
                                           :: WINDOW,
                                           atoms_len_RotateProperties :: Word16,
                                           delta_RotateProperties :: Int16,
                                           atoms_RotateProperties :: [ATOM]}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Serialize RotateProperties where
        serialize x
          = do putWord8 114
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serialize (window_RotateProperties x)
               serialize (atoms_len_RotateProperties x)
               serialize (delta_RotateProperties x)
               serializeList (atoms_RotateProperties x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + 1 + size (window_RotateProperties x) +
              size (atoms_len_RotateProperties x)
              + size (delta_RotateProperties x)
              + sum (map size (atoms_RotateProperties x))
 
data ScreenSaver = ScreenSaverReset
                 | ScreenSaverActive
                 deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum ScreenSaver where
        toValue ScreenSaverReset{} = 0
        toValue ScreenSaverActive{} = 1
        fromValue 0 = ScreenSaverReset
        fromValue 1 = ScreenSaverActive
 
data ForceScreenSaver = MkForceScreenSaver{mode_ForceScreenSaver ::
                                           ScreenSaver}
                      deriving (Show, Typeable, Eq, Ord)
 
instance Serialize ForceScreenSaver where
        serialize x
          = do putWord8 115
               serialize (toValue (mode_ForceScreenSaver x) :: Word8)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 3 + size (undefined :: Word8)
 
data MappingStatus = MappingStatusSuccess
                   | MappingStatusBusy
                   | MappingStatusFailure
                   deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum MappingStatus where
        toValue MappingStatusSuccess{} = 0
        toValue MappingStatusBusy{} = 1
        toValue MappingStatusFailure{} = 2
        fromValue 0 = MappingStatusSuccess
        fromValue 1 = MappingStatusBusy
        fromValue 2 = MappingStatusFailure
 
data SetPointerMapping = MkSetPointerMapping{map_len_SetPointerMapping
                                             :: Word8,
                                             map_SetPointerMapping :: [Word8]}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetPointerMapping where
        serialize x
          = do putWord8 116
               serialize (map_len_SetPointerMapping x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serializeList (map_SetPointerMapping x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (map_len_SetPointerMapping x) +
              sum (map size (map_SetPointerMapping x))
 
data SetPointerMappingReply = MkSetPointerMappingReply{status_SetPointerMappingReply
                                                       :: MappingStatus}
                            deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize SetPointerMappingReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               let _ = isCard32 length
               return (MkSetPointerMappingReply status)
 
data GetPointerMapping = MkGetPointerMapping{}
                       deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetPointerMapping where
        serialize x
          = do putWord8 117
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data GetPointerMappingReply = MkGetPointerMappingReply{map_len_GetPointerMappingReply
                                                       :: Word8,
                                                       map_GetPointerMappingReply :: [Word8]}
                            deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetPointerMappingReply where
        deserialize
          = do skip 1
               map_len <- deserialize
               skip 2
               length <- deserialize
               skip 24
               map <- deserializeList (fromIntegral map_len)
               let _ = isCard32 length
               return (MkGetPointerMappingReply map_len map)
 
data MapIndex = MapIndexShift
              | MapIndexLock
              | MapIndexControl
              | MapIndex1
              | MapIndex2
              | MapIndex3
              | MapIndex4
              | MapIndex5
              deriving (Show, Eq, Ord, Enum)
 
instance SimpleEnum MapIndex where
        toValue MapIndexShift{} = 0
        toValue MapIndexLock{} = 1
        toValue MapIndexControl{} = 2
        toValue MapIndex1{} = 3
        toValue MapIndex2{} = 4
        toValue MapIndex3{} = 5
        toValue MapIndex4{} = 6
        toValue MapIndex5{} = 7
        fromValue 0 = MapIndexShift
        fromValue 1 = MapIndexLock
        fromValue 2 = MapIndexControl
        fromValue 3 = MapIndex1
        fromValue 4 = MapIndex2
        fromValue 5 = MapIndex3
        fromValue 6 = MapIndex4
        fromValue 7 = MapIndex5
 
data SetModifierMapping = MkSetModifierMapping{keycodes_per_modifier_SetModifierMapping
                                               :: Word8,
                                               keycodes_SetModifierMapping :: [KEYCODE]}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Serialize SetModifierMapping where
        serialize x
          = do putWord8 118
               serialize (keycodes_per_modifier_SetModifierMapping x)
               serialize (convertBytesToRequestSize (size x) :: Int16)
               serializeList (keycodes_SetModifierMapping x)
               putSkip (requiredPadding (size x))
        size x
          = 3 + size (keycodes_per_modifier_SetModifierMapping x) +
              sum (map size (keycodes_SetModifierMapping x))
 
data SetModifierMappingReply = MkSetModifierMappingReply{status_SetModifierMappingReply
                                                         :: MappingStatus}
                             deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize SetModifierMappingReply where
        deserialize
          = do skip 1
               status <- liftM fromValue (deserialize :: Get Word8)
               skip 2
               length <- deserialize
               let _ = isCard32 length
               return (MkSetModifierMappingReply status)
 
data GetModifierMapping = MkGetModifierMapping{}
                        deriving (Show, Typeable, Eq, Ord)
 
instance Serialize GetModifierMapping where
        serialize x
          = do putWord8 119
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4
 
data GetModifierMappingReply = MkGetModifierMappingReply{keycodes_per_modifier_GetModifierMappingReply
                                                         :: Word8,
                                                         keycodes_GetModifierMappingReply ::
                                                         [KEYCODE]}
                             deriving (Show, Typeable, Eq, Ord)
 
instance Deserialize GetModifierMappingReply where
        deserialize
          = do skip 1
               keycodes_per_modifier <- deserialize
               skip 2
               length <- deserialize
               skip 24
               keycodes <- deserializeList
                             (fromIntegral (fromIntegral (keycodes_per_modifier * 8)))
               let _ = isCard32 length
               return (MkGetModifierMappingReply keycodes_per_modifier keycodes)
 
data NoOperation = MkNoOperation{}
                 deriving (Show, Typeable, Eq, Ord)
 
instance Serialize NoOperation where
        serialize x
          = do putWord8 127
               putSkip 1
               serialize (convertBytesToRequestSize (size x) :: Int16)
               putSkip (requiredPadding (size x))
        size x = 4