Dash Core  0.12.2.1
P2P Digital Currency
uint256.cpp
Go to the documentation of this file.
1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2015 The Bitcoin Core developers
3 // Distributed under the MIT software license, see the accompanying
4 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
5 
6 #include "uint256.h"
7 
8 #include "utilstrencodings.h"
9 
10 #include <stdio.h>
11 #include <string.h>
12 
13 template <unsigned int BITS>
14 base_blob<BITS>::base_blob(const std::vector<unsigned char>& vch)
15 {
16  assert(vch.size() == sizeof(data));
17  memcpy(data, &vch[0], sizeof(data));
18 }
19 
20 template <unsigned int BITS>
21 std::string base_blob<BITS>::GetHex() const
22 {
23  char psz[sizeof(data) * 2 + 1];
24  for (unsigned int i = 0; i < sizeof(data); i++)
25  sprintf(psz + i * 2, "%02x", data[sizeof(data) - i - 1]);
26  return std::string(psz, psz + sizeof(data) * 2);
27 }
28 
29 template <unsigned int BITS>
30 void base_blob<BITS>::SetHex(const char* psz)
31 {
32  memset(data, 0, sizeof(data));
33 
34  // skip leading spaces
35  while (isspace(*psz))
36  psz++;
37 
38  // skip 0x
39  if (psz[0] == '0' && tolower(psz[1]) == 'x')
40  psz += 2;
41 
42  // hex string to uint
43  const char* pbegin = psz;
44  while (::HexDigit(*psz) != -1)
45  psz++;
46  psz--;
47  unsigned char* p1 = (unsigned char*)data;
48  unsigned char* pend = p1 + WIDTH;
49  while (psz >= pbegin && p1 < pend) {
50  *p1 = ::HexDigit(*psz--);
51  if (psz >= pbegin) {
52  *p1 |= ((unsigned char)::HexDigit(*psz--) << 4);
53  p1++;
54  }
55  }
56 }
57 
58 template <unsigned int BITS>
59 void base_blob<BITS>::SetHex(const std::string& str)
60 {
61  SetHex(str.c_str());
62 }
63 
64 template <unsigned int BITS>
65 std::string base_blob<BITS>::ToString() const
66 {
67  return (GetHex());
68 }
69 
70 // Explicit instantiations for base_blob<160>
71 template base_blob<160>::base_blob(const std::vector<unsigned char>&);
72 template std::string base_blob<160>::GetHex() const;
73 template std::string base_blob<160>::ToString() const;
74 template void base_blob<160>::SetHex(const char*);
75 template void base_blob<160>::SetHex(const std::string&);
76 
77 // Explicit instantiations for base_blob<256>
78 template base_blob<256>::base_blob(const std::vector<unsigned char>&);
79 template std::string base_blob<256>::GetHex() const;
80 template std::string base_blob<256>::ToString() const;
81 template void base_blob<256>::SetHex(const char*);
82 template void base_blob<256>::SetHex(const std::string&);
83 
84 static void inline HashMix(uint32_t& a, uint32_t& b, uint32_t& c)
85 {
86  // Taken from lookup3, by Bob Jenkins.
87  a -= c;
88  a ^= ((c << 4) | (c >> 28));
89  c += b;
90  b -= a;
91  b ^= ((a << 6) | (a >> 26));
92  a += c;
93  c -= b;
94  c ^= ((b << 8) | (b >> 24));
95  b += a;
96  a -= c;
97  a ^= ((c << 16) | (c >> 16));
98  c += b;
99  b -= a;
100  b ^= ((a << 19) | (a >> 13));
101  a += c;
102  c -= b;
103  c ^= ((b << 4) | (b >> 28));
104  b += a;
105 }
106 
107 static void inline HashFinal(uint32_t& a, uint32_t& b, uint32_t& c)
108 {
109  // Taken from lookup3, by Bob Jenkins.
110  c ^= b;
111  c -= ((b << 14) | (b >> 18));
112  a ^= c;
113  a -= ((c << 11) | (c >> 21));
114  b ^= a;
115  b -= ((a << 25) | (a >> 7));
116  c ^= b;
117  c -= ((b << 16) | (b >> 16));
118  a ^= c;
119  a -= ((c << 4) | (c >> 28));
120  b ^= a;
121  b -= ((a << 14) | (a >> 18));
122  c ^= b;
123  c -= ((b << 24) | (b >> 8));
124 }
125 
126 uint64_t uint256::GetHash(const uint256& salt) const
127 {
128  uint32_t a, b, c;
129  const uint32_t *pn = (const uint32_t*)data;
130  const uint32_t *salt_pn = (const uint32_t*)salt.data;
131  a = b = c = 0xdeadbeef + WIDTH;
132 
133  a += pn[0] ^ salt_pn[0];
134  b += pn[1] ^ salt_pn[1];
135  c += pn[2] ^ salt_pn[2];
136  HashMix(a, b, c);
137  a += pn[3] ^ salt_pn[3];
138  b += pn[4] ^ salt_pn[4];
139  c += pn[5] ^ salt_pn[5];
140  HashMix(a, b, c);
141  a += pn[6] ^ salt_pn[6];
142  b += pn[7] ^ salt_pn[7];
143  HashFinal(a, b, c);
144 
145  return ((((uint64_t)b) << 32) | c);
146 }
string salt
Definition: rpcuser.py:25
uint8_t data[WIDTH]
Definition: uint256.h:24
base_blob()
Definition: uint256.h:26
uint64_t GetHash(const uint256 &salt) const
Definition: uint256.cpp:126
static void HashMix(uint32_t &a, uint32_t &b, uint32_t &c)
Definition: uint256.cpp:84
static void HashFinal(uint32_t &a, uint32_t &b, uint32_t &c)
Definition: uint256.cpp:107
std::string ToString() const
Definition: uint256.cpp:65
void * memcpy(void *a, const void *b, size_t c)
std::string GetHex() const
Definition: uint256.cpp:21
signed char HexDigit(char c)
void SetHex(const char *psz)
Definition: uint256.cpp:30