00001 /***************************************************************************** 00002 * vlc_md5.h: MD5 hash 00003 ***************************************************************************** 00004 * Copyright (C) 2004-2005 the VideoLAN team 00005 * $Id$ 00006 * 00007 * Authors: Jon Lech Johansen <jon-vl@nanocrew.net> 00008 * Sam Hocevar <sam@zoy.org> 00009 * 00010 * This program is free software; you can redistribute it and/or modify 00011 * it under the terms of the GNU General Public License as published by 00012 * the Free Software Foundation; either version 2 of the License, or 00013 * (at your option) any later version. 00014 * 00015 * This program is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00018 * GNU General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU General Public License 00021 * along with this program; if not, write to the Free Software 00022 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. 00023 *****************************************************************************/ 00024 00025 #ifndef VLC_MD5_H 00026 # define VLC_MD5_H 00027 00028 /** 00029 * \file 00030 * This file defines functions and structures for handling md5 checksums 00031 */ 00032 00033 /***************************************************************************** 00034 * md5_s: MD5 message structure 00035 ***************************************************************************** 00036 * This structure stores the static information needed to compute an MD5 00037 * hash. It has an extra data buffer to allow non-aligned writes. 00038 *****************************************************************************/ 00039 struct md5_s 00040 { 00041 uint64_t i_bits; /* Total written bits */ 00042 uint32_t p_digest[4]; /* The MD5 digest */ 00043 uint32_t p_data[16]; /* Buffer to cache non-aligned writes */ 00044 }; 00045 00046 VLC_EXPORT(void, InitMD5, ( struct md5_s * ) ); 00047 VLC_EXPORT(void, AddMD5, ( struct md5_s *, const void *, size_t ) ); 00048 VLC_EXPORT(void, EndMD5, ( struct md5_s * ) ); 00049 00050 /** 00051 * Returns a char representation of the md5 hash, as shown by UNIX md5 or 00052 * md5sum tools. 00053 */ 00054 static inline char * psz_md5_hash( struct md5_s *md5_s ) 00055 { 00056 char *psz = malloc( 33 ); /* md5 string is 32 bytes + NULL character */ 00057 if( !psz ) return NULL; 00058 00059 int i; 00060 for ( i = 0; i < 4; i++ ) 00061 { 00062 sprintf( &psz[8*i], "%02x%02x%02x%02x", 00063 md5_s->p_digest[i] & 0xff, 00064 ( md5_s->p_digest[i] >> 8 ) & 0xff, 00065 ( md5_s->p_digest[i] >> 16 ) & 0xff, 00066 md5_s->p_digest[i] >> 24 00067 ); 00068 } 00069 psz[32] = '\0'; 00070 00071 return psz; 00072 } 00073 00074 #endif
1.5.6