{-# LINE 2 "./System/GIO/Icons/Emblem.chs" #-} -- GIMP Toolkit (GTK) Binding for Haskell: binding to gio -*-haskell-*- -- -- Author : Andy Stewart -- Created: 30-Apirl-2010 -- -- Copyright (c) 2010 Andy Stewart -- -- 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 3 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. -- -- You should have received a copy of the GNU Lesser General Public -- License along with this program. If not, see -- <http: -- -- GIO, the C library which this Haskell library depends on, is -- available under LGPL Version 2. The documentation included with -- this library is based on the original GIO documentation. -- -- | Maintainer : gtk2hs-devel@lists.sourceforge.net -- Stability : alpha -- Portability : portable (depends on GHC) module System.GIO.Icons.Emblem ( -- * Details -- -- | 'Emblem' is an implementation of 'Icon' that supports having an emblem, which is an icon with -- additional properties. It can than be added to a 'EmblemedIcon'. -- -- Currently, only metainformation about the emblem's origin is supported. More may be added in the -- future. -- * Types Emblem(..), EmblemClass, -- * Enums EmblemOrigin (..), -- * Methods emblemNew, emblemNewWithOrigin, emblemGetIcon, emblemGetOrigin, ) where import Control.Monad import System.GIO.Enums import System.Glib.FFI import System.Glib.Flags import System.Glib.GError import System.Glib.GObject import System.Glib.UTFString import System.GIO.Types {-# LINE 63 "./System/GIO/Icons/Emblem.chs" #-} {-# LINE 65 "./System/GIO/Icons/Emblem.chs" #-} ------------------- -- Methods -- | Creates a new emblem for icon. emblemNew :: IconClass icon => icon -> IO Emblem emblemNew icon = wrapNewGObject mkEmblem $ (\(Icon arg1) -> withForeignPtr arg1 $ \argPtr1 ->g_emblem_new argPtr1) (toIcon icon) -- | Creates a new emblem for icon. emblemNewWithOrigin :: IconClass icon => icon -- ^ @icon@ a 'Icon' containing the icon. -> EmblemOrigin -- ^ @origin@ a 'EmblemOrigin' enum defining the emblem's origin -> IO Emblem emblemNewWithOrigin icon origin = wrapNewGObject mkEmblem $ (\(Icon arg1) arg2 -> withForeignPtr arg1 $ \argPtr1 ->g_emblem_new_with_origin argPtr1 arg2) (toIcon icon) ((fromIntegral . fromEnum) origin) -- | Gives back the icon from emblem. emblemGetIcon :: EmblemClass emblem => emblem -- ^ @emblem@ a 'Emblem' from which the icon should be extracted. -> IO Icon -- ^ returns a 'Icon'. The returned object belongs to the emblem and should not be modified or freed. emblemGetIcon emblem = makeNewGObject mkIcon $ (\(Emblem arg1) -> withForeignPtr arg1 $ \argPtr1 ->g_emblem_get_icon argPtr1) (toEmblem emblem) -- | Gets the origin of the emblem. emblemGetOrigin :: EmblemClass emblem => emblem -> IO EmblemOrigin emblemGetOrigin emblem = liftM (toEnum . fromIntegral) $ (\(Emblem arg1) -> withForeignPtr arg1 $ \argPtr1 ->g_emblem_get_origin argPtr1) (toEmblem emblem) foreign import ccall safe "g_emblem_new" g_emblem_new :: ((Ptr Icon) -> (IO (Ptr Emblem))) foreign import ccall safe "g_emblem_new_with_origin" g_emblem_new_with_origin :: ((Ptr Icon) -> (CInt -> (IO (Ptr Emblem)))) foreign import ccall safe "g_emblem_get_icon" g_emblem_get_icon :: ((Ptr Emblem) -> (IO (Ptr Icon))) foreign import ccall safe "g_emblem_get_origin" g_emblem_get_origin :: ((Ptr Emblem) -> (IO CInt))