module GI.Soup.Objects.ContentSniffer
(
ContentSniffer(..) ,
ContentSnifferK ,
toContentSniffer ,
noContentSniffer ,
contentSnifferGetBufferSize ,
contentSnifferNew ,
contentSnifferSniff ,
) where
import Prelude ()
import Data.GI.Base.ShortPrelude
import qualified Data.Text as T
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import GI.Soup.Types
import GI.Soup.Callbacks
import qualified GI.GObject as GObject
newtype ContentSniffer = ContentSniffer (ForeignPtr ContentSniffer)
foreign import ccall "soup_content_sniffer_get_type"
c_soup_content_sniffer_get_type :: IO GType
type instance ParentTypes ContentSniffer = ContentSnifferParentTypes
type ContentSnifferParentTypes = '[GObject.Object, SessionFeature]
instance GObject ContentSniffer where
gobjectIsInitiallyUnowned _ = False
gobjectType _ = c_soup_content_sniffer_get_type
class GObject o => ContentSnifferK o
instance (GObject o, IsDescendantOf ContentSniffer o) => ContentSnifferK o
toContentSniffer :: ContentSnifferK o => o -> IO ContentSniffer
toContentSniffer = unsafeCastTo ContentSniffer
noContentSniffer :: Maybe ContentSniffer
noContentSniffer = Nothing
type instance AttributeList ContentSniffer = ContentSnifferAttributeList
type ContentSnifferAttributeList = ('[ ] :: [(Symbol, *)])
type instance SignalList ContentSniffer = ContentSnifferSignalList
type ContentSnifferSignalList = ('[ '("notify", GObject.ObjectNotifySignalInfo), '("notify::[property]", GObjectNotifySignalInfo)] :: [(Symbol, *)])
foreign import ccall "soup_content_sniffer_new" soup_content_sniffer_new ::
IO (Ptr ContentSniffer)
contentSnifferNew ::
(MonadIO m) =>
m ContentSniffer
contentSnifferNew = liftIO $ do
result <- soup_content_sniffer_new
checkUnexpectedReturnNULL "soup_content_sniffer_new" result
result' <- (wrapObject ContentSniffer) result
return result'
foreign import ccall "soup_content_sniffer_get_buffer_size" soup_content_sniffer_get_buffer_size ::
Ptr ContentSniffer ->
IO Word64
contentSnifferGetBufferSize ::
(MonadIO m, ContentSnifferK a) =>
a ->
m Word64
contentSnifferGetBufferSize _obj = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
result <- soup_content_sniffer_get_buffer_size _obj'
touchManagedPtr _obj
return result
foreign import ccall "soup_content_sniffer_sniff" soup_content_sniffer_sniff ::
Ptr ContentSniffer ->
Ptr Message ->
Ptr Buffer ->
Ptr (Ptr (GHashTable CString CString)) ->
IO CString
contentSnifferSniff ::
(MonadIO m, ContentSnifferK a, MessageK b) =>
a ->
b ->
Buffer ->
m (T.Text,(Map.Map T.Text T.Text))
contentSnifferSniff _obj msg buffer = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
let msg' = unsafeManagedPtrCastPtr msg
let buffer' = unsafeManagedPtrGetPtr buffer
params <- allocMem :: IO (Ptr (Ptr (GHashTable CString CString)))
result <- soup_content_sniffer_sniff _obj' msg' buffer' params
checkUnexpectedReturnNULL "soup_content_sniffer_sniff" result
result' <- cstringToText result
freeMem result
params' <- peek params
params'' <- unpackGHashTable params'
let params''' = mapFirst cstringUnpackPtr params''
params'''' <- mapFirstA cstringToText params'''
let params''''' = mapSecond cstringUnpackPtr params''''
params'''''' <- mapSecondA cstringToText params'''''
let params''''''' = Map.fromList params''''''
unrefGHashTable params'
touchManagedPtr _obj
touchManagedPtr msg
touchManagedPtr buffer
freeMem params
return (result', params''''''')