Hello community,

here is the log from the commit of package ghc-JuicyPixels for openSUSE:Factory 
checked in at 2019-10-18 14:33:27
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/ghc-JuicyPixels (Old)
 and      /work/SRC/openSUSE:Factory/.ghc-JuicyPixels.new.2352 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Package is "ghc-JuicyPixels"

Fri Oct 18 14:33:27 2019 rev:25 rq:737184 version:3.3.4

Changes:
--------
--- /work/SRC/openSUSE:Factory/ghc-JuicyPixels/ghc-JuicyPixels.changes  
2019-06-30 10:21:24.515611552 +0200
+++ 
/work/SRC/openSUSE:Factory/.ghc-JuicyPixels.new.2352/ghc-JuicyPixels.changes    
    2019-10-18 14:33:29.020231545 +0200
@@ -1,0 +2,11 @@
+Thu Oct  3 02:02:01 UTC 2019 - [email protected]
+
+- Update JuicyPixels to version 3.3.4.
+  v3.3.4 September 2019
+  ---------------------
+
+   * support reading compressed zTXt metadata from PNG files (claudeha)
+   * Add helper functions to convert a DynamicImage to RGB16 (uglyoldbob)
+   * Fix RGB to CMYK conversion (lehins)
+
+-------------------------------------------------------------------

Old:
----
  JuicyPixels-3.3.3.1.tar.gz

New:
----
  JuicyPixels-3.3.4.tar.gz

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

Other differences:
------------------
++++++ ghc-JuicyPixels.spec ++++++
--- /var/tmp/diff_new_pack.5U98Nj/_old  2019-10-18 14:33:29.564230128 +0200
+++ /var/tmp/diff_new_pack.5U98Nj/_new  2019-10-18 14:33:29.564230128 +0200
@@ -18,7 +18,7 @@
 
 %global pkg_name JuicyPixels
 Name:           ghc-%{pkg_name}
-Version:        3.3.3.1
+Version:        3.3.4
 Release:        0
 Summary:        Picture loading/serialization (in png, jpeg, bitmap, gif, tga, 
tiff and radiance)
 License:        BSD-3-Clause

++++++ JuicyPixels-3.3.3.1.tar.gz -> JuicyPixels-3.3.4.tar.gz ++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/JuicyPixels-3.3.3.1/JuicyPixels.cabal 
new/JuicyPixels-3.3.4/JuicyPixels.cabal
--- old/JuicyPixels-3.3.3.1/JuicyPixels.cabal   2019-06-19 21:11:57.000000000 
+0200
+++ new/JuicyPixels-3.3.4/JuicyPixels.cabal     2019-10-02 21:17:11.000000000 
+0200
@@ -1,5 +1,5 @@
 Name:                JuicyPixels
-Version:             3.3.3.1
+Version:             3.3.4
 Synopsis:            Picture loading/serialization (in png, jpeg, bitmap, gif, 
tga, tiff and radiance)
 Description:
     
<<>>
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/JuicyPixels-3.3.3.1/changelog 
new/JuicyPixels-3.3.4/changelog
--- old/JuicyPixels-3.3.3.1/changelog   2019-06-19 21:11:17.000000000 +0200
+++ new/JuicyPixels-3.3.4/changelog     2019-10-02 21:17:11.000000000 +0200
@@ -1,6 +1,13 @@
 Change log
 ==========
 
+v3.3.4 September 2019
+---------------------
+
+ * support reading compressed zTXt metadata from PNG files (claudeha)
+ * Add helper functions to convert a DynamicImage to RGB16 (uglyoldbob)
+ * Fix RGB to CMYK conversion (lehins)
+
 v3.3.3.1 June 2019
 ------------------
 
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' 
old/JuicyPixels-3.3.3.1/src/Codec/Picture/Png/Internal/Metadata.hs 
new/JuicyPixels-3.3.4/src/Codec/Picture/Png/Internal/Metadata.hs
--- old/JuicyPixels-3.3.3.1/src/Codec/Picture/Png/Internal/Metadata.hs  
2019-06-19 21:11:57.000000000 +0200
+++ new/JuicyPixels-3.3.4/src/Codec/Picture/Png/Internal/Metadata.hs    
2019-10-02 21:17:11.000000000 +0200
@@ -13,13 +13,15 @@
 
 import Data.Maybe( fromMaybe )
 import Data.Binary( Binary( get, put ), encode )
-import Data.Binary.Get( getLazyByteStringNul )
+import Data.Binary.Get( getLazyByteStringNul, getWord8 )
 import Data.Binary.Put( putLazyByteString, putWord8 )
 import qualified Data.ByteString.Lazy.Char8 as L
 #if !MIN_VERSION_base(4,11,0)
 import Data.Monoid( (<>) )
 #endif
 
+import qualified Codec.Compression.Zlib as Z
+
 import Codec.Picture.InternalHelper
 import qualified Codec.Picture.Metadata as Met
 import Codec.Picture.Metadata ( Metadatas
@@ -68,8 +70,26 @@
     putWord8 0
     putLazyByteString pdata
 
-textToMetadata :: PngText -> Metadatas
-textToMetadata ptext = case pngKeyword ptext of
+data PngZText = PngZText
+  { pngZKeyword :: !L.ByteString
+  , pngZData    :: !L.ByteString
+  }
+  deriving Show
+
+instance Binary PngZText where
+  get = PngZText <$> getLazyByteStringNul <* getCompressionType <*> 
(Z.decompress <$> getRemainingLazyBytes)
+    where
+      getCompressionType = do
+        0 <- getWord8
+        return ()
+  put (PngZText kw pdata) = do
+    putLazyByteString kw
+    putWord8 0
+    putWord8 0 -- compression type
+    putLazyByteString (Z.compress pdata)
+
+aToMetadata :: (a -> L.ByteString) -> (a -> L.ByteString) -> a -> Metadatas
+aToMetadata pkeyword pdata ptext = case pkeyword ptext of
   "Title" -> strValue Met.Title
   "Author" -> strValue Met.Author
   "Description" -> strValue Met.Description
@@ -83,18 +103,27 @@
   other -> 
     Met.singleton
       (Met.Unknown $ L.unpack other)
-      (Met.String . L.unpack $ pngData ptext)
+      (Met.String . L.unpack $ pdata ptext)
   where
-    strValue k = Met.singleton k . L.unpack $ pngData ptext
+    strValue k = Met.singleton k . L.unpack $ pdata ptext
+
+textToMetadata :: PngText -> Metadatas
+textToMetadata = aToMetadata pngKeyword pngData
+
+ztxtToMetadata :: PngZText -> Metadatas
+ztxtToMetadata = aToMetadata pngZKeyword pngZData
 
 getTexts :: [L.ByteString] -> Metadatas
-getTexts = foldMap (eitherFoldMap textToMetadata . runGet get) where
- 
+getTexts = foldMap (eitherFoldMap textToMetadata . runGet get)
+
+getZTexts :: [L.ByteString] -> Metadatas
+getZTexts = foldMap (eitherFoldMap ztxtToMetadata . runGet get)
 
 extractMetadatas :: PngRawImage -> Metadatas
 extractMetadatas img = getDpis (chunksOf pHYsSignature)
                     <> getGamma (chunksOf gammaSignature)
                     <> getTexts (chunksOf tEXtSignature)
+                    <> getZTexts (chunksOf zTXtSignature)
   where
     chunksOf = chunksWithSig img
 
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/JuicyPixels-3.3.3.1/src/Codec/Picture/Types.hs 
new/JuicyPixels-3.3.4/src/Codec/Picture/Types.hs
--- old/JuicyPixels-3.3.3.1/src/Codec/Picture/Types.hs  2019-06-19 
21:11:57.000000000 +0200
+++ new/JuicyPixels-3.3.4/src/Codec/Picture/Types.hs    2019-10-02 
21:17:11.000000000 +0200
@@ -1248,6 +1248,10 @@
     {-# INLINE promotePixel #-}
     promotePixel c = PixelRGB8 c c c
 
+instance ColorConvertible Pixel8 PixelRGB16 where
+    {-# INLINE promotePixel #-}
+    promotePixel c = PixelRGB16 (fromIntegral c * 257) (fromIntegral c * 257) 
(fromIntegral c * 257)
+
 instance ColorConvertible Pixel8 PixelRGBA8 where
     {-# INLINE promotePixel #-}
     promotePixel c = PixelRGBA8 c c c 255
@@ -1424,6 +1428,10 @@
     {-# INLINE promotePixel #-}
     promotePixel (PixelYA8 y _) = PixelRGB8 y y y
 
+instance ColorConvertible PixelYA8 PixelRGB16 where
+    {-# INLINE promotePixel #-}
+    promotePixel (PixelYA8 y _) = PixelRGB16 (fromIntegral y * 257) 
(fromIntegral y * 257) (fromIntegral y * 257)
+
 instance ColorConvertible PixelYA8 PixelRGBA8 where
     {-# INLINE promotePixel #-}
     promotePixel (PixelYA8 y a) = PixelRGBA8 y y y a
@@ -1494,6 +1502,10 @@
     unsafeWritePixel v idx (PixelYA16 y a) =
         M.unsafeWrite v idx y >> M.unsafeWrite v (idx + 1) a
 
+instance ColorConvertible PixelYA16 PixelRGB16 where
+    {-# INLINE promotePixel #-}
+    promotePixel (PixelYA16 y _) = PixelRGB16 y y y
+
 instance ColorConvertible PixelYA16 PixelRGBA16 where
     {-# INLINE promotePixel #-}
     promotePixel (PixelYA16 y a) = PixelRGBA16 y y y a
@@ -2244,26 +2256,25 @@
                                  -> (Word8, Word8, Word8) -> b #-}
 {-# SPECIALIZE integralRGBToCMYK :: (Word16 -> Word16 -> Word16 -> Word16 -> b)
                                  -> (Word16, Word16, Word16) -> b #-}
+-- | Convert RGB8 or RGB16 to CMYK8 and CMYK16 respectfully.
+--
+-- /Note/ - 32bit precision is not supported. Make sure to adjust 
implementation if ever
+-- used with Word32.
 integralRGBToCMYK :: (Bounded a, Integral a)
                   => (a -> a -> a -> a -> b)    -- ^ Pixel building function
                   -> (a, a, a)                  -- ^ RGB sample
                   -> b                          -- ^ Resulting sample
-integralRGBToCMYK build (r, g, b) =
-  build (clamp c) (clamp m) (clamp y) (fromIntegral kInt)
-    where maxi = maxBound
-
-          ir = fromIntegral $ maxi - r :: Int
-          ig = fromIntegral $ maxi - g
-          ib = fromIntegral $ maxi - b
-
-          kInt = minimum [ir, ig, ib]
-          ik = fromIntegral maxi - kInt
-
-          c = (ir - kInt) `div` ik
-          m = (ig - kInt) `div` ik
-          y = (ib - kInt) `div` ik
-
-          clamp = fromIntegral . max 0
+integralRGBToCMYK build (r, g, b)
+  | kMax == 0 = build 0 0 0 maxVal -- prevent division by zero
+  | otherwise = build (fromIntegral c) (fromIntegral m) (fromIntegral y) k
+    where maxVal = maxBound
+          max32 = fromIntegral maxVal :: Word32
+          kMax32 = fromIntegral kMax :: Word32
+          kMax = max r (max g b)
+          k = maxVal - kMax
+          c = max32 * (kMax32 - fromIntegral r) `div` kMax32
+          m = max32 * (kMax32 - fromIntegral g) `div` kMax32
+          y = max32 * (kMax32 - fromIntegral b) `div` kMax32
 
 instance ColorSpaceConvertible PixelRGB8 PixelCMYK8 where
   convertPixel (PixelRGB8 r g b) = integralRGBToCMYK PixelCMYK8 (r, g, b)
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' 
'--exclude=.svnignore' old/JuicyPixels-3.3.3.1/src/Codec/Picture.hs 
new/JuicyPixels-3.3.4/src/Codec/Picture.hs
--- old/JuicyPixels-3.3.3.1/src/Codec/Picture.hs        2018-12-16 
22:36:06.000000000 +0100
+++ new/JuicyPixels-3.3.4/src/Codec/Picture.hs  2019-10-02 21:17:11.000000000 
+0200
@@ -32,6 +32,7 @@
 
                       -- * RGB helper functions
                      , convertRGB8
+                     , convertRGB16
                      , convertRGBA8
 
                      -- * Lens compatibility
@@ -295,6 +296,13 @@
 decimateWord16 (Image w h da) =
   Image w h $ VS.map (\v -> fromIntegral $ v `unsafeShiftR` 8) da
 
+decimateWord3216 :: ( Pixel px1, Pixel px2
+                  , PixelBaseComponent px1 ~ Pixel32
+                  , PixelBaseComponent px2 ~ Pixel16
+                  ) => Image px1 -> Image px2
+decimateWord3216 (Image w h da) =
+  Image w h $ VS.map (\v -> fromIntegral $ v `unsafeShiftR` 16) da
+  
 decimateWord32 :: ( Pixel px1, Pixel px2
                   , PixelBaseComponent px1 ~ Pixel32
                   , PixelBaseComponent px2 ~ Pixel8
@@ -309,9 +317,19 @@
 decimateFloat (Image w h da) =
   Image w h $ VS.map (floor . (255*) . max 0 . min 1) da
 
+decimateFloat16 :: ( Pixel px1, Pixel px2
+                 , PixelBaseComponent px1 ~ PixelF
+                 , PixelBaseComponent px2 ~ Pixel16
+                 ) => Image px1 -> Image px2
+decimateFloat16 (Image w h da) =
+  Image w h $ VS.map (floor . (65535*) . max 0 . min 1) da
+
 instance Decimable Pixel16 Pixel8 where
    decimateBitDepth = decimateWord16
 
+instance Decimable Pixel32 Pixel16 where
+   decimateBitDepth = decimateWord3216
+
 instance Decimable Pixel32 Pixel8 where
    decimateBitDepth = decimateWord32
 
@@ -330,9 +348,15 @@
 instance Decimable PixelF Pixel8 where
    decimateBitDepth = decimateFloat
 
+instance Decimable PixelF Pixel16 where
+   decimateBitDepth = decimateFloat16
+
 instance Decimable PixelRGBF PixelRGB8 where
    decimateBitDepth = decimateFloat
 
+instance Decimable PixelRGBF PixelRGB16 where
+   decimateBitDepth = decimateFloat16
+
 -- | Convert by any means possible a dynamic image to an image
 -- in RGBA. The process can lose precision while converting from
 -- 16bits pixels or Floating point pixels.
@@ -374,6 +398,27 @@
   ImageYCbCr8 img -> convertImage img
   ImageCMYK8  img -> convertImage img
   ImageCMYK16 img -> convertImage (decimateBitDepth img :: Image PixelCMYK8)
+  
+-- | Convert by any means possible a dynamic image to an image
+-- in RGB. The process can lose precision while converting from
+-- 32bits pixels or Floating point pixels. Any alpha layer will
+-- be dropped
+convertRGB16 :: DynamicImage -> Image PixelRGB16
+convertRGB16 dynImage = case dynImage of
+  ImageY8     img -> promoteImage img
+  ImageY16    img -> promoteImage img
+  ImageY32    img -> promoteImage (decimateBitDepth img :: Image Pixel16)
+  ImageYF     img -> promoteImage (decimateBitDepth img :: Image Pixel16)
+  ImageYA8    img -> promoteImage img
+  ImageYA16   img -> promoteImage img
+  ImageRGB8   img -> promoteImage img
+  ImageRGB16  img -> img
+  ImageRGBF   img -> decimateBitDepth img :: Image PixelRGB16
+  ImageRGBA8  img -> dropAlphaLayer (promoteImage img :: Image PixelRGBA16)
+  ImageRGBA16 img -> dropAlphaLayer img
+  ImageYCbCr8 img -> promoteImage (convertImage img :: Image PixelRGB8)
+  ImageCMYK8  img -> promoteImage (convertImage img :: Image PixelRGB8)
+  ImageCMYK16 img -> convertImage img
 
 -- | Equivalent to 'decodeImage', but also provide potential metadatas
 -- present in the given file and the palettes if the format provides them.


Reply via email to