-- GENERATED by C->Haskell Compiler, version 0.28.6 Switcheroo, 25 November 2017 (Haskell)
-- Edit the ORIGNAL .chs file instead!


{-# LINE 1 "src/Graphics/UI/FLTK/LowLevel/XPMImage.chs" #-}
{-# LANGUAGE CPP, TypeSynonymInstances, FlexibleInstances, MultiParamTypeClasses, FlexibleContexts #-}
{-# OPTIONS_GHC -fno-warn-orphans #-}
module Graphics.UI.FLTK.LowLevel.XPMImage
    (
     xpmImageNew
     -- * Hierarchy
     --
     -- $hierarchy

    )
where
import qualified Foreign.C.Types as C2HSImp
import qualified Foreign.Ptr as C2HSImp





import C2HS hiding (cFromEnum, cFromBool, cToBool,cToEnum)
import Graphics.UI.FLTK.LowLevel.Fl_Types
import Graphics.UI.FLTK.LowLevel.Utils
import Graphics.UI.FLTK.LowLevel.Hierarchy
import Graphics.UI.FLTK.LowLevel.RGBImage
import qualified Data.Text as T
xpmImageNew' :: (T.Text) -> IO ((Ptr ()))
xpmImageNew' a1 =
  let {a1' = unsafeToCString a1} in
  xpmImageNew''_ a1' >>= \res ->
  let {res' = id res} in
  return (res')

{-# LINE 21 "src/Graphics/UI/FLTK/LowLevel/XPMImage.chs" #-}

xpmImageNew :: T.Text -> IO (Either UnknownError (Ref XPMImage))
xpmImageNew filename' = do
  ptr <- xpmImageNew' filename'
  ref' <- (toRef ptr :: IO (Ref XPMImage))
  checkImage ref'

-- $hierarchy
-- @
-- "Graphics.UI.FLTK.LowLevel.Image"
--  |
--  v
-- "Graphics.UI.FLTK.LowLevel.RGBImage"
--  |
--  v
-- "Graphics.UI.FLTK.LowLevel.XPMImage"
-- @

foreign import ccall safe "Graphics/UI/FLTK/LowLevel/XPMImage.chs.h Fl_XPM_Image_New"
  xpmImageNew''_ :: ((C2HSImp.Ptr C2HSImp.CChar) -> (IO (C2HSImp.Ptr ())))