LCOV - code coverage report
Current view: top level - image/encoders/ico - nsICOEncoder.h (source / functions) Hit Total Coverage
Test: output.info Lines: 0 6 0.0 %
Date: 2017-07-14 16:53:18 Functions: 0 3 0.0 %
Legend: Lines: hit not hit

          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

Generated by: LCOV version 1.13