1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
|
{-# LANGUAGE CPP #-}
-- -*-haskell-*-
-----------------------------------------------------------------------------
-- Module : Graphics.UI.Gtk.WebKit.WebResource
-- Author : Andy Stewart
-- Copyright : (c) 2010 Andy Stewart <lazycat.manatee@gmail.com>
--
-- This library is free software; you can redistribute it and/or
-- modify it under the terms of the GNU Lesser General Public
-- License as published by the Free Software Foundation; either
-- version 2.1 of the License, or (at your option) any later version.
--
-- This library is distributed in the hope that it will be useful,
-- but WITHOUT ANY WARRANTY; without even the implied warranty of
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-- Lesser General Public License for more details.
--
-- |
-- Maintainer : gtk2hs-users@lists.sourceforge.net
-- Stability : provisional
-- Portability : portable (depends on GHC)
--
-- Note:
--
-- Function `webkit_web_resource_get_data` haven't binding
-- no idea how to handle `GString`.
--
-- Access to the WebKit Web Resource
-----------------------------------------------------------------------------
module Graphics.UI.Gtk.WebKit.WebResource (
-- * Types
WebResource,
-- * Constructors
webResourceNew,
-- * Methods
webResourceGetEncoding,
webResourceGetFrameName,
webResourceGetMimeType,
webResourceGetUri,
) where
import Control.Monad (liftM)
import System.Glib.FFI
import System.Glib.UTFString
import System.Glib.GList
import System.Glib.GError
import Graphics.UI.Gtk.Gdk.Events
{#import Graphics.UI.Gtk.Abstract.Object#} (makeNewObject)
{#import Graphics.UI.Gtk.WebKit.Types#}
{#import System.Glib.GObject#}
{#context lib="webkit" prefix ="webkit"#}
-- | Returns a new WebKitWebResource.
-- The @encoding@ can be empty.
-- The @frameName@ can be used if the resource represents contents of an
-- entire HTML frame, otherwise pass empty.
webResourceNew :: String -> Int -> String -> String -> String -> String -> IO WebResource
webResourceNew resData size uri mimeType encoding frameName =
withCString resData $ \dataPtr ->
withCString uri $ \uriPtr ->
withCString mimeType $ \mimePtr ->
withCString encoding $ \encodingPtr ->
withCString frameName $ \framePtr ->
constructNewGObject mkWebResource $
{#call web_resource_new#} dataPtr (fromIntegral size) uriPtr mimePtr encodingPtr framePtr
-- | Get encoding.
webResourceGetEncoding ::
WebResourceClass self => self
-> IO String
webResourceGetEncoding wr =
{#call web_resource_get_encoding#} (toWebResource wr) >>= peekCString
-- | Get frame name.
webResourceGetFrameName ::
WebResourceClass self => self
-> IO String
webResourceGetFrameName wr =
{#call web_resource_get_frame_name#} (toWebResource wr) >>= peekCString
-- | Get mime type.
webResourceGetMimeType ::
WebResourceClass self => self
-> IO String
webResourceGetMimeType wr =
{#call web_resource_get_mime_type#} (toWebResource wr) >>= peekCString
-- | Get uri.
webResourceGetUri ::
WebResourceClass self => self
-> IO String
webResourceGetUri wr =
{#call web_resource_get_uri#} (toWebResource wr) >>= peekCString
|