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.