File tree Expand file tree Collapse file tree 4 files changed +36
-8
lines changed
src/ImageSharp/Formats/Webp Expand file tree Collapse file tree 4 files changed +36
-8
lines changed Original file line number Diff line number Diff line change @@ -660,14 +660,22 @@ private uint ReadChunkSize()
660660 /// </summary>
661661 /// <param name="chunkType">The chunk type.</param>
662662 /// <returns>True, if its an optional chunk type.</returns>
663- private static bool IsOptionalVp8XChunk ( WebpChunkType chunkType ) => chunkType switch
663+ private static bool IsOptionalVp8XChunk ( WebpChunkType chunkType )
664664 {
665- WebpChunkType . Alpha => true ,
666- WebpChunkType . Animation => true ,
667- WebpChunkType . Exif => true ,
668- WebpChunkType . Iccp => true ,
669- WebpChunkType . Xmp => true ,
670- _ => false
671- } ;
665+ switch ( chunkType )
666+ {
667+ case WebpChunkType . Alpha :
668+ case WebpChunkType . Iccp :
669+ case WebpChunkType . Exif :
670+ case WebpChunkType . Xmp :
671+ return true ;
672+ case WebpChunkType . AnimationParameter :
673+ case WebpChunkType . Animation :
674+ WebpThrowHelper . ThrowNotSupportedException ( "Animated webp are not yet supported." ) ;
675+ return false ;
676+ default :
677+ return false ;
678+ }
679+ }
672680 }
673681}
Original file line number Diff line number Diff line change 11// Copyright (c) Six Labors.
22// Licensed under the Apache License, Version 2.0.
33
4+ using System ;
45using System . IO ;
56using SixLabors . ImageSharp . Formats . Webp ;
67using SixLabors . ImageSharp . PixelFormats ;
@@ -369,6 +370,19 @@ public void WebpDecoder_ThrowImageFormatException_OnInvalidImages<TPixel>(TestIm
369370 }
370371 } ) ;
371372
373+ // https://github.com/SixLabors/ImageSharp/issues/2154
374+ [ Theory ]
375+ [ WithFile ( Lossless . Issue2154 , PixelTypes . Rgba32 ) ]
376+ public void WebpDecoder_ThrowsNotSupportedException_Issue2154 < TPixel > ( TestImageProvider < TPixel > provider )
377+ where TPixel : unmanaged, IPixel < TPixel > =>
378+ Assert . Throws < NotSupportedException > (
379+ ( ) =>
380+ {
381+ using ( provider . GetImage ( WebpDecoder ) )
382+ {
383+ }
384+ } ) ;
385+
372386#if SUPPORTS_RUNTIME_INTRINSICS
373387 private static void RunDecodeLossyWithHorizontalFilter ( )
374388 {
Original file line number Diff line number Diff line change @@ -632,6 +632,9 @@ public static class Lossless
632632 public const string LossLessCorruptImage3 = "Webp/lossless_color_transform.webp" ; // cross_color, predictor
633633
634634 public const string LossLessCorruptImage4 = "Webp/near_lossless_75.webp" ; // predictor, cross_color.
635+
636+ // Issues
637+ public const string Issue2154 = "Webp/issues/Issue2154.webp" ;
635638 }
636639
637640 public static class Lossy
You can’t perform that action at this time.
0 commit comments