mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 21:12:43 +00:00 
			
		
		
		
	 da394abe04
			
		
	
	
		da394abe04
		
	
	
	
	
		
			
			This prevents callers from accidentally discarding the result of initialize(), which was the root cause of this OSS Fuzz bug: https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=55896&q=label%3AProj-serenity&sort=summary
		
			
				
	
	
		
			40 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <LibGfx/Bitmap.h>
 | |
| #include <LibGfx/ImageFormats/ImageDecoder.h>
 | |
| 
 | |
| namespace Gfx {
 | |
| 
 | |
| struct GIFLoadingContext;
 | |
| 
 | |
| class GIFImageDecoderPlugin final : public ImageDecoderPlugin {
 | |
| public:
 | |
|     static bool sniff(ReadonlyBytes);
 | |
|     static ErrorOr<NonnullOwnPtr<ImageDecoderPlugin>> create(ReadonlyBytes);
 | |
| 
 | |
|     virtual ~GIFImageDecoderPlugin() override;
 | |
| 
 | |
|     virtual IntSize size() override;
 | |
|     virtual void set_volatile() override;
 | |
|     [[nodiscard]] virtual bool set_nonvolatile(bool& was_purged) override;
 | |
|     virtual ErrorOr<void> initialize() override;
 | |
|     virtual bool is_animated() override;
 | |
|     virtual size_t loop_count() override;
 | |
|     virtual size_t frame_count() override;
 | |
|     virtual size_t first_animated_frame_index() override;
 | |
|     virtual ErrorOr<ImageFrameDescriptor> frame(size_t index) override;
 | |
|     virtual ErrorOr<Optional<ReadonlyBytes>> icc_data() override;
 | |
| 
 | |
| private:
 | |
|     GIFImageDecoderPlugin(u8 const*, size_t);
 | |
| 
 | |
|     OwnPtr<GIFLoadingContext> m_context;
 | |
| };
 | |
| 
 | |
| }
 |