/* * Copyright 2012 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef SkMD5_DEFINED #define SkMD5_DEFINED #include "SkTypes.h" #include "SkEndian.h" #include "SkStream.h" //The following macros can be defined to affect the MD5 code generated. //SK_MD5_CLEAR_DATA causes all intermediate state to be overwritten with 0's. //SK_CPU_LENDIAN allows 32 bit <=> 8 bit conversions without copies (if alligned). //SK_CPU_FAST_UNALIGNED_ACCESS allows 32 bit <=> 8 bit conversions without copies if SK_CPU_LENDIAN. class SkMD5 : public SkWStream { public: SkMD5(); /** Processes input, adding it to the digest. * Note that this treats the buffer as a series of uint8_t values. */ bool write(const void* buffer, size_t size) override { this->update(reinterpret_cast<const uint8_t*>(buffer), size); return true; } size_t bytesWritten() const override { return SkToSizeT(this->byteCount); } /** Processes input, adding it to the digest. Calling this after finish is undefined. */ void update(const uint8_t* input, size_t length); struct Digest { uint8_t data[16]; bool operator ==(Digest const& other) const { return 0 == memcmp(data, other.data, sizeof(data)); } bool operator !=(Digest const& other) const { return 0 != memcmp(data, other.data, sizeof(data)); } }; /** Computes and returns the digest. */ void finish(Digest& digest); private: // number of bytes, modulo 2^64 uint64_t byteCount; // state (ABCD) uint32_t state[4]; // input buffer uint8_t buffer[64]; }; #endif