mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
8c296bbcd4
This patch was generated by a script. Here's the source of the script for future reference: function convert() { echo "Converting $1 to $2..." find . ! -wholename "*nsprpub*" \ ! -wholename "*security/nss*" \ ! -wholename "*/.hg*" \ ! -wholename "obj-ff-dbg*" \ ! -name nsXPCOMCID.h \ ! -name prtypes.h \ -type f \ \( -iname "*.cpp" \ -o -iname "*.h" \ -o -iname "*.c" \ -o -iname "*.cc" \ -o -iname "*.idl" \ -o -iname "*.ipdl" \ -o -iname "*.ipdlh" \ -o -iname "*.mm" \) | \ xargs -n 1 sed -i -e "s/\b$1\b/$2/g" } convert PRInt8 int8_t convert PRUint8 uint8_t convert PRInt16 int16_t convert PRUint16 uint16_t convert PRInt32 int32_t convert PRUint32 uint32_t convert PRInt64 int64_t convert PRUint64 uint64_t convert PRIntn int convert PRUintn unsigned convert PRSize size_t convert PROffset32 int32_t convert PROffset64 int64_t convert PRPtrdiff ptrdiff_t convert PRFloat64 double
67 lines
2.0 KiB
C++
67 lines
2.0 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#ifndef nsIconDecoder_h__
|
|
#define nsIconDecoder_h__
|
|
|
|
#include "Decoder.h"
|
|
|
|
#include "nsCOMPtr.h"
|
|
|
|
#include "imgIDecoderObserver.h"
|
|
|
|
namespace mozilla {
|
|
namespace image {
|
|
class RasterImage;
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////
|
|
// The icon decoder is a decoder specifically tailored for loading icons
|
|
// from the OS. We've defined our own little format to represent these icons
|
|
// and this decoder takes that format and converts it into 24-bit RGB with alpha channel
|
|
// support. It was modeled a bit off the PPM decoder.
|
|
//
|
|
// Assumptions about the decoder:
|
|
// (1) We receive ALL of the data from the icon channel in one OnDataAvailable call. We don't
|
|
// support multiple ODA calls yet.
|
|
// (2) the format of the incoming data is as follows:
|
|
// The first two bytes contain the width and the height of the icon.
|
|
// The remaining bytes contain the icon data, 4 bytes per pixel, in
|
|
// ARGB order (platform endianness, A in highest bits, B in lowest
|
|
// bits), row-primary, top-to-bottom, left-to-right, with
|
|
// premultiplied alpha.
|
|
//
|
|
//
|
|
//////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
class nsIconDecoder : public Decoder
|
|
{
|
|
public:
|
|
|
|
nsIconDecoder(RasterImage &aImage, imgIDecoderObserver* aObserver);
|
|
virtual ~nsIconDecoder();
|
|
|
|
virtual void WriteInternal(const char* aBuffer, uint32_t aCount);
|
|
|
|
uint8_t mWidth;
|
|
uint8_t mHeight;
|
|
uint32_t mPixBytesRead;
|
|
uint32_t mPixBytesTotal;
|
|
uint8_t* mImageData;
|
|
uint32_t mState;
|
|
};
|
|
|
|
enum {
|
|
iconStateStart = 0,
|
|
iconStateHaveHeight = 1,
|
|
iconStateReadPixels = 2,
|
|
iconStateFinished = 3
|
|
};
|
|
|
|
} // namespace image
|
|
} // namespace mozilla
|
|
|
|
#endif // nsIconDecoder_h__
|