mirror of
https://github.com/Mikaela/Limnoria.git
synced 2024-12-19 08:32:55 +01:00
src/cdb.py: Use 'future' division and decode/encode data from/to the disk.
This commit is contained in:
parent
535593d555
commit
1b6be5842f
21
src/cdb.py
21
src/cdb.py
@ -32,6 +32,8 @@ Database module, similar to dbhash. Uses a format similar to (if not entirely
|
|||||||
the same as) DJB's CDB <http://cr.yp.to/cdb.html>.
|
the same as) DJB's CDB <http://cr.yp.to/cdb.html>.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
from __future__ import division
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
import struct
|
import struct
|
||||||
@ -144,8 +146,8 @@ class Maker(object):
|
|||||||
hashPointer = h % 256
|
hashPointer = h % 256
|
||||||
startPosition = self.fd.tell()
|
startPosition = self.fd.tell()
|
||||||
self.fd.write(pack2Ints(len(key), len(data)))
|
self.fd.write(pack2Ints(len(key), len(data)))
|
||||||
self.fd.write(key)
|
self.fd.write(key.encode())
|
||||||
self.fd.write(data)
|
self.fd.write(data.encode())
|
||||||
self.hashes[hashPointer].append((h, startPosition))
|
self.hashes[hashPointer].append((h, startPosition))
|
||||||
|
|
||||||
def finish(self):
|
def finish(self):
|
||||||
@ -164,7 +166,7 @@ class Maker(object):
|
|||||||
hashLen = len(hash) * 2
|
hashLen = len(hash) * 2
|
||||||
a = [(0, 0)] * hashLen
|
a = [(0, 0)] * hashLen
|
||||||
for (h, pos) in hash:
|
for (h, pos) in hash:
|
||||||
i = (h / 256) % hashLen
|
i = (h // 256) % hashLen
|
||||||
while a[i] != (0, 0):
|
while a[i] != (0, 0):
|
||||||
i = (i + 1) % hashLen
|
i = (i + 1) % hashLen
|
||||||
a[i] = (h, pos)
|
a[i] = (h, pos)
|
||||||
@ -208,7 +210,8 @@ class Reader(utils.IterableMap):
|
|||||||
while self.hslots < self.loop:
|
while self.hslots < self.loop:
|
||||||
(klen, dlen) = unpack2Ints(self._read(8, self.hslots))
|
(klen, dlen) = unpack2Ints(self._read(8, self.hslots))
|
||||||
dpos = self.hslots + 8 + klen
|
dpos = self.hslots + 8 + klen
|
||||||
ret = (self._read(klen, self.hslots+8), self._read(dlen, dpos))
|
ret = (self._read(klen, self.hslots+8).decode(),
|
||||||
|
self._read(dlen, dpos).decode())
|
||||||
self.hslots = dpos + dlen
|
self.hslots = dpos + dlen
|
||||||
yield ret
|
yield ret
|
||||||
self.loop = 0
|
self.loop = 0
|
||||||
@ -221,7 +224,7 @@ class Reader(utils.IterableMap):
|
|||||||
(self.khash * 8) & 2047))
|
(self.khash * 8) & 2047))
|
||||||
if not self.hslots:
|
if not self.hslots:
|
||||||
return False
|
return False
|
||||||
self.kpos = self.hpos + (((self.khash / 256) % self.hslots) * 8)
|
self.kpos = self.hpos + (((self.khash // 256) % self.hslots) * 8)
|
||||||
while self.loop < self.hslots:
|
while self.loop < self.hslots:
|
||||||
(h, p) = unpack2Ints(self._read(8, self.kpos))
|
(h, p) = unpack2Ints(self._read(8, self.kpos))
|
||||||
if p == 0:
|
if p == 0:
|
||||||
@ -243,7 +246,7 @@ class Reader(utils.IterableMap):
|
|||||||
return self._findnext(key)
|
return self._findnext(key)
|
||||||
|
|
||||||
def _getCurrentData(self):
|
def _getCurrentData(self):
|
||||||
return self._read(self.dlen, self.dpos)
|
return self._read(self.dlen, self.dpos).decode()
|
||||||
|
|
||||||
def find(self, key, loop=0):
|
def find(self, key, loop=0):
|
||||||
if self._find(key, loop=loop):
|
if self._find(key, loop=loop):
|
||||||
@ -269,7 +272,7 @@ class Reader(utils.IterableMap):
|
|||||||
def __len__(self):
|
def __len__(self):
|
||||||
(start,) = struct.unpack('<i', self._read(4, 0))
|
(start,) = struct.unpack('<i', self._read(4, 0))
|
||||||
self.fd.seek(0, 2)
|
self.fd.seek(0, 2)
|
||||||
return ((self.fd.tell() - start) / 16)
|
return ((self.fd.tell() - start) // 16)
|
||||||
|
|
||||||
has_key = _find
|
has_key = _find
|
||||||
__contains__ = has_key
|
__contains__ = has_key
|
||||||
@ -292,7 +295,7 @@ class ReaderWriter(utils.IterableMap):
|
|||||||
|
|
||||||
def _openFiles(self):
|
def _openFiles(self):
|
||||||
self.cdb = Reader(self.filename)
|
self.cdb = Reader(self.filename)
|
||||||
self.journal = open(self.journalName, 'wb')
|
self.journal = open(self.journalName, 'w')
|
||||||
|
|
||||||
def _closeFiles(self):
|
def _closeFiles(self):
|
||||||
self.cdb.close()
|
self.cdb.close()
|
||||||
@ -312,7 +315,7 @@ class ReaderWriter(utils.IterableMap):
|
|||||||
removals = set()
|
removals = set()
|
||||||
adds = {}
|
adds = {}
|
||||||
try:
|
try:
|
||||||
fd = open(self.journalName, 'rb')
|
fd = open(self.journalName, 'r')
|
||||||
while 1:
|
while 1:
|
||||||
(initchar, key, value) = _readKeyValue(fd)
|
(initchar, key, value) = _readKeyValue(fd)
|
||||||
if initchar is None:
|
if initchar is None:
|
||||||
|
Loading…
Reference in New Issue
Block a user