-- 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/JPEGImage.chs" #-}
{-# LANGUAGE CPP, TypeSynonymInstances, FlexibleInstances, MultiParamTypeClasses, FlexibleContexts #-}
{-# OPTIONS_GHC -fno-warn-orphans #-}
module Graphics.UI.FLTK.LowLevel.JPEGImage
    (
     jpegImageNew,
     jpegImageNewWithData
     -- * 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.ByteString as B
import qualified Data.Text as T
jpegImageNew' :: (CString) -> IO ((Ptr ()))
jpegImageNew' a1 =
  (flip ($)) a1 $ \a1' -> 
  CString -> IO (Ptr ())
jpegImageNew''_ CString
a1' IO (Ptr ()) -> (Ptr () -> IO (Ptr ())) -> IO (Ptr ())
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= \res :: Ptr ()
res ->
  let {res' = id res} in
  Ptr () -> IO (Ptr ())
forall (m :: * -> *) a. Monad m => a -> m a
return (Ptr ()
res')

{-# LINE 23 "src/Graphics/UI/FLTK/LowLevel/JPEGImage.chs" #-}

jpegImageNewWithData' :: (CString) -> (Ptr CUChar) -> IO ((Ptr ()))
jpegImageNewWithData' a1 a2 =
  (flip ($)) a1 $ \a1' -> 
  let {a2' = id a2} in 
  jpegImageNewWithData''_ a1' a2' >>= \res ->
  let {res' = id res} in
  return (res')

{-# LINE 24 "src/Graphics/UI/FLTK/LowLevel/JPEGImage.chs" #-}

jpegImageNew :: T.Text -> IO (Either UnknownError (Ref JPEGImage))
jpegImageNew filename' = withText filename' jpegImageNew' >>= toRef >>= checkImage

jpegImageNewWithData :: T.Text -> B.ByteString -> IO (Either UnknownError (Ref JPEGImage))
jpegImageNewWithData l' data' = do
  jpeg' <- copyByteStringToCString data'
  labelString <- copyTextToCString l'
  jpegImageNewWithData' labelString (castPtr jpeg') >>= toRef >>= checkImage

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

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

foreign import ccall safe "Graphics/UI/FLTK/LowLevel/JPEGImage.chs.h Fl_JPEG_Image_New_WithData"
  jpegImageNewWithData''_ :: ((C2HSImp.Ptr C2HSImp.CChar) -> ((C2HSImp.Ptr C2HSImp.CUChar) -> (IO (C2HSImp.Ptr ()))))