/* * Copyright (c) 2012 The WebM project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef LIBVPX_TEST_MD5_HELPER_H_ #define LIBVPX_TEST_MD5_HELPER_H_ extern "C" { #include "./md5_utils.h" #include "vpx/vpx_decoder.h" } namespace libvpx_test { class MD5 { public: MD5() { MD5Init(&md5_); } void Add(const vpx_image_t *img) { for (int plane = 0; plane < 3; ++plane) { uint8_t *buf = img->planes[plane]; const int h = plane ? (img->d_h + 1) >> 1 : img->d_h; const int w = plane ? (img->d_w + 1) >> 1 : img->d_w; for (int y = 0; y < h; ++y) { MD5Update(&md5_, buf, w); buf += img->stride[plane]; } } } const char *Get(void) { static const char hex[16] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', }; uint8_t tmp[16]; MD5Context ctx_tmp = md5_; MD5Final(tmp, &ctx_tmp); for (int i = 0; i < 16; i++) { res_[i * 2 + 0] = hex[tmp[i] >> 4]; res_[i * 2 + 1] = hex[tmp[i] & 0xf]; } res_[32] = 0; return res_; } protected: char res_[33]; MD5Context md5_; }; } // namespace libvpx_test #endif // LIBVPX_TEST_MD5_HELPER_H_