]>
git.saurik.com Git - apt.git/blob - apt-pkg/contrib/hashsum_template.h
1 // -*- mode: cpp; mode: fold -*-
3 // $Id: hashsum_template.h,v 1.3 2001/05/07 05:05:47 jgg Exp $
4 /* ######################################################################
6 HashSumValueTemplate - Generic Storage for a hash value
8 ##################################################################### */
10 #ifndef APTPKG_HASHSUM_TEMPLATE_H
11 #define APTPKG_HASHSUM_TEMPLATE_H
21 unsigned char Sum
[N
/8];
26 bool operator ==(const HashSumValue
&rhs
) const
28 return memcmp(Sum
,rhs
.Sum
,sizeof(Sum
)) == 0;
31 std::string
Value() const
34 { '0','1','2','3','4','5','6','7','8','9','a','b',
37 char Result
[((N
/8)*2)+1];
40 // Convert each char into two letters
43 for (; I
!= (N
/8)*2; J
++,I
+= 2)
45 Result
[I
] = Conv
[Sum
[J
] >> 4];
46 Result
[I
+ 1] = Conv
[Sum
[J
] & 0xF];
48 return std::string(Result
);
51 inline void Value(unsigned char S
[N
/8])
53 for (int I
= 0; I
!= sizeof(Sum
); I
++)
57 inline operator std::string() const
62 bool Set(std::string Str
)
64 return Hex2Num(Str
,Sum
,sizeof(Sum
));
67 inline void Set(unsigned char S
[N
/8])
69 for (int I
= 0; I
!= sizeof(Sum
); I
++)
73 HashSumValue(std::string Str
)
75 memset(Sum
,0,sizeof(Sum
));
80 memset(Sum
,0,sizeof(Sum
));
84 class SummationImplementation
87 virtual bool Add(const unsigned char *inbuf
, unsigned long long inlen
) = 0;
88 inline bool Add(const char *inbuf
, unsigned long long const inlen
)
89 { return Add((unsigned char *)inbuf
, inlen
); };
91 inline bool Add(const unsigned char *Data
)
92 { return Add(Data
, strlen((const char *)Data
)); };
93 inline bool Add(const char *Data
)
94 { return Add((const unsigned char *)Data
, strlen((const char *)Data
)); };
96 inline bool Add(const unsigned char *Beg
, const unsigned char *End
)
97 { return Add(Beg
, End
- Beg
); };
98 inline bool Add(const char *Beg
, const char *End
)
99 { return Add((const unsigned char *)Beg
, End
- Beg
); };
101 bool AddFD(int Fd
, unsigned long long Size
= 0);