xref: /aosp_15_r20/external/skia/src/codec/SkPngCompositeChunkReader.h (revision c8dee2aa9b3f27cf6c858bd81872bdeb2c07ed17)
1*c8dee2aaSAndroid Build Coastguard Worker /*
2*c8dee2aaSAndroid Build Coastguard Worker  * Copyright 2024 Google Inc.
3*c8dee2aaSAndroid Build Coastguard Worker  *
4*c8dee2aaSAndroid Build Coastguard Worker  * Use of this source code is governed by a BSD-style license that can be
5*c8dee2aaSAndroid Build Coastguard Worker  * found in the LICENSE file.
6*c8dee2aaSAndroid Build Coastguard Worker  */
7*c8dee2aaSAndroid Build Coastguard Worker #ifndef SkPngCompositeChunkReader_DEFINED
8*c8dee2aaSAndroid Build Coastguard Worker #define SkPngCompositeChunkReader_DEFINED
9*c8dee2aaSAndroid Build Coastguard Worker 
10*c8dee2aaSAndroid Build Coastguard Worker #include "include/codec/SkPngChunkReader.h"
11*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkRefCnt.h"
12*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkStream.h"
13*c8dee2aaSAndroid Build Coastguard Worker #include "include/private/SkGainmapInfo.h"
14*c8dee2aaSAndroid Build Coastguard Worker 
15*c8dee2aaSAndroid Build Coastguard Worker #include <cstddef>
16*c8dee2aaSAndroid Build Coastguard Worker #include <memory>
17*c8dee2aaSAndroid Build Coastguard Worker #include <optional>
18*c8dee2aaSAndroid Build Coastguard Worker #include <utility>
19*c8dee2aaSAndroid Build Coastguard Worker 
20*c8dee2aaSAndroid Build Coastguard Worker /**
21*c8dee2aaSAndroid Build Coastguard Worker  * Reader for PNG chunks that handles the composite of:
22*c8dee2aaSAndroid Build Coastguard Worker  * 1. Chunks currently unknown to the PNG spec, but are necessary to correctly
23*c8dee2aaSAndroid Build Coastguard Worker  *    decode certain images. For example, images that contain gainmap chunks.
24*c8dee2aaSAndroid Build Coastguard Worker  * 2. Client-provided callbacks that may listen to other unknown chunks.
25*c8dee2aaSAndroid Build Coastguard Worker  *
26*c8dee2aaSAndroid Build Coastguard Worker  * The PNG api can only register one callback for unknown chunks at a time,
27*c8dee2aaSAndroid Build Coastguard Worker  * hence this wrapper class.
28*c8dee2aaSAndroid Build Coastguard Worker  */
29*c8dee2aaSAndroid Build Coastguard Worker class SkPngCompositeChunkReader : public SkPngChunkReader {
30*c8dee2aaSAndroid Build Coastguard Worker public:
SkPngCompositeChunkReader(SkPngChunkReader * chunkReader)31*c8dee2aaSAndroid Build Coastguard Worker     explicit SkPngCompositeChunkReader(SkPngChunkReader* chunkReader)
32*c8dee2aaSAndroid Build Coastguard Worker             : fChunkReader(SkSafeRef(chunkReader)) {}
33*c8dee2aaSAndroid Build Coastguard Worker 
34*c8dee2aaSAndroid Build Coastguard Worker     bool readChunk(const char tag[], const void* data, size_t length) override;
35*c8dee2aaSAndroid Build Coastguard Worker 
takeGaimapStream()36*c8dee2aaSAndroid Build Coastguard Worker     std::unique_ptr<SkStream> takeGaimapStream() { return std::move(fGainmapStream); }
37*c8dee2aaSAndroid Build Coastguard Worker 
getGainmapInfo()38*c8dee2aaSAndroid Build Coastguard Worker     std::optional<SkGainmapInfo> getGainmapInfo() const { return fGainmapInfo; }
39*c8dee2aaSAndroid Build Coastguard Worker 
40*c8dee2aaSAndroid Build Coastguard Worker private:
41*c8dee2aaSAndroid Build Coastguard Worker     sk_sp<SkPngChunkReader> fChunkReader = nullptr;
42*c8dee2aaSAndroid Build Coastguard Worker     std::optional<SkGainmapInfo> fGainmapInfo;
43*c8dee2aaSAndroid Build Coastguard Worker     std::unique_ptr<SkStream> fGainmapStream = nullptr;
44*c8dee2aaSAndroid Build Coastguard Worker };
45*c8dee2aaSAndroid Build Coastguard Worker 
46*c8dee2aaSAndroid Build Coastguard Worker #endif  // SkPngCompositeChunkReader_DEFINED
47