mirror of
https://github.com/derrod/legendary.git
synced 2025-01-08 13:55:28 +00:00
[models] Calculate group_num based on GUID
This commit is contained in:
parent
17ea65d2da
commit
8328a8ebaa
|
@ -400,11 +400,12 @@ class ChunkInfo:
|
||||||
self.guid = None
|
self.guid = None
|
||||||
self.hash = 0
|
self.hash = 0
|
||||||
self.sha_hash = b''
|
self.sha_hash = b''
|
||||||
self.group_num = 0
|
|
||||||
self.window_size = 0
|
self.window_size = 0
|
||||||
self.file_size = 0
|
self.file_size = 0
|
||||||
|
|
||||||
self._manifest_version = manifest_version
|
self._manifest_version = manifest_version
|
||||||
# caches for things that are "expensive" to compute
|
# caches for things that are "expensive" to compute
|
||||||
|
self._group_num = None
|
||||||
self._guid_str = None
|
self._guid_str = None
|
||||||
self._guid_num = None
|
self._guid_num = None
|
||||||
|
|
||||||
|
@ -426,17 +427,28 @@ class ChunkInfo:
|
||||||
self._guid_num = self.guid[3] + (self.guid[2] << 32) + (self.guid[1] << 64) + (self.guid[0] << 96)
|
self._guid_num = self.guid[3] + (self.guid[2] << 32) + (self.guid[1] << 64) + (self.guid[0] << 96)
|
||||||
return self._guid_num
|
return self._guid_num
|
||||||
|
|
||||||
|
@property
|
||||||
|
def group_num(self):
|
||||||
|
if self._guid_num is not None:
|
||||||
|
return self._group_num
|
||||||
|
|
||||||
|
self._group_num = (zlib.crc32(
|
||||||
|
struct.pack('<I', self.guid[0]) +
|
||||||
|
struct.pack('<I', self.guid[1]) +
|
||||||
|
struct.pack('<I', self.guid[2]) +
|
||||||
|
struct.pack('<I', self.guid[3])
|
||||||
|
) & 0xffffffff) % 100
|
||||||
|
return self._group_num
|
||||||
|
|
||||||
|
@group_num.setter
|
||||||
|
def group_num(self, value):
|
||||||
|
self._group_num = value
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def path(self):
|
def path(self):
|
||||||
return '{}/{:02d}/{:016X}_{}.chunk'.format(
|
return '{}/{:02d}/{:016X}_{}.chunk'.format(
|
||||||
get_chunk_dir(self._manifest_version),
|
get_chunk_dir(self._manifest_version), self.group_num,
|
||||||
# the result of this seems to always match the group number, but this is the "correct way"
|
self.hash, ''.join('{:08X}'.format(g) for g in self.guid))
|
||||||
(zlib.crc32(struct.pack('<I', self.guid[0]) +
|
|
||||||
struct.pack('<I', self.guid[1]) +
|
|
||||||
struct.pack('<I', self.guid[2]) +
|
|
||||||
struct.pack('<I', self.guid[3])) & 0xffffffff) % 100,
|
|
||||||
self.hash, ''.join('{:08X}'.format(g) for g in self.guid)
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class FML:
|
class FML:
|
||||||
|
|
Loading…
Reference in a new issue