| Index: src/codec/SkJpegCodec.h | 
| diff --git a/src/codec/SkJpegCodec.h b/src/codec/SkJpegCodec.h | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..51a741a525aa0936442aa7ac50c179f6e07db5fb | 
| --- /dev/null | 
| +++ b/src/codec/SkJpegCodec.h | 
| @@ -0,0 +1,99 @@ | 
| +/* | 
| + * Copyright 2015 Google Inc. | 
| + * | 
| + * Use of this source code is governed by a BSD-style license that can be | 
| + * found in the LICENSE file. | 
| + */ | 
| + | 
| +#ifndef SkJpegCodec_DEFINED | 
| +#define SkJpegCodec_DEFINED | 
| + | 
| +#include "SkCodec.h" | 
| +#include "SkImageInfo.h" | 
| +#include "SkJpegDecoderMgr.h" | 
| +#include "SkJpegUtility.h" | 
| +#include "SkStream.h" | 
| + | 
| +extern "C" { | 
| +    #include "jpeglib.h" | 
| +} | 
| + | 
| +/* | 
| + * | 
| + * This class implements the decoding for jpeg images | 
| + * | 
| + */ | 
| +class SkJpegCodec : public SkCodec { | 
| +public: | 
| + | 
| +    /* | 
| +     * Checks the start of the stream to see if the image is a jpeg | 
| +     * Does not take ownership of the stream | 
| +     */ | 
| +    static bool IsJpeg(SkStream*); | 
| + | 
| +    /* | 
| +     * Assumes IsJpeg was called and returned true | 
| +     * Creates a jpeg decoder | 
| +     * Takes ownership of the stream | 
| +     */ | 
| +    static SkCodec* NewFromStream(SkStream*); | 
| + | 
| +protected: | 
| + | 
| +    /* | 
| +     * Recommend a set of destination dimensions given a requested scale | 
| +     */ | 
| +    SkISize onGetScaledDimensions(float desiredScale) const override; | 
| + | 
| +    /* | 
| +     * Initiates the jpeg decode | 
| +     */ | 
| +    Result onGetPixels(const SkImageInfo& dstInfo, void* dst, size_t dstRowBytes, const Options&, | 
| +            SkPMColor*, int*) override; | 
| + | 
| +    SkEncodedFormat onGetEncodedFormat() const override { | 
| +        return kJPEG_SkEncodedFormat; | 
| +    } | 
| + | 
| +private: | 
| + | 
| +    /* | 
| +     * Read enough of the stream to initialize the SkJpegCodec. | 
| +     * Returns a bool representing success or failure. | 
| +     * | 
| +     * @param codecOut | 
| +     * If this returns true, and codecOut was not NULL, | 
| +     * codecOut will be set to a new SkJpegCodec. | 
| +     * | 
| +     * @param decoderMgrOut | 
| +     * If this returns true, and codecOut was NULL, | 
| +     * decoderMgrOut must be non-NULL and decoderMgrOut will be set to a new | 
| +     * JpegDecoderMgr pointer. | 
| +     * | 
| +     * @param stream | 
| +     * Deleted on failure. | 
| +     * codecOut will take ownership of it in the case where we created a codec. | 
| +     * Ownership is unchanged when we set decoderMgrOut. | 
| +     * | 
| +     */ | 
| +    static bool ReadHeader(SkStream* stream, SkCodec** codecOut, | 
| +            JpegDecoderMgr** decoderMgrOut); | 
| + | 
| +    /* | 
| +     * Creates an instance of the decoder | 
| +     * Called only by NewFromStream | 
| +     * | 
| +     * @param srcInfo contains the source width and height | 
| +     * @param stream the encoded image data | 
| +     * @param decoderMgr holds decompress struct, src manager, and error manager | 
| +     *                   takes ownership | 
| +     */ | 
| +    SkJpegCodec(const SkImageInfo& srcInfo, SkStream* stream, JpegDecoderMgr* decoderMgr); | 
| + | 
| +    SkAutoTDelete<JpegDecoderMgr> fDecoderMgr; | 
| + | 
| +    typedef SkCodec INHERITED; | 
| +}; | 
| + | 
| +#endif | 
|  |