Line data Source code
1 : /* This Source Code Form is subject to the terms of the Mozilla Public
2 : * License, v. 2.0. If a copy of the MPL was not distributed with this
3 : * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
4 :
5 : #ifndef mozilla_image_encoders_ico_nsICOEncoder_h
6 : #define mozilla_image_encoders_ico_nsICOEncoder_h
7 :
8 : #include "mozilla/Attributes.h"
9 : #include "mozilla/ReentrantMonitor.h"
10 :
11 : #include "imgIEncoder.h"
12 :
13 : #include "nsCOMPtr.h"
14 : #include "ICOFileHeaders.h"
15 :
16 : #define NS_ICOENCODER_CID \
17 : { /*92AE3AB2-8968-41B1-8709-B6123BCEAF21 */ \
18 : 0x92ae3ab2, \
19 : 0x8968, \
20 : 0x41b1, \
21 : {0x87, 0x09, 0xb6, 0x12, 0x3b, 0Xce, 0xaf, 0x21} \
22 : }
23 :
24 : // Provides ICO encoding functionality. Use InitFromData() to do the
25 : // encoding. See that function definition for encoding options.
26 :
27 : class nsICOEncoder final : public imgIEncoder
28 : {
29 : typedef mozilla::ReentrantMonitor ReentrantMonitor;
30 : public:
31 : NS_DECL_THREADSAFE_ISUPPORTS
32 : NS_DECL_IMGIENCODER
33 : NS_DECL_NSIINPUTSTREAM
34 : NS_DECL_NSIASYNCINPUTSTREAM
35 :
36 : nsICOEncoder();
37 :
38 : // Obtains the width of the icon directory entry
39 0 : uint32_t GetRealWidth() const
40 : {
41 0 : return mICODirEntry.mWidth == 0 ? 256 : mICODirEntry.mWidth;
42 : }
43 :
44 : // Obtains the height of the icon directory entry
45 0 : uint32_t GetRealHeight() const
46 : {
47 0 : return mICODirEntry.mHeight == 0 ? 256 : mICODirEntry.mHeight;
48 : }
49 :
50 : protected:
51 : ~nsICOEncoder();
52 :
53 : nsresult ParseOptions(const nsAString& aOptions, uint16_t& aBppOut,
54 : bool& aUsePNGOut);
55 : void NotifyListener();
56 :
57 : // Initializes the icon file header mICOFileHeader
58 : void InitFileHeader();
59 : // Initializes the icon directory info header mICODirEntry
60 : void InitInfoHeader(uint16_t aBPP, uint8_t aWidth, uint8_t aHeight);
61 : // Encodes the icon file header mICOFileHeader
62 : void EncodeFileHeader();
63 : // Encodes the icon directory info header mICODirEntry
64 : void EncodeInfoHeader();
65 : // Obtains the current offset filled up to for the image buffer
66 0 : inline int32_t GetCurrentImageBufferOffset()
67 : {
68 0 : return static_cast<int32_t>(mImageBufferCurr - mImageBufferStart);
69 : }
70 :
71 : // Holds either a PNG or a BMP depending on the encoding options specified
72 : // or if no encoding options specified will use the default (PNG)
73 : nsCOMPtr<imgIEncoder> mContainedEncoder;
74 :
75 : // These headers will always contain endian independent stuff.
76 : // Don't trust the width and height of mICODirEntry directly,
77 : // instead use the accessors GetRealWidth() and GetRealHeight().
78 : mozilla::image::IconFileHeader mICOFileHeader;
79 : mozilla::image::IconDirEntry mICODirEntry;
80 :
81 : // Keeps track of the start of the image buffer
82 : uint8_t* mImageBufferStart;
83 : // Keeps track of the current position in the image buffer
84 : uint8_t* mImageBufferCurr;
85 : // Keeps track of the image buffer size
86 : uint32_t mImageBufferSize;
87 : // Keeps track of the number of bytes in the image buffer which are read
88 : uint32_t mImageBufferReadPoint;
89 : // Stores true if the image is done being encoded
90 : bool mFinished;
91 : // Stores true if the contained image is a PNG
92 : bool mUsePNG;
93 :
94 : nsCOMPtr<nsIInputStreamCallback> mCallback;
95 : nsCOMPtr<nsIEventTarget> mCallbackTarget;
96 : uint32_t mNotifyThreshold;
97 : };
98 :
99 : #endif // mozilla_image_encoders_ico_nsICOEncoder_h
|