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
|
{-# LANGUAGE CPP #-}
-- -*-haskell-*-
-----------------------------------------------------------------------------
-- Module : Graphics.UI.Gtk.WebKit.NetworkRequest
-- Author : Cjacker Huang
-- Copyright : (c) 2009 Cjacker Huang <jzhuang@redflag-linux.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)
--
-- The target of a navigation request
-----------------------------------------------------------------------------
module Graphics.UI.Gtk.WebKit.NetworkRequest (
-- * Types
NetworkRequest,
-- * Constructors
networkRequestNew,
-- * Methods
networkRequestSetUri,
networkRequestGetUri,
) 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"#}
------------------
-- Constructors
-- | Create a new NetworkRequest with the given @uri@.
--
-- It is used whenever WebKit wants to provide information
-- about a request that will be sent, or has been sent.
networkRequestNew ::
String -- ^ @uri@ - the uri of the request
-> IO NetworkRequest
networkRequestNew uri =
withCString uri $ \uriPtr ->
constructNewGObject mkNetworkRequest $
{#call network_request_new#} uriPtr
-- | Set the URI of 'NetworkRequest'.
--
networkRequestSetUri ::
NetworkRequestClass self => self
-> String -- ^ @uri@ - the uri will be set to the request.
-> IO()
networkRequestSetUri networkrequest uri =
withCString uri $ \uriPtr ->
{#call network_request_set_uri#}
(toNetworkRequest networkrequest)
uriPtr
-- | Return the uri of 'NetworkRequest'.
networkRequestGetUri ::
NetworkRequestClass self => self
-> IO (Maybe String) -- ^ the URI or @Nothing@ in case failed.
networkRequestGetUri networkrequest =
{#call network_request_get_uri#}
(toNetworkRequest networkrequest) >>=
maybePeek peekCString
|