9 progress_callback = None
10 max_pack_size = 1000*1000*1000 # larger packs will slow down pruning
11 max_pack_objects = 200*1000 # cache memory usage is about 83 bytes per object
21 self.data = buffer(self.data, self.start) + s
24 def peek(self, count):
25 return buffer(self.data, self.start, count)
31 v = buffer(self.data, self.start, count)
36 return len(self.data) - self.start
40 b = buf.peek(buf.used())
41 (ofs, bits) = _hashsplit.splitbuf(b)
44 return (buffer(b, 0, ofs), bits)
57 def hashsplit_iter(files):
58 assert(BLOB_HWM > BLOB_MAX)
62 (blob, bits) = splitbuf(buf)
66 if buf.used() >= BLOB_MAX:
68 yield (buf.get(buf.used()), 0)
69 while buf.used() < BLOB_HWM:
74 yield (buf.get(buf.used()), 0)
80 def _split_to_blobs(w, files):
82 for (blob, bits) in hashsplit_iter(files):
83 sha = w.new_blob(blob)
84 total_split += len(blob)
85 if w.outbytes >= max_pack_size or w.count >= max_pack_objects:
88 progress_callback(len(blob))
89 yield (sha, len(blob), bits)
95 for (mode, sha, size) in l:
96 shalist.append((mode, '%016x' % ofs, sha))
99 return (shalist, total)
102 def _squish(w, stacks, n):
104 while i<n or len(stacks[i]) > MAX_PER_TREE:
105 while len(stacks) <= i+1:
107 if len(stacks[i]) == 1:
108 stacks[i+1] += stacks[i]
110 (shalist, size) = _make_shalist(stacks[i])
111 tree = w.new_tree(shalist)
112 stacks[i+1].append(('40000', tree, size))
117 def split_to_shalist(w, files):
118 sl = _split_to_blobs(w, files)
121 for (sha,size,bits) in sl:
122 shal.append(('100644', sha, size))
123 return _make_shalist(shal)[0]
125 base_bits = _hashsplit.blobbits()
126 fanout_bits = int(math.log(fanout, 2))
128 assert(n >= base_bits)
129 return (n - base_bits)/fanout_bits
131 for (sha,size,bits) in sl:
133 stacks[0].append(('100644', sha, size))
135 _squish(w, stacks, bits_to_idx(bits))
136 #log('stacks: %r\n' % [len(i) for i in stacks])
137 _squish(w, stacks, len(stacks)-1)
138 #log('stacks: %r\n' % [len(i) for i in stacks])
139 return _make_shalist(stacks[-1])[0]
142 def split_to_blob_or_tree(w, files):
143 shalist = list(split_to_shalist(w, files))
144 if len(shalist) == 1:
145 return (shalist[0][0], shalist[0][2])
146 elif len(shalist) == 0:
147 return ('100644', w.new_blob(''))
149 return ('40000', w.new_tree(shalist))