Script 'mail_helper' called by obssrc
Hello community,

here is the log from the commit of package ghc-X11-xft for openSUSE:Factory 
checked in at 2022-02-11 23:10:03
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/ghc-X11-xft (Old)
 and      /work/SRC/openSUSE:Factory/.ghc-X11-xft.new.1956 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "ghc-X11-xft"

Fri Feb 11 23:10:03 2022 rev:7 rq:953565 version:0.3.4

Changes:
--------
--- /work/SRC/openSUSE:Factory/ghc-X11-xft/ghc-X11-xft.changes  2020-12-22 
11:34:09.413179629 +0100
+++ /work/SRC/openSUSE:Factory/.ghc-X11-xft.new.1956/ghc-X11-xft.changes        
2022-02-11 23:12:02.767403520 +0100
@@ -1,0 +2,8 @@
+Sat Dec 11 12:24:35 UTC 2021 - Peter Simons <[email protected]>
+
+- Update X11-xft to version 0.3.4.
+  Upstream added a new change log file in this release. With no
+  previous version to compare against, the automatic updater cannot
+  reliable determine the relevante entries for this release.
+
+-------------------------------------------------------------------

Old:
----
  X11-xft-0.3.1.tar.gz

New:
----
  X11-xft-0.3.4.tar.gz

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Other differences:
------------------
++++++ ghc-X11-xft.spec ++++++
--- /var/tmp/diff_new_pack.YF8pog/_old  2022-02-11 23:12:03.119404538 +0100
+++ /var/tmp/diff_new_pack.YF8pog/_new  2022-02-11 23:12:03.123404549 +0100
@@ -1,7 +1,7 @@
 #
 # spec file for package ghc-X11-xft
 #
-# Copyright (c) 2020 SUSE LLC
+# Copyright (c) 2021 SUSE LLC
 #
 # All modifications and additions to the file contributed by third parties
 # remain the property of their copyright owners, unless otherwise agreed
@@ -18,10 +18,10 @@
 
 %global pkg_name X11-xft
 Name:           ghc-%{pkg_name}
-Version:        0.3.1
+Version:        0.3.4
 Release:        0
-Summary:        Bindings to the Xft, X Free Type interface library, and some 
Xrender parts
-License:        LGPL-2.1-or-later
+Summary:        Bindings to the Xft and some Xrender parts
+License:        BSD-3-Clause
 URL:            https://hackage.haskell.org/package/%{pkg_name}
 Source0:        
https://hackage.haskell.org/package/%{pkg_name}-%{version}/%{pkg_name}-%{version}.tar.gz
 BuildRequires:  ghc-Cabal-devel
@@ -34,7 +34,10 @@
 ExcludeArch:    %{ix86}
 
 %description
-Bindings to the Xft, X Free Type interface library, and some Xrender parts.
+A Haskell bindings to the X Font library. With it, Haskell X11 applications can
+access high quality font renderings and provide fonts with anti-aliasing and
+subpixel rendering. The bindings also provide minimal bindings to Xrender
+parts.
 
 %package devel
 Summary:        Haskell %{pkg_name} library development files
@@ -67,5 +70,6 @@
 %license LICENSE
 
 %files devel -f %{name}-devel.files
+%doc CHANGES.md README.md
 
 %changelog

++++++ X11-xft-0.3.1.tar.gz -> X11-xft-0.3.4.tar.gz ++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/X11-xft-0.3.1/CHANGES.md new/X11-xft-0.3.4/CHANGES.md
--- old/X11-xft-0.3.1/CHANGES.md        1970-01-01 01:00:00.000000000 +0100
+++ new/X11-xft-0.3.4/CHANGES.md        2001-09-09 03:46:40.000000000 +0200
@@ -0,0 +1,20 @@
+# Change Log / Release Notes
+
+## 0.3.4 (2021-12-11)
+
+  * Dropped support for GHC 7.10.
+
+  * Added `xftDrawStringFallback`, which works like `xftDrawString` but
+    supports font fallback.
+
+  * Added `xftTextAccumExtents`, which works like `xftTextExtents` but
+    possibly uses different fonts for different parts of the string and
+    returns the accumulative extents.
+
+  * Added the functions `xftfont_max_ascent`, `xftfont_max_descent`, and
+    `xftfont_max_height` to gain information about a non-empty list of
+    `XftFont`s.
+
+## 0.3.3 (2021-12-01)
+
+  * Fixed flipped green/blue values in XRenderColor.
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/X11-xft-0.3.1/Graphics/X11/Xft.hsc 
new/X11-xft-0.3.4/Graphics/X11/Xft.hsc
--- old/X11-xft-0.3.1/Graphics/X11/Xft.hsc      2011-10-01 08:18:12.000000000 
+0200
+++ new/X11-xft-0.3.4/Graphics/X11/Xft.hsc      2001-09-09 03:46:40.000000000 
+0200
@@ -1,3 +1,5 @@
+{-# LANGUAGE ForeignFunctionInterface #-}
+
 -----------------------------------------------------------------------------
 -- Module      :  Graphics.X11.Xft
 -- Copyright   :  Clemens Fruhwirth <[email protected]> 2007
@@ -7,57 +9,61 @@
 -----------------------------------------------------------------------------
 
 module Graphics.X11.Xft ( XftColor
-                       , xftcolor_pixel
-                       , allocaXftColor
-                       , withXftColorName
-                       , withXftColorValue
-                       , XftDraw
-                       , withXftDraw
-                       , xftDrawCreate
-                       , xftDrawCreateBitmap
-                       , xftDrawCreateAlpha
-                       , xftDrawChange
-                       , xftDrawDisplay
-                       , xftDrawDrawable
-                       , xftDrawColormap
-                       , xftDrawVisual
-                       , xftDrawDestroy
-                       , XftFont
-                       , xftfont_ascent
-                       , xftfont_descent
-                       , xftfont_height
-                       , xftfont_max_advance_width
-                       , xftFontOpen
-                       , xftFontOpenXlfd
-                       , xftLockFace
-                       , xftUnlockFace
-                       , xftFontCopy
-                       , xftFontClose
-                       , xftDrawGlyphs
-                       , xftDrawString
-                       , xftTextExtents
-                       , xftDrawRect
-                       , xftDrawSetClipRectangles
-                       , xftDrawSetSubwindowMode
-                       , xftInitFtLibrary
-                         )
+                        , xftcolor_pixel
+                        , allocaXftColor
+                        , withXftColorName
+                        , withXftColorValue
+                        , XftDraw
+                        , withXftDraw
+                        , xftDrawCreate
+                        , xftDrawCreateBitmap
+                        , xftDrawCreateAlpha
+                        , xftDrawChange
+                        , xftDrawDisplay
+                        , xftDrawDrawable
+                        , xftDrawColormap
+                        , xftDrawVisual
+                        , xftDrawDestroy
+                        , XftFont
+                        , xftfont_ascent
+                        , xftfont_max_ascent
+                        , xftfont_descent
+                        , xftfont_max_descent
+                        , xftfont_height
+                        , xftfont_max_height
+                        , xftfont_max_advance_width
+                        , xftFontOpen
+                        , xftFontOpenXlfd
+                        , xftLockFace
+                        , xftUnlockFace
+                        , xftFontCopy
+                        , xftFontClose
+                        , xftDrawGlyphs
+                        , xftDrawString
+                        , xftDrawStringFallback
+                        , xftTextExtents
+                        , xftTextAccumExtents
+                        , xftDrawRect
+                        , xftDrawSetClipRectangles
+                        , xftDrawSetSubwindowMode
+                        , xftInitFtLibrary
+                        )
+ where
 
-where
 import Graphics.X11
 import Graphics.X11.Xlib.Types
-import Graphics.X11.Xlib.Region
 import Graphics.X11.Xrender
 
-import Foreign
-import Foreign.C.Types
-import Foreign.C.String
-import Foreign.Ptr
-import Foreign.Marshal.Alloc
-import Foreign.Marshal.Array
 import Codec.Binary.UTF8.String as UTF8
-import Data.Int
-import Data.Word
-import Control.Monad
+import Control.Arrow ((&&&))
+import Control.Monad (void)
+import Data.Char (ord)
+import Data.Function (on)
+import Data.List (groupBy, foldl')
+import Data.List.NonEmpty (NonEmpty)
+import Foreign hiding (void)
+import Foreign.C.String
+import Foreign.C.Types
 
 #include <X11/Xft/Xft.h>
 
@@ -67,6 +73,7 @@
 
 newtype XftColor = XftColor (Ptr XftColor)
 
+xftcolor_pixel :: XftColor -> IO Int
 xftcolor_pixel (XftColor p) = peekCUShort p #{offset XftColor, pixel}
 -- missing xftcolor_color to get XRenderColor
 
@@ -79,11 +86,11 @@
 withXftColorName :: Display -> Visual -> Colormap -> String -> (XftColor -> IO 
a) -> IO a
 withXftColorName d v cm name f =
     allocaXftColor $ (\color -> do
-                       withCAString name (\cstring -> do
-                                            cXftColorAllocName d v cm cstring 
color
-                                            r <- f color
-                                            cXftColorFree d v cm color
-                                            return r)) . XftColor
+                        withCAString name (\cstring -> do
+                                             void $ cXftColorAllocName d v cm 
cstring color
+                                             r <- f color
+                                             cXftColorFree d v cm color
+                                             return r)) . XftColor
 
 foreign import ccall "XftColorAllocValue"
   cXftColorAllocValue :: Display -> Visual -> Colormap -> (Ptr XRenderColor) 
-> XftColor -> IO (#type Bool)
@@ -91,11 +98,11 @@
 withXftColorValue :: Display -> Visual -> Colormap -> XRenderColor -> 
(XftColor -> IO a) -> IO a
 withXftColorValue d v cm rc f =
     allocaXftColor $ (\color -> do
-                       with rc (\rc_ptr -> do
-                                  cXftColorAllocValue d v cm rc_ptr color
-                                  r <- f color
-                                  cXftColorFree d v cm color
-                                  return r)) . XftColor
+                        with rc (\rc_ptr -> do
+                                   void $ cXftColorAllocValue d v cm rc_ptr 
color
+                                   r <- f color
+                                   cXftColorFree d v cm color
+                                   return r)) . XftColor
 
 foreign import ccall "XftColorFree"
   cXftColorFree :: Display -> Visual -> Colormap -> XftColor -> IO ()
@@ -123,6 +130,7 @@
 foreign import ccall "XftDrawCreateAlpha"
   cXftDrawCreateAlpha :: Display -> Pixmap -> CInt -> IO XftDraw
 
+xftDrawCreateAlpha :: Integral a => Display -> Pixmap -> a -> IO XftDraw
 xftDrawCreateAlpha d p i = cXftDrawCreateAlpha d p (fi i)
 
 foreign import ccall "XftDrawChange"
@@ -149,6 +157,7 @@
 
 newtype XftFont = XftFont (Ptr XftFont)
 
+xftfont_ascent, xftfont_descent, xftfont_height, xftfont_max_advance_width :: 
XftFont -> IO Int
 xftfont_ascent (XftFont p)            = peekCUShort p #{offset XftFont, ascent}
 xftfont_descent (XftFont p)           = peekCUShort p #{offset XftFont, 
descent}
 xftfont_height (XftFont p)            = peekCUShort p #{offset XftFont, height}
@@ -159,6 +168,7 @@
 foreign import ccall "XftFontOpenName"
   cXftFontOpen :: Display -> CInt -> CString -> IO XftFont
 
+xftFontOpen :: Display -> Screen -> String -> IO XftFont
 xftFontOpen dpy screen fontname =
     withCAString fontname $
       \cfontname -> cXftFontOpen dpy (fi (screenNumberOfScreen screen)) 
cfontname
@@ -166,6 +176,7 @@
 foreign import ccall "XftFontOpenXlfd"
   cXftFontOpenXlfd :: Display -> CInt -> CString -> IO XftFont
 
+xftFontOpenXlfd :: Display -> Screen -> String -> IO XftFont
 xftFontOpenXlfd dpy screen fontname =
     withCAString fontname $ \cfontname -> cXftFontOpenXlfd dpy (fi 
(screenNumberOfScreen screen)) cfontname
 
@@ -181,15 +192,37 @@
 foreign import ccall "XftFontClose"
   xftFontClose :: Display -> XftFont -> IO ()
 
+-- Support for multiple fonts --
+
+xftfont_max_ascent :: NonEmpty XftFont -> IO Int
+xftfont_max_ascent = fmap maximum . mapM xftfont_ascent
+
+xftfont_max_descent :: NonEmpty XftFont -> IO Int
+xftfont_max_descent = fmap maximum . mapM xftfont_descent
+
+xftfont_max_height :: NonEmpty XftFont -> IO Int
+xftfont_max_height = fmap maximum . mapM xftfont_height
+
 ---------------------
 -- Painting
 ---------------------
 
 -- Drawing strings or glyphs --
 
+foreign import ccall "XftCharExists"
+  cXftCharExists :: Display -> XftFont -> (#type FcChar32) -> IO (#type FcBool)
+
+xftCharExists :: Display -> XftFont -> Char -> IO Bool
+xftCharExists d f c = bool <$> cXftCharExists d f (fi $ ord c)
+  where
+    bool 0 = False
+    bool _ = True
+
 foreign import ccall "XftDrawGlyphs"
   cXftDrawGlyphs :: XftDraw -> XftColor -> XftFont -> CInt -> CInt -> Ptr 
(#type FT_UInt) -> CInt -> IO ()
 
+xftDrawGlyphs :: (Integral a, Integral b, Integral c)
+              => XftDraw -> XftColor -> XftFont -> b -> c -> [a] -> IO ()
 xftDrawGlyphs d c f x y glyphs =
     withArrayLen (map fi glyphs)
       (\len ptr -> cXftDrawGlyphs d c f (fi x) (fi y) ptr (fi len))
@@ -197,6 +230,8 @@
 foreign import ccall "XftDrawStringUtf8"
   cXftDrawStringUtf8 :: XftDraw -> XftColor -> XftFont -> CInt -> CInt -> Ptr 
(#type FcChar8) -> CInt -> IO ()
 
+xftDrawString :: (Integral a, Integral b)
+              => XftDraw -> XftColor -> XftFont -> a -> b -> String -> IO ()
 xftDrawString d c f x y string =
     withArrayLen (map fi (UTF8.encode string))
       (\len ptr -> cXftDrawStringUtf8 d c f (fi x) (fi y) ptr (fi len))
@@ -214,11 +249,76 @@
       cXftTextExtentsUtf8 d f str_ptr (fi len) cglyph
       peek cglyph
 
+-- Support for multiple fonts --
+
+-- | Like 'xftDrawString', but fall back to another font in the given
+-- list if necessary (i.e., should a character not be drawable with the
+-- currently selected font).
+xftDrawStringFallback :: XftDraw -> XftColor -> [XftFont] -> Int -> Int -> 
String -> IO ()
+xftDrawStringFallback d c fs x y string = do
+    display <- xftDrawDisplay d
+    chunks <- getChunks display fs x y string
+    mapM_ (\(f, s, (XGlyphInfo _  _ x' y' _ _)) -> xftDrawString d c f x' y' 
s) chunks
+
+-- | Like 'xftTextExtents' but for multiple fonts. Return
+-- accumulative extents using appropriate fonts for each part of
+-- string.
+xftTextAccumExtents :: Display -> [XftFont] -> String -> IO XGlyphInfo
+xftTextAccumExtents disp fts string = do
+  chunks <- map (\ (_, _, gi) -> gi) <$> getChunks disp fts 0 0 string
+  return $ foldl' calcExtents (XGlyphInfo 0 0 0 0 0 0) chunks
+  where
+    calcExtents :: XGlyphInfo -> XGlyphInfo -> XGlyphInfo
+    calcExtents (XGlyphInfo _ _ x y xo yo) (XGlyphInfo w' h' _ _ xo' yo')
+      = XGlyphInfo (xo + w') (yo + h') x y (xo + xo') (yo + yo')
+
+-- | Split string and determine fonts/offsets for individual parts
+getChunks :: Display
+          -> [XftFont]
+          -> Int
+          -> Int
+          -> String
+          -> IO [(XftFont, String, XGlyphInfo)]
+getChunks disp fts xInit yInit str = do
+    chunks <- getFonts fts str
+    getChunksExtents xInit yInit chunks
+  where
+    -- Split string and determine fonts for individual parts
+    getFonts :: [XftFont] -> String -> IO [(XftFont, String)]
+    getFonts [] _ = return []
+    getFonts [ft] s = return [(ft, s)]
+    getFonts fonts@(ft:_) s = do
+        -- Determine which glyph can be rendered by current font
+        glyphs <- mapM (xftCharExists disp ft) s
+        -- Split string into parts that return "can/cannot be rendered"
+        let splits = map (fst . head &&& map snd)
+                   . groupBy ((==) `on` fst)
+                   $ zip glyphs s
+        -- Determine which font to render each chunk with
+        concat <$> mapM (getFont fonts) splits
+
+    -- Determine fonts for substrings
+    getFont :: [XftFont] -> (Bool, String) -> IO [(XftFont, String)]
+    getFont [] _ = return []
+    getFont [ft] (_, s) = return [(ft, s)]      -- Last font, use it
+    getFont (ft:_) (True, s) = return [(ft, s)] -- Current font can render 
this substring
+    getFont (_:fs) (False, s) = getFonts fs s   -- Fallback to next font
+
+    -- Determine coordinates for chunks using extents
+    getChunksExtents :: Int -> Int -> [(XftFont, String)] -> IO [(XftFont, 
String, XGlyphInfo)]
+    getChunksExtents _ _ [] = return []
+    getChunksExtents x y ((f, s) : chunks) = do
+      (XGlyphInfo w h _ _ xo yo) <- xftTextExtents disp f s
+      rest <- getChunksExtents (x + xo) (y + yo) chunks
+      return $ (f, s, XGlyphInfo w h x y xo yo) : rest
+
 -- Drawing auxilary --
 
 foreign import ccall "XftDrawRect"
   cXftDrawRect :: XftDraw -> XftColor -> CInt -> CInt -> CUInt -> CUInt -> IO 
()
 
+xftDrawRect :: (Integral a, Integral b, Integral c, Integral d)
+            => XftDraw -> XftColor -> a -> b -> c -> d -> IO ()
 xftDrawRect draw color x y width height =
     cXftDrawRect draw color (fi x) (fi y) (fi width) (fi height)
 
@@ -234,15 +334,16 @@
   cXftDrawSetClipRectangles :: XftDraw -> CInt -> CInt -> (Ptr Rectangle) -> 
CInt -> IO CInt
 
 xftDrawSetClipRectangles :: XftDraw -> Int -> Int -> [Rectangle] -> IO Bool
-xftDrawSetClipRectangles draw x y rects =
-    withArrayLen rects
+xftDrawSetClipRectangles draw x y rectangles =
+    withArrayLen rectangles
       (\len rects -> do
-        r <- cXftDrawSetClipRectangles draw (fi x) (fi y) rects (fi len)
+         r <- cXftDrawSetClipRectangles draw (fi x) (fi y) rects (fi len)
          return (toInteger r /= 0)) -- verify whether this is really the 
convention
 
 foreign import ccall "XftDrawSetSubwindowMode"
   cXftDrawSetSubwindowMode :: XftDraw -> CInt -> IO ()
 
+xftDrawSetSubwindowMode :: Integral a => XftDraw -> a -> IO ()
 xftDrawSetSubwindowMode d i = cXftDrawSetSubwindowMode d (fi i)
 
 --------------
@@ -257,38 +358,38 @@
 but otherwise all the functions can be achieved by DrawGlyphs
 
 void
-XftDrawCharSpec (XftDraw               *draw,
-                _Xconst XftColor       *color,
-                XftFont                *pub,
-                _Xconst XftCharSpec    *chars,
-                int                    len);
+XftDrawCharSpec (XftDraw                *draw,
+                 _Xconst XftColor       *color,
+                 XftFont                *pub,
+                 _Xconst XftCharSpec    *chars,
+                 int                    len);
 
 void
-XftDrawCharFontSpec (XftDraw                   *draw,
-                    _Xconst XftColor           *color,
-                    _Xconst XftCharFontSpec    *chars,
-                    int                        len);
+XftDrawCharFontSpec (XftDraw                    *draw,
+                     _Xconst XftColor           *color,
+                     _Xconst XftCharFontSpec    *chars,
+                     int                        len);
 
 void
-XftDrawGlyphSpec (XftDraw              *draw,
-                 _Xconst XftColor      *color,
-                 XftFont               *pub,
-                 _Xconst XftGlyphSpec  *glyphs,
-                 int                   len);
+XftDrawGlyphSpec (XftDraw               *draw,
+                  _Xconst XftColor      *color,
+                  XftFont               *pub,
+                  _Xconst XftGlyphSpec  *glyphs,
+                  int                   len);
 
 void
-XftDrawGlyphFontSpec (XftDraw                  *draw,
-                     _Xconst XftColor          *color,
-                     _Xconst XftGlyphFontSpec  *glyphs,
-                     int                       len);
+XftDrawGlyphFontSpec (XftDraw                   *draw,
+                      _Xconst XftColor          *color,
+                      _Xconst XftGlyphFontSpec  *glyphs,
+                      int                       len);
 ------
 Missing
 void
-XftGlyphExtents (Display           *dpy,
-                XftFont            *pub,
-                _Xconst FT_UInt    *glyphs,
-                int                nglyphs,
-                XGlyphInfo         *extents);
+XftGlyphExtents (Display            *dpy,
+                 XftFont            *pub,
+                 _Xconst FT_UInt    *glyphs,
+                 int                nglyphs,
+                 XGlyphInfo         *extents);
 
 Intentionally Missing Bindings
 xftDrawString8,xftDrawString16,xftDrawString32,xftDrawStringUtf16
@@ -315,9 +416,9 @@
 XftFontInfoEqual (_Xconst XftFontInfo *a, _Xconst XftFontInfo *b);
 
 XftFont *
-XftFontOpenInfo (Display       *dpy,
-                FcPattern      *pattern,
-                XftFontInfo    *fi);
+XftFontOpenInfo (Display        *dpy,
+                 FcPattern      *pattern,
+                 XftFontInfo    *fi);
 
 XftFont *
 XftFontOpenPattern (Display *dpy, FcPattern *pattern);
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/X11-xft-0.3.1/Graphics/X11/Xrender.hsc 
new/X11-xft-0.3.4/Graphics/X11/Xrender.hsc
--- old/X11-xft-0.3.1/Graphics/X11/Xrender.hsc  2011-10-01 08:18:12.000000000 
+0200
+++ new/X11-xft-0.3.4/Graphics/X11/Xrender.hsc  2001-09-09 03:46:40.000000000 
+0200
@@ -6,89 +6,91 @@
 --
 -----------------------------------------------------------------------------
 
-module Graphics.X11.Xrender
-where
-import Graphics.X11
-import Graphics.X11.Xlib.Types
+module Graphics.X11.Xrender (
+  peekCUShort,
+  pokeCUShort,
+  peekCShort,
+  pokeCShort,
+  XRenderColor (..),
+  XGlyphInfo (..),
+  XRenderDirectFormat (..),
+) where
+
 import Foreign
 import Foreign.C
-import Foreign.C.Types
-import Foreign.Ptr
-import Foreign.Storable( Storable(..) )
 
 #include <X11/extensions/Xrender.h>
 
 peekCUShort :: Ptr a -> CInt -> IO Int
 peekCUShort ptr off = do
-       v <- peekByteOff ptr (fromIntegral off)
-       return (fromIntegral (v::CUShort))
+        v <- peekByteOff ptr (fromIntegral off)
+        return (fromIntegral (v::CUShort))
 
 pokeCUShort :: Ptr a -> CInt -> Int -> IO ()
 pokeCUShort ptr off v =
-       pokeByteOff ptr (fromIntegral off) (fromIntegral v::CUShort)
-
+        pokeByteOff ptr (fromIntegral off) (fromIntegral v::CUShort)
 
 peekCShort :: Ptr a -> CInt -> IO Int
 peekCShort ptr off = do
-       v <- peekByteOff ptr (fromIntegral off)
-       return (fromIntegral (v::CShort))
+        v <- peekByteOff ptr (fromIntegral off)
+        return (fromIntegral (v::CShort))
 
 pokeCShort :: Ptr a -> CInt -> Int -> IO ()
 pokeCShort ptr off v =
-       pokeByteOff ptr (fromIntegral off) (fromIntegral v::CShort)
+        pokeByteOff ptr (fromIntegral off) (fromIntegral v::CShort)
 
-data XRenderColor = XRenderColor { 
-      xrendercolor_red   :: Int, 
-      xrendercolor_green :: Int, 
-      xrendercolor_blue  :: Int, 
-      xrendercolor_alpha :: Int 
+data XRenderColor = XRenderColor {
+      xrendercolor_red   :: Int,
+      xrendercolor_green :: Int,
+      xrendercolor_blue  :: Int,
+      xrendercolor_alpha :: Int
 }
 
 instance Storable XRenderColor where
-       sizeOf _ = #{size XRenderColor}
-       alignment _ = alignment (undefined::CInt)
-       peek p = do
-               red   <- peekCUShort p #{offset XRenderColor, red}
-               blue  <- peekCUShort p #{offset XRenderColor, blue}
-               green <- peekCUShort p #{offset XRenderColor, green}
-               alpha <- peekCUShort p #{offset XRenderColor, alpha}
-               return (XRenderColor red blue green alpha)
-       poke p (XRenderColor red blue green alpha) = do
-               pokeCUShort p #{offset XRenderColor,red} red
-               pokeCUShort p #{offset XRenderColor,blue} blue
-               pokeCUShort p #{offset XRenderColor,green} green
-               pokeCUShort p #{offset XRenderColor,alpha} alpha
-
-data XGlyphInfo = XGlyphInfo { 
-      xglyphinfo_width  :: Int, 
-      xglyphinfo_height :: Int, 
-      xglyphinfo_x      :: Int, 
-      xglyphinfo_y      :: Int, 
-      xglyphinfo_xOff   :: Int, 
+        sizeOf _ = #{size XRenderColor}
+        alignment _ = alignment (undefined::CInt)
+        peek p = do
+                red   <- peekCUShort p #{offset XRenderColor, red}
+                blue  <- peekCUShort p #{offset XRenderColor, blue}
+                green <- peekCUShort p #{offset XRenderColor, green}
+                alpha <- peekCUShort p #{offset XRenderColor, alpha}
+                return (XRenderColor red green blue alpha)
+        poke p (XRenderColor red green blue alpha) = do
+                pokeCUShort p #{offset XRenderColor,red} red
+                pokeCUShort p #{offset XRenderColor,blue} blue
+                pokeCUShort p #{offset XRenderColor,green} green
+                pokeCUShort p #{offset XRenderColor,alpha} alpha
+
+data XGlyphInfo = XGlyphInfo {
+      xglyphinfo_width  :: Int,
+      xglyphinfo_height :: Int,
+      xglyphinfo_x      :: Int,
+      xglyphinfo_y      :: Int,
+      xglyphinfo_xOff   :: Int,
       xglyphinfo_yOff   :: Int
 }
 
 instance Storable XGlyphInfo where
-       sizeOf _ = #{size XGlyphInfo}
-       alignment _ = alignment (undefined::CInt)
-       peek p = do
-               width  <- peekCUShort p #{offset XGlyphInfo, width}
-               height <- peekCUShort p #{offset XGlyphInfo, height}
-               x <- peekCShort p #{offset XGlyphInfo, x}
-               y <- peekCShort p #{offset XGlyphInfo, y}
-               xOff <- peekCShort p #{offset XGlyphInfo, xOff}
-               yOff <- peekCShort p #{offset XGlyphInfo, yOff}
-               return (XGlyphInfo width height x y xOff yOff)
-       poke p (XGlyphInfo width height x y xOff yOff) = do
-               pokeCUShort p #{offset XGlyphInfo,width} width
-               pokeCUShort p #{offset XGlyphInfo,height} height
-               pokeCShort p #{offset XGlyphInfo,x} x
-               pokeCShort p #{offset XGlyphInfo,y} y
-               pokeCShort p #{offset XGlyphInfo,xOff} xOff
-               pokeCShort p #{offset XGlyphInfo,yOff} yOff
+        sizeOf _ = #{size XGlyphInfo}
+        alignment _ = alignment (undefined::CInt)
+        peek p = do
+                width  <- peekCUShort p #{offset XGlyphInfo, width}
+                height <- peekCUShort p #{offset XGlyphInfo, height}
+                x <- peekCShort p #{offset XGlyphInfo, x}
+                y <- peekCShort p #{offset XGlyphInfo, y}
+                xOff <- peekCShort p #{offset XGlyphInfo, xOff}
+                yOff <- peekCShort p #{offset XGlyphInfo, yOff}
+                return (XGlyphInfo width height x y xOff yOff)
+        poke p (XGlyphInfo width height x y xOff yOff) = do
+                pokeCUShort p #{offset XGlyphInfo,width} width
+                pokeCUShort p #{offset XGlyphInfo,height} height
+                pokeCShort p #{offset XGlyphInfo,x} x
+                pokeCShort p #{offset XGlyphInfo,y} y
+                pokeCShort p #{offset XGlyphInfo,xOff} xOff
+                pokeCShort p #{offset XGlyphInfo,yOff} yOff
 
 
-data XRenderDirectFormat = XRenderDirectFormat { 
+data XRenderDirectFormat = XRenderDirectFormat {
      xrenderdirectformat_red       :: Int,
      xrenderdirectformat_redMask   :: Int,
      xrenderdirectformat_green     :: Int,
@@ -100,25 +102,24 @@
 }
 
 instance Storable XRenderDirectFormat where
-       sizeOf _ = #{size XRenderDirectFormat}
-       alignment _ = alignment (undefined::CInt)
-       peek p = do
-               red  <- peekCShort p #{offset XRenderDirectFormat, red}
-               redMask  <- peekCShort p #{offset XRenderDirectFormat, redMask}
-               green  <- peekCShort p #{offset XRenderDirectFormat, green}
-               greenMask  <- peekCShort p #{offset XRenderDirectFormat, 
greenMask}
-               blue  <- peekCShort p #{offset XRenderDirectFormat, blue}
-               blueMask  <- peekCShort p #{offset XRenderDirectFormat, 
blueMask}
-               alpha  <- peekCShort p #{offset XRenderDirectFormat, alpha}
-               alphaMask  <- peekCShort p #{offset XRenderDirectFormat, 
alphaMask}
-               return (XRenderDirectFormat red redMask green greenMask blue 
blueMask alpha alphaMask)
-       poke p (XRenderDirectFormat red redMask green greenMask blue blueMask 
alpha alphaMask) = do
-               pokeCShort p #{offset XRenderDirectFormat,red} red
-               pokeCShort p #{offset XRenderDirectFormat,redMask} redMask
-               pokeCShort p #{offset XRenderDirectFormat,blue} blue
-               pokeCShort p #{offset XRenderDirectFormat,blueMask} blueMask
-               pokeCShort p #{offset XRenderDirectFormat,green} green
-               pokeCShort p #{offset XRenderDirectFormat,greenMask} greenMask
-               pokeCShort p #{offset XRenderDirectFormat,alpha} alpha
-               pokeCShort p #{offset XRenderDirectFormat,alphaMask} alphaMask
-
+        sizeOf _ = #{size XRenderDirectFormat}
+        alignment _ = alignment (undefined::CInt)
+        peek p = do
+                red  <- peekCShort p #{offset XRenderDirectFormat, red}
+                redMask  <- peekCShort p #{offset XRenderDirectFormat, redMask}
+                green  <- peekCShort p #{offset XRenderDirectFormat, green}
+                greenMask  <- peekCShort p #{offset XRenderDirectFormat, 
greenMask}
+                blue  <- peekCShort p #{offset XRenderDirectFormat, blue}
+                blueMask  <- peekCShort p #{offset XRenderDirectFormat, 
blueMask}
+                alpha  <- peekCShort p #{offset XRenderDirectFormat, alpha}
+                alphaMask  <- peekCShort p #{offset XRenderDirectFormat, 
alphaMask}
+                return (XRenderDirectFormat red redMask green greenMask blue 
blueMask alpha alphaMask)
+        poke p (XRenderDirectFormat red redMask green greenMask blue blueMask 
alpha alphaMask) = do
+                pokeCShort p #{offset XRenderDirectFormat,red} red
+                pokeCShort p #{offset XRenderDirectFormat,redMask} redMask
+                pokeCShort p #{offset XRenderDirectFormat,blue} blue
+                pokeCShort p #{offset XRenderDirectFormat,blueMask} blueMask
+                pokeCShort p #{offset XRenderDirectFormat,green} green
+                pokeCShort p #{offset XRenderDirectFormat,greenMask} greenMask
+                pokeCShort p #{offset XRenderDirectFormat,alpha} alpha
+                pokeCShort p #{offset XRenderDirectFormat,alphaMask} alphaMask
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/X11-xft-0.3.1/Hello.hs new/X11-xft-0.3.4/Hello.hs
--- old/X11-xft-0.3.1/Hello.hs  2011-10-01 08:18:12.000000000 +0200
+++ new/X11-xft-0.3.4/Hello.hs  1970-01-01 01:00:00.000000000 +0100
@@ -1,28 +0,0 @@
-module Main where
-import Graphics.X11.Xlib
-import Graphics.X11.Xft
-import System.Exit (exitWith, ExitCode(..))
-import Control.Concurrent (threadDelay)
- 
-main :: IO ()
-main =
- do dpy <- openDisplay ""
-    let dflt = defaultScreen dpy
-       border = blackPixel dpy dflt
-       background = whitePixel dpy dflt
-    rootw <- rootWindow dpy dflt
-    win <- createSimpleWindow dpy rootw 0 0 100 100 1 border background
-    setTextProperty dpy win "Hello World" wM_NAME
-    mapWindow dpy win
-    let screen = defaultScreenOfDisplay dpy;
-       colormap = defaultColormapOfScreen screen;
-       visual = defaultVisualOfScreen screen;
-    draw <- xftDrawCreate dpy win visual colormap
-    font <- xftFontOpen dpy screen "Sans-10"
-    putStrLn "ARGARGH??LLL???x???y???z"
-    withXftColorName dpy visual colormap "red" (\color -> xftDrawString draw 
color font 20 20 "ARGARGH??LLLz??????????")
-    sync dpy False
-    threadDelay (10 * 1000000)
-    xftDrawDestroy draw
-    exitWith ExitSuccess
-
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/X11-xft-0.3.1/LICENSE new/X11-xft-0.3.4/LICENSE
--- old/X11-xft-0.3.1/LICENSE   2011-10-01 08:18:12.000000000 +0200
+++ new/X11-xft-0.3.4/LICENSE   2001-09-09 03:46:40.000000000 +0200
@@ -1,504 +1,27 @@
-                 GNU LESSER GENERAL PUBLIC LICENSE
-                      Version 2.1, February 1999
+Copyright (c) 2007 Clemens Fruhwirth
+Copyright (c) The Xmonad Community. All rights reserved.
 
- Copyright (C) 1991, 1999 Free Software Foundation, Inc.
-     51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
- Everyone is permitted to copy and distribute verbatim copies
- of this license document, but changing it is not allowed.
-
-[This is the first released version of the Lesser GPL.  It also counts
- as the successor of the GNU Library Public License, version 2, hence
- the version number 2.1.]
-
-                           Preamble
-
-  The licenses for most software are designed to take away your
-freedom to share and change it.  By contrast, the GNU General Public
-Licenses are intended to guarantee your freedom to share and change
-free software--to make sure the software is free for all its users.
-
-  This license, the Lesser General Public License, applies to some
-specially designated software packages--typically libraries--of the
-Free Software Foundation and other authors who decide to use it.  You
-can use it too, but we suggest you first think carefully about whether
-this license or the ordinary General Public License is the better
-strategy to use in any particular case, based on the explanations below.
-
-  When we speak of free software, we are referring to freedom of use,
-not price.  Our General Public Licenses are designed to make sure that
-you have the freedom to distribute copies of free software (and charge
-for this service if you wish); that you receive source code or can get
-it if you want it; that you can change the software and use pieces of
-it in new free programs; and that you are informed that you can do
-these things.
-
-  To protect your rights, we need to make restrictions that forbid
-distributors to deny you these rights or to ask you to surrender these
-rights.  These restrictions translate to certain responsibilities for
-you if you distribute copies of the library or if you modify it.
-
-  For example, if you distribute copies of the library, whether gratis
-or for a fee, you must give the recipients all the rights that we gave
-you.  You must make sure that they, too, receive or can get the source
-code.  If you link other code with the library, you must provide
-complete object files to the recipients, so that they can relink them
-with the library after making changes to the library and recompiling
-it.  And you must show them these terms so they know their rights.
-
-  We protect your rights with a two-step method: (1) we copyright the
-library, and (2) we offer you this license, which gives you legal
-permission to copy, distribute and/or modify the library.
-
-  To protect each distributor, we want to make it very clear that
-there is no warranty for the free library.  Also, if the library is
-modified by someone else and passed on, the recipients should know
-that what they have is not the original version, so that the original
-author's reputation will not be affected by problems that might be
-introduced by others.
-
-  Finally, software patents pose a constant threat to the existence of
-any free program.  We wish to make sure that a company cannot
-effectively restrict the users of a free program by obtaining a
-restrictive license from a patent holder.  Therefore, we insist that
-any patent license obtained for a version of the library must be
-consistent with the full freedom of use specified in this license.
-
-  Most GNU software, including some libraries, is covered by the
-ordinary GNU General Public License.  This license, the GNU Lesser
-General Public License, applies to certain designated libraries, and
-is quite different from the ordinary General Public License.  We use
-this license for certain libraries in order to permit linking those
-libraries into non-free programs.
-
-  When a program is linked with a library, whether statically or using
-a shared library, the combination of the two is legally speaking a
-combined work, a derivative of the original library.  The ordinary
-General Public License therefore permits such linking only if the
-entire combination fits its criteria of freedom.  The Lesser General
-Public License permits more lax criteria for linking other code with
-the library.
-
-  We call this license the "Lesser" General Public License because it
-does Less to protect the user's freedom than the ordinary General
-Public License.  It also provides other free software developers Less
-of an advantage over competing non-free programs.  These disadvantages
-are the reason we use the ordinary General Public License for many
-libraries.  However, the Lesser license provides advantages in certain
-special circumstances.
-
-  For example, on rare occasions, there may be a special need to
-encourage the widest possible use of a certain library, so that it becomes
-a de-facto standard.  To achieve this, non-free programs must be
-allowed to use the library.  A more frequent case is that a free
-library does the same job as widely used non-free libraries.  In this
-case, there is little to gain by limiting the free library to free
-software only, so we use the Lesser General Public License.
-
-  In other cases, permission to use a particular library in non-free
-programs enables a greater number of people to use a large body of
-free software.  For example, permission to use the GNU C Library in
-non-free programs enables many more people to use the whole GNU
-operating system, as well as its variant, the GNU/Linux operating
-system.
-
-  Although the Lesser General Public License is Less protective of the
-users' freedom, it does ensure that the user of a program that is
-linked with the Library has the freedom and the wherewithal to run
-that program using a modified version of the Library.
-
-  The precise terms and conditions for copying, distribution and
-modification follow.  Pay close attention to the difference between a
-"work based on the library" and a "work that uses the library".  The
-former contains code derived from the library, whereas the latter must
-be combined with the library in order to run.
-
-                 GNU LESSER GENERAL PUBLIC LICENSE
-   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
-
-  0. This License Agreement applies to any software library or other
-program which contains a notice placed by the copyright holder or
-other authorized party saying it may be distributed under the terms of
-this Lesser General Public License (also called "this License").
-Each licensee is addressed as "you".
-
-  A "library" means a collection of software functions and/or data
-prepared so as to be conveniently linked with application programs
-(which use some of those functions and data) to form executables.
-
-  The "Library", below, refers to any such software library or work
-which has been distributed under these terms.  A "work based on the
-Library" means either the Library or any derivative work under
-copyright law: that is to say, a work containing the Library or a
-portion of it, either verbatim or with modifications and/or translated
-straightforwardly into another language.  (Hereinafter, translation is
-included without limitation in the term "modification".)
-
-  "Source code" for a work means the preferred form of the work for
-making modifications to it.  For a library, complete source code means
-all the source code for all modules it contains, plus any associated
-interface definition files, plus the scripts used to control compilation
-and installation of the library.
-
-  Activities other than copying, distribution and modification are not
-covered by this License; they are outside its scope.  The act of
-running a program using the Library is not restricted, and output from
-such a program is covered only if its contents constitute a work based
-on the Library (independent of the use of the Library in a tool for
-writing it).  Whether that is true depends on what the Library does
-and what the program that uses the Library does.
-  
-  1. You may copy and distribute verbatim copies of the Library's
-complete source code as you receive it, in any medium, provided that
-you conspicuously and appropriately publish on each copy an
-appropriate copyright notice and disclaimer of warranty; keep intact
-all the notices that refer to this License and to the absence of any
-warranty; and distribute a copy of this License along with the
-Library.
-
-  You may charge a fee for the physical act of transferring a copy,
-and you may at your option offer warranty protection in exchange for a
-fee.
-
-  2. You may modify your copy or copies of the Library or any portion
-of it, thus forming a work based on the Library, and copy and
-distribute such modifications or work under the terms of Section 1
-above, provided that you also meet all of these conditions:
-
-    a) The modified work must itself be a software library.
-
-    b) You must cause the files modified to carry prominent notices
-    stating that you changed the files and the date of any change.
-
-    c) You must cause the whole of the work to be licensed at no
-    charge to all third parties under the terms of this License.
-
-    d) If a facility in the modified Library refers to a function or a
-    table of data to be supplied by an application program that uses
-    the facility, other than as an argument passed when the facility
-    is invoked, then you must make a good faith effort to ensure that,
-    in the event an application does not supply such function or
-    table, the facility still operates, and performs whatever part of
-    its purpose remains meaningful.
-
-    (For example, a function in a library to compute square roots has
-    a purpose that is entirely well-defined independent of the
-    application.  Therefore, Subsection 2d requires that any
-    application-supplied function or table used by this function must
-    be optional: if the application does not supply it, the square
-    root function must still compute square roots.)
-
-These requirements apply to the modified work as a whole.  If
-identifiable sections of that work are not derived from the Library,
-and can be reasonably considered independent and separate works in
-themselves, then this License, and its terms, do not apply to those
-sections when you distribute them as separate works.  But when you
-distribute the same sections as part of a whole which is a work based
-on the Library, the distribution of the whole must be on the terms of
-this License, whose permissions for other licensees extend to the
-entire whole, and thus to each and every part regardless of who wrote
-it.
-
-Thus, it is not the intent of this section to claim rights or contest
-your rights to work written entirely by you; rather, the intent is to
-exercise the right to control the distribution of derivative or
-collective works based on the Library.
-
-In addition, mere aggregation of another work not based on the Library
-with the Library (or with a work based on the Library) on a volume of
-a storage or distribution medium does not bring the other work under
-the scope of this License.
-
-  3. You may opt to apply the terms of the ordinary GNU General Public
-License instead of this License to a given copy of the Library.  To do
-this, you must alter all the notices that refer to this License, so
-that they refer to the ordinary GNU General Public License, version 2,
-instead of to this License.  (If a newer version than version 2 of the
-ordinary GNU General Public License has appeared, then you can specify
-that version instead if you wish.)  Do not make any other change in
-these notices.
-
-  Once this change is made in a given copy, it is irreversible for
-that copy, so the ordinary GNU General Public License applies to all
-subsequent copies and derivative works made from that copy.
-
-  This option is useful when you wish to copy part of the code of
-the Library into a program that is not a library.
-
-  4. You may copy and distribute the Library (or a portion or
-derivative of it, under Section 2) in object code or executable form
-under the terms of Sections 1 and 2 above provided that you accompany
-it with the complete corresponding machine-readable source code, which
-must be distributed under the terms of Sections 1 and 2 above on a
-medium customarily used for software interchange.
-
-  If distribution of object code is made by offering access to copy
-from a designated place, then offering equivalent access to copy the
-source code from the same place satisfies the requirement to
-distribute the source code, even though third parties are not
-compelled to copy the source along with the object code.
-
-  5. A program that contains no derivative of any portion of the
-Library, but is designed to work with the Library by being compiled or
-linked with it, is called a "work that uses the Library".  Such a
-work, in isolation, is not a derivative work of the Library, and
-therefore falls outside the scope of this License.
-
-  However, linking a "work that uses the Library" with the Library
-creates an executable that is a derivative of the Library (because it
-contains portions of the Library), rather than a "work that uses the
-library".  The executable is therefore covered by this License.
-Section 6 states terms for distribution of such executables.
-
-  When a "work that uses the Library" uses material from a header file
-that is part of the Library, the object code for the work may be a
-derivative work of the Library even though the source code is not.
-Whether this is true is especially significant if the work can be
-linked without the Library, or if the work is itself a library.  The
-threshold for this to be true is not precisely defined by law.
-
-  If such an object file uses only numerical parameters, data
-structure layouts and accessors, and small macros and small inline
-functions (ten lines or less in length), then the use of the object
-file is unrestricted, regardless of whether it is legally a derivative
-work.  (Executables containing this object code plus portions of the
-Library will still fall under Section 6.)
-
-  Otherwise, if the work is a derivative of the Library, you may
-distribute the object code for the work under the terms of Section 6.
-Any executables containing that work also fall under Section 6,
-whether or not they are linked directly with the Library itself.
-
-  6. As an exception to the Sections above, you may also combine or
-link a "work that uses the Library" with the Library to produce a
-work containing portions of the Library, and distribute that work
-under terms of your choice, provided that the terms permit
-modification of the work for the customer's own use and reverse
-engineering for debugging such modifications.
-
-  You must give prominent notice with each copy of the work that the
-Library is used in it and that the Library and its use are covered by
-this License.  You must supply a copy of this License.  If the work
-during execution displays copyright notices, you must include the
-copyright notice for the Library among them, as well as a reference
-directing the user to the copy of this License.  Also, you must do one
-of these things:
-
-    a) Accompany the work with the complete corresponding
-    machine-readable source code for the Library including whatever
-    changes were used in the work (which must be distributed under
-    Sections 1 and 2 above); and, if the work is an executable linked
-    with the Library, with the complete machine-readable "work that
-    uses the Library", as object code and/or source code, so that the
-    user can modify the Library and then relink to produce a modified
-    executable containing the modified Library.  (It is understood
-    that the user who changes the contents of definitions files in the
-    Library will not necessarily be able to recompile the application
-    to use the modified definitions.)
-
-    b) Use a suitable shared library mechanism for linking with the
-    Library.  A suitable mechanism is one that (1) uses at run time a
-    copy of the library already present on the user's computer system,
-    rather than copying library functions into the executable, and (2)
-    will operate properly with a modified version of the library, if
-    the user installs one, as long as the modified version is
-    interface-compatible with the version that the work was made with.
-
-    c) Accompany the work with a written offer, valid for at
-    least three years, to give the same user the materials
-    specified in Subsection 6a, above, for a charge no more
-    than the cost of performing this distribution.
-
-    d) If distribution of the work is made by offering access to copy
-    from a designated place, offer equivalent access to copy the above
-    specified materials from the same place.
-
-    e) Verify that the user has already received a copy of these
-    materials or that you have already sent this user a copy.
-
-  For an executable, the required form of the "work that uses the
-Library" must include any data and utility programs needed for
-reproducing the executable from it.  However, as a special exception,
-the materials to be distributed need not include anything that is
-normally distributed (in either source or binary form) with the major
-components (compiler, kernel, and so on) of the operating system on
-which the executable runs, unless that component itself accompanies
-the executable.
-
-  It may happen that this requirement contradicts the license
-restrictions of other proprietary libraries that do not normally
-accompany the operating system.  Such a contradiction means you cannot
-use both them and the Library together in an executable that you
-distribute.
-
-  7. You may place library facilities that are a work based on the
-Library side-by-side in a single library together with other library
-facilities not covered by this License, and distribute such a combined
-library, provided that the separate distribution of the work based on
-the Library and of the other library facilities is otherwise
-permitted, and provided that you do these two things:
-
-    a) Accompany the combined library with a copy of the same work
-    based on the Library, uncombined with any other library
-    facilities.  This must be distributed under the terms of the
-    Sections above.
-
-    b) Give prominent notice with the combined library of the fact
-    that part of it is a work based on the Library, and explaining
-    where to find the accompanying uncombined form of the same work.
-
-  8. You may not copy, modify, sublicense, link with, or distribute
-the Library except as expressly provided under this License.  Any
-attempt otherwise to copy, modify, sublicense, link with, or
-distribute the Library is void, and will automatically terminate your
-rights under this License.  However, parties who have received copies,
-or rights, from you under this License will not have their licenses
-terminated so long as such parties remain in full compliance.
-
-  9. You are not required to accept this License, since you have not
-signed it.  However, nothing else grants you permission to modify or
-distribute the Library or its derivative works.  These actions are
-prohibited by law if you do not accept this License.  Therefore, by
-modifying or distributing the Library (or any work based on the
-Library), you indicate your acceptance of this License to do so, and
-all its terms and conditions for copying, distributing or modifying
-the Library or works based on it.
-
-  10. Each time you redistribute the Library (or any work based on the
-Library), the recipient automatically receives a license from the
-original licensor to copy, distribute, link with or modify the Library
-subject to these terms and conditions.  You may not impose any further
-restrictions on the recipients' exercise of the rights granted herein.
-You are not responsible for enforcing compliance by third parties with
-this License.
-
-  11. If, as a consequence of a court judgment or allegation of patent
-infringement or for any other reason (not limited to patent issues),
-conditions are imposed on you (whether by court order, agreement or
-otherwise) that contradict the conditions of this License, they do not
-excuse you from the conditions of this License.  If you cannot
-distribute so as to satisfy simultaneously your obligations under this
-License and any other pertinent obligations, then as a consequence you
-may not distribute the Library at all.  For example, if a patent
-license would not permit royalty-free redistribution of the Library by
-all those who receive copies directly or indirectly through you, then
-the only way you could satisfy both it and this License would be to
-refrain entirely from distribution of the Library.
-
-If any portion of this section is held invalid or unenforceable under any
-particular circumstance, the balance of the section is intended to apply,
-and the section as a whole is intended to apply in other circumstances.
-
-It is not the purpose of this section to induce you to infringe any
-patents or other property right claims or to contest validity of any
-such claims; this section has the sole purpose of protecting the
-integrity of the free software distribution system which is
-implemented by public license practices.  Many people have made
-generous contributions to the wide range of software distributed
-through that system in reliance on consistent application of that
-system; it is up to the author/donor to decide if he or she is willing
-to distribute software through any other system and a licensee cannot
-impose that choice.
-
-This section is intended to make thoroughly clear what is believed to
-be a consequence of the rest of this License.
-
-  12. If the distribution and/or use of the Library is restricted in
-certain countries either by patents or by copyrighted interfaces, the
-original copyright holder who places the Library under this License may add
-an explicit geographical distribution limitation excluding those countries,
-so that distribution is permitted only in or among countries not thus
-excluded.  In such case, this License incorporates the limitation as if
-written in the body of this License.
-
-  13. The Free Software Foundation may publish revised and/or new
-versions of the Lesser General Public License from time to time.
-Such new versions will be similar in spirit to the present version,
-but may differ in detail to address new problems or concerns.
-
-Each version is given a distinguishing version number.  If the Library
-specifies a version number of this License which applies to it and
-"any later version", you have the option of following the terms and
-conditions either of that version or of any later version published by
-the Free Software Foundation.  If the Library does not specify a
-license version number, you may choose any version ever published by
-the Free Software Foundation.
-
-  14. If you wish to incorporate parts of the Library into other free
-programs whose distribution conditions are incompatible with these,
-write to the author to ask for permission.  For software which is
-copyrighted by the Free Software Foundation, write to the Free
-Software Foundation; we sometimes make exceptions for this.  Our
-decision will be guided by the two goals of preserving the free status
-of all derivatives of our free software and of promoting the sharing
-and reuse of software generally.
-
-                           NO WARRANTY
-
-  15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
-WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
-EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
-OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
-KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
-IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
-PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
-LIBRARY IS WITH YOU.  SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
-THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
-
-  16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
-WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
-AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
-FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
-CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
-LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
-RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
-FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
-SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
-DAMAGES.
-
-                    END OF TERMS AND CONDITIONS
-
-           How to Apply These Terms to Your New Libraries
-
-  If you develop a new library, and you want it to be of the greatest
-possible use to the public, we recommend making it free software that
-everyone can redistribute and change.  You can do so by permitting
-redistribution under these terms (or, alternatively, under the terms of the
-ordinary General Public License).
-
-  To apply these terms, attach the following notices to the library.  It is
-safest to attach them to the start of each source file to most effectively
-convey the exclusion of warranty; and each file should have at least the
-"copyright" line and a pointer to where the full notice is found.
-
-    <one line to give the library's name and a brief idea of what it does.>
-    Copyright (C) <year>  <name of author>
-
-    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.
-
-    You should have received a copy of the GNU Lesser General Public
-    License along with this library; if not, write to the Free Software
-    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
-
-Also add information on how to contact you by electronic and paper mail.
-
-You should also get your employer (if you work as a programmer) or your
-school, if any, to sign a "copyright disclaimer" for the library, if
-necessary.  Here is a sample; alter the names:
-
-  Yoyodyne, Inc., hereby disclaims all copyright interest in the
-  library `Frob' (a library for tweaking knobs) written by James Random Hacker.
-
-  <signature of Ty Coon>, 1 April 1990
-  Ty Coon, President of Vice
-
-That's all there is to it!
+Redistribution and use in source and binary forms, with or without 
modification,
+are permitted provided that the following conditions are met:
 
+1. Redistributions of source code must retain the above copyright notice,
+this list of conditions and the following disclaimer.
 
+2. Redistributions in binary form must reproduce the above copyright notice,
+this list of conditions and the following disclaimer in the documentation
+and/or other materials provided with the distribution.
+
+3. Neither the name of the copyright holder nor the names of its contributors
+may be used to endorse or promote products derived from this software without
+specific prior written permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
+LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
CONSEQUENTIAL
+DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
+USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/X11-xft-0.3.1/README.md new/X11-xft-0.3.4/README.md
--- old/X11-xft-0.3.1/README.md 1970-01-01 01:00:00.000000000 +0100
+++ new/X11-xft-0.3.4/README.md 2001-09-09 03:46:40.000000000 +0200
@@ -0,0 +1 @@
+# Bindings to the X Free Type interface library 
[![Hackage](https://img.shields.io/hackage/v/X11-xft.svg?logo=haskell)](https://hackage.haskell.org/package/X11-xft)
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/X11-xft-0.3.1/Setup.lhs new/X11-xft-0.3.4/Setup.lhs
--- old/X11-xft-0.3.1/Setup.lhs 2011-10-01 08:18:12.000000000 +0200
+++ new/X11-xft-0.3.4/Setup.lhs 1970-01-01 01:00:00.000000000 +0100
@@ -1,3 +0,0 @@
-#!/usr/bin/env runhaskell
-> import Distribution.Simple
-> main = defaultMain
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/X11-xft-0.3.1/X11-xft.cabal 
new/X11-xft-0.3.4/X11-xft.cabal
--- old/X11-xft-0.3.1/X11-xft.cabal     2011-10-01 08:18:12.000000000 +0200
+++ new/X11-xft-0.3.4/X11-xft.cabal     2001-09-09 03:46:40.000000000 +0200
@@ -1,16 +1,39 @@
-name:           X11-xft
-version:        0.3.1
-license:        LGPL
-license-file:   LICENSE
-author:         Clemens Fruhwirth
-maintainer:     [email protected]
-category:       Graphics
-synopsis:       Bindings to the Xft, X Free Type interface library, and some 
Xrender parts
-description:    Bindings to the Xft, X Free Type interface library, and some 
Xrender parts
-exposed-modules:    Graphics.X11.Xft, Graphics.X11.Xrender
-extensions:         ForeignFunctionInterface
-build-depends:     base < 5, X11>=1.2.1, utf8-string>=0.1
-ghc-options:        -funbox-strict-fields
-pkgconfig-depends:  xft
-extra-source-files: Hello.hs
-build-type:         Simple
+cabal-version: 2.2
+name:          X11-xft
+version:       0.3.4
+license:       BSD-3-Clause
+license-file:  LICENSE
+author:        Clemens Fruhwirth
+maintainer:    [email protected]
+category:      Graphics
+synopsis:      Bindings to the Xft and some Xrender parts
+description:   A Haskell bindings to the X Font library. With it, Haskell X11
+               applications can access high quality font renderings and provide
+               fonts with anti-aliasing and subpixel rendering. The bindings
+               also provide minimal bindings to Xrender parts.
+build-type:    Simple
+tested-with:   GHC == 8.0.2 || == 8.2.2 || == 8.4.4 || == 8.6.5 || == 8.8.4 || 
== 8.10.4 || == 9.0.1 || == 9.2.1
+extra-source-files: CHANGES.md
+                    README.md
+
+flag pedantic
+  description: Be pedantic (-Werror and the like)
+  default:     False
+  manual:      True
+
+library
+  build-depends:     base        >= 4.9.0.0 && < 5
+                   , X11         >= 1.2.1
+                   , utf8-string >= 0.1
+  ghc-options:       -funbox-strict-fields -Wall -fno-warn-unused-binds
+  pkgconfig-depends: xft
+  other-extensions:  ForeignFunctionInterface
+  exposed-modules:   Graphics.X11.Xft, Graphics.X11.Xrender
+  default-language:  Haskell98
+
+  if flag(pedantic)
+    ghc-options:      -Werror
+
+source-repository head
+  type:     git
+  location: https://github.com/xmonad/X11-xft.git

Reply via email to