module GI.WebKit.Objects.IconDatabase
(
IconDatabase(..) ,
IconDatabaseK ,
toIconDatabase ,
noIconDatabase ,
iconDatabaseClear ,
iconDatabaseGetIconPixbuf ,
iconDatabaseGetIconUri ,
iconDatabaseGetPath ,
iconDatabaseSetPath ,
IconDatabasePathPropertyInfo ,
constructIconDatabasePath ,
getIconDatabasePath ,
setIconDatabasePath ,
IconDatabaseIconLoadedCallback ,
IconDatabaseIconLoadedCallbackC ,
IconDatabaseIconLoadedSignalInfo ,
afterIconDatabaseIconLoaded ,
iconDatabaseIconLoadedCallbackWrapper ,
iconDatabaseIconLoadedClosure ,
mkIconDatabaseIconLoadedCallback ,
noIconDatabaseIconLoadedCallback ,
onIconDatabaseIconLoaded ,
) 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.WebKit.Types
import GI.WebKit.Callbacks
import qualified GI.GObject as GObject
import qualified GI.GdkPixbuf as GdkPixbuf
newtype IconDatabase = IconDatabase (ForeignPtr IconDatabase)
foreign import ccall "webkit_icon_database_get_type"
c_webkit_icon_database_get_type :: IO GType
type instance ParentTypes IconDatabase = IconDatabaseParentTypes
type IconDatabaseParentTypes = '[GObject.Object]
instance GObject IconDatabase where
gobjectIsInitiallyUnowned _ = False
gobjectType _ = c_webkit_icon_database_get_type
class GObject o => IconDatabaseK o
instance (GObject o, IsDescendantOf IconDatabase o) => IconDatabaseK o
toIconDatabase :: IconDatabaseK o => o -> IO IconDatabase
toIconDatabase = unsafeCastTo IconDatabase
noIconDatabase :: Maybe IconDatabase
noIconDatabase = Nothing
type IconDatabaseIconLoadedCallback =
WebFrame ->
T.Text ->
IO ()
noIconDatabaseIconLoadedCallback :: Maybe IconDatabaseIconLoadedCallback
noIconDatabaseIconLoadedCallback = Nothing
type IconDatabaseIconLoadedCallbackC =
Ptr () ->
Ptr WebFrame ->
CString ->
Ptr () ->
IO ()
foreign import ccall "wrapper"
mkIconDatabaseIconLoadedCallback :: IconDatabaseIconLoadedCallbackC -> IO (FunPtr IconDatabaseIconLoadedCallbackC)
iconDatabaseIconLoadedClosure :: IconDatabaseIconLoadedCallback -> IO Closure
iconDatabaseIconLoadedClosure cb = newCClosure =<< mkIconDatabaseIconLoadedCallback wrapped
where wrapped = iconDatabaseIconLoadedCallbackWrapper cb
iconDatabaseIconLoadedCallbackWrapper ::
IconDatabaseIconLoadedCallback ->
Ptr () ->
Ptr WebFrame ->
CString ->
Ptr () ->
IO ()
iconDatabaseIconLoadedCallbackWrapper _cb _ frame frame_uri _ = do
frame' <- (newObject WebFrame) frame
frame_uri' <- cstringToText frame_uri
_cb frame' frame_uri'
onIconDatabaseIconLoaded :: (GObject a, MonadIO m) => a -> IconDatabaseIconLoadedCallback -> m SignalHandlerId
onIconDatabaseIconLoaded obj cb = liftIO $ connectIconDatabaseIconLoaded obj cb SignalConnectBefore
afterIconDatabaseIconLoaded :: (GObject a, MonadIO m) => a -> IconDatabaseIconLoadedCallback -> m SignalHandlerId
afterIconDatabaseIconLoaded obj cb = connectIconDatabaseIconLoaded obj cb SignalConnectAfter
connectIconDatabaseIconLoaded :: (GObject a, MonadIO m) =>
a -> IconDatabaseIconLoadedCallback -> SignalConnectMode -> m SignalHandlerId
connectIconDatabaseIconLoaded obj cb after = liftIO $ do
cb' <- mkIconDatabaseIconLoadedCallback (iconDatabaseIconLoadedCallbackWrapper cb)
connectSignalFunPtr obj "icon-loaded" cb' after
getIconDatabasePath :: (MonadIO m, IconDatabaseK o) => o -> m T.Text
getIconDatabasePath obj = liftIO $ getObjectPropertyString obj "path"
setIconDatabasePath :: (MonadIO m, IconDatabaseK o) => o -> T.Text -> m ()
setIconDatabasePath obj val = liftIO $ setObjectPropertyString obj "path" val
constructIconDatabasePath :: T.Text -> IO ([Char], GValue)
constructIconDatabasePath val = constructObjectPropertyString "path" val
data IconDatabasePathPropertyInfo
instance AttrInfo IconDatabasePathPropertyInfo where
type AttrAllowedOps IconDatabasePathPropertyInfo = '[ 'AttrSet, 'AttrConstruct, 'AttrGet]
type AttrSetTypeConstraint IconDatabasePathPropertyInfo = (~) T.Text
type AttrBaseTypeConstraint IconDatabasePathPropertyInfo = IconDatabaseK
type AttrGetType IconDatabasePathPropertyInfo = T.Text
type AttrLabel IconDatabasePathPropertyInfo = "IconDatabase::path"
attrGet _ = getIconDatabasePath
attrSet _ = setIconDatabasePath
attrConstruct _ = constructIconDatabasePath
type instance AttributeList IconDatabase = IconDatabaseAttributeList
type IconDatabaseAttributeList = ('[ '("path", IconDatabasePathPropertyInfo)] :: [(Symbol, *)])
data IconDatabaseIconLoadedSignalInfo
instance SignalInfo IconDatabaseIconLoadedSignalInfo where
type HaskellCallbackType IconDatabaseIconLoadedSignalInfo = IconDatabaseIconLoadedCallback
connectSignal _ = connectIconDatabaseIconLoaded
type instance SignalList IconDatabase = IconDatabaseSignalList
type IconDatabaseSignalList = ('[ '("icon-loaded", IconDatabaseIconLoadedSignalInfo), '("notify", GObject.ObjectNotifySignalInfo), '("notify::[property]", GObjectNotifySignalInfo)] :: [(Symbol, *)])
foreign import ccall "webkit_icon_database_clear" webkit_icon_database_clear ::
Ptr IconDatabase ->
IO ()
iconDatabaseClear ::
(MonadIO m, IconDatabaseK a) =>
a ->
m ()
iconDatabaseClear _obj = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
webkit_icon_database_clear _obj'
touchManagedPtr _obj
return ()
foreign import ccall "webkit_icon_database_get_icon_pixbuf" webkit_icon_database_get_icon_pixbuf ::
Ptr IconDatabase ->
CString ->
IO (Ptr GdkPixbuf.Pixbuf)
iconDatabaseGetIconPixbuf ::
(MonadIO m, IconDatabaseK a) =>
a ->
T.Text ->
m GdkPixbuf.Pixbuf
iconDatabaseGetIconPixbuf _obj page_uri = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
page_uri' <- textToCString page_uri
result <- webkit_icon_database_get_icon_pixbuf _obj' page_uri'
checkUnexpectedReturnNULL "webkit_icon_database_get_icon_pixbuf" result
result' <- (wrapObject GdkPixbuf.Pixbuf) result
touchManagedPtr _obj
freeMem page_uri'
return result'
foreign import ccall "webkit_icon_database_get_icon_uri" webkit_icon_database_get_icon_uri ::
Ptr IconDatabase ->
CString ->
IO CString
iconDatabaseGetIconUri ::
(MonadIO m, IconDatabaseK a) =>
a ->
T.Text ->
m T.Text
iconDatabaseGetIconUri _obj page_uri = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
page_uri' <- textToCString page_uri
result <- webkit_icon_database_get_icon_uri _obj' page_uri'
checkUnexpectedReturnNULL "webkit_icon_database_get_icon_uri" result
result' <- cstringToText result
freeMem result
touchManagedPtr _obj
freeMem page_uri'
return result'
foreign import ccall "webkit_icon_database_get_path" webkit_icon_database_get_path ::
Ptr IconDatabase ->
IO CString
iconDatabaseGetPath ::
(MonadIO m, IconDatabaseK a) =>
a ->
m T.Text
iconDatabaseGetPath _obj = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
result <- webkit_icon_database_get_path _obj'
checkUnexpectedReturnNULL "webkit_icon_database_get_path" result
result' <- cstringToText result
touchManagedPtr _obj
return result'
foreign import ccall "webkit_icon_database_set_path" webkit_icon_database_set_path ::
Ptr IconDatabase ->
CString ->
IO ()
iconDatabaseSetPath ::
(MonadIO m, IconDatabaseK a) =>
a ->
T.Text ->
m ()
iconDatabaseSetPath _obj path = liftIO $ do
let _obj' = unsafeManagedPtrCastPtr _obj
path' <- textToCString path
webkit_icon_database_set_path _obj' path'
touchManagedPtr _obj
freeMem path'
return ()