diff -r 4fbbdd9b04f1 -r 5779d096a696 mercurial/bundle2.py --- a/mercurial/bundle2.py Tue Sep 19 22:08:09 2017 +0200 +++ b/mercurial/bundle2.py Tue Sep 19 22:01:31 2017 +0200 @@ -179,8 +179,6 @@ _fpayloadsize = '>i' _fpartparamcount = '>BB' -_fphasesentry = struct.Struct('>i20s') - preferedchunksize = 4096 _parttypeforbidden = re.compile('[^a-zA-Z0-9_:-]') @@ -1480,11 +1478,8 @@ if opts.get('phases', False): headsbyphase = phases.subsetphaseheads(repo, outgoing.missing) - phasedata = [] - for phase in phases.allphases: - for head in headsbyphase[phase]: - phasedata.append(_fphasesentry.pack(phase, head)) - bundler.newpart('phase-heads', data=''.join(phasedata)) + phasedata = phases.binaryencode(headsbyphase) + bundler.newpart('phase-heads', data=phasedata) def addparttagsfnodescache(repo, bundler, outgoing): # we include the tags fnode cache for the bundle changeset @@ -1843,14 +1838,14 @@ def _readphaseheads(inpart): headsbyphase = [[] for i in phases.allphases] - entrysize = _fphasesentry.size + entrysize = phases._fphasesentry.size while True: entry = inpart.read(entrysize) if len(entry) < entrysize: if entry: raise error.Abort(_('bad phase-heads bundle part')) break - phase, node = _fphasesentry.unpack(entry) + phase, node = phases._fphasesentry.unpack(entry) headsbyphase[phase].append(node) return headsbyphase