1 # Eloipool - Python Bitcoin pool server
2 # Copyright (C) 2011-2012 Luke Dashjr <luke-jr+eloipool@utopios.org>
4 # This program is free software: you can redistribute it and/or modify
5 # it under the terms of the GNU Affero General Public License as
6 # published by the Free Software Foundation, either version 3 of the
7 # License, or (at your option) any later version.
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU Affero General Public License for more details.
14 # You should have received a copy of the GNU Affero General Public License
15 # along with this program. If not, see <http://www.gnu.org/licenses/>.
17 from hashlib import sha256
18 from struct import unpack
22 return sha256(sha256(b).digest()).digest()
26 for i in range(0, len(b), 4):
27 o += b[i + 3:i - 1 if i else None:-1]
30 def Bits2Target(bits):
31 return unpack('<L', bits[:3] + b'\0')[0] * 2**(8*(bits[3] - 3))
34 n = unpack('<QQQQ', h)
35 n = (n[3] << 192) | (n[2] << 128) | (n[1] << 64) | n[0]
38 def tryErr(func, *a, **kw):
39 IE = kw.pop('IgnoredExceptions', BaseException)
40 logger = kw.pop('Logger', None)
41 emsg = kw.pop('ErrorMsg', None)
46 emsg = "%s\n" % (emsg,) if emsg else ""
47 emsg += traceback.format_exc()
51 class RejectedShare(ValueError):
62 def _build_heap(self):
63 newheap = list((v[0], k, v[1]) for k, v in self._dict.items())
64 heapq.heapify(newheap)
69 (t, k, o) = self._heap[0]
72 heapq.heappop(self._heap)
77 (t, k, o) = heapq.heappop(self._heap)
83 def __setitem__(self, o, t):
85 self._dict[k] = (t, o)
86 if len(self._heap) / 2 > len(self._dict):
89 heapq.heappush(self._heap, (t, k, o))
91 def __getitem__(self, o):
92 return self._dict[id(o)][0]
94 def __delitem__(self, o):
96 if len(self._dict) < 2:
100 return len(self._dict)