Move update-external.sh to third_party/
[Samba.git] / lib / crypto / md5.h
blobec6128e86cab7bab132f1cc79f2fc426fc9be85d
1 #ifndef MD5_H
2 #define MD5_H
4 #ifndef HEADER_MD5_H
5 /* Try to avoid clashes with OpenSSL */
6 #define HEADER_MD5_H
7 #endif
9 #if defined(HAVE_BSD_MD5_H)
10 /* Try to avoid clashes with BSD MD5 implementation (on linux) */
11 #include <bsd/md5.h>
13 #elif defined(HAVE_SYS_MD5_H)
14 /* Try to avoid clashes with BSD MD5 implementation (on BSD) */
15 #include <sys/md5.h>
17 /* Try to use CommonCrypto on Mac as otherwise we can get MD5Final twice */
18 #elif defined(HAVE_COMMONCRYPTO_COMMONDIGEST_H)
19 #include <CommonCrypto/CommonDigest.h>
21 #define MD5_CTX CC_MD5_CTX
22 #define MD5Init(c) CC_MD5_Init(c)
23 #define MD5Update(c,d,l) CC_MD5_Update(c,d,l)
24 #define MD5Final(m, c) CC_MD5_Final((unsigned char *)m,c)
25 #define MD5Context CC_MD5state_st
27 #else
28 typedef struct MD5Context {
29 uint32_t buf[4];
30 uint32_t bits[2];
31 uint8_t in[64];
32 } MD5_CTX;
34 #define MD5_DIGEST_LENGTH 16
36 void MD5Init(MD5_CTX *context);
37 void MD5Update(MD5_CTX *context, const uint8_t *buf,
38 size_t len);
39 void MD5Final(uint8_t digest[MD5_DIGEST_LENGTH], MD5_CTX *context);
40 #endif /* HAVE_*MD5_H */
42 #endif /* !MD5_H */