[PATCH 08 of 10 py3] localrepo: ensure transaction id is fully bytes on py3
Augie Fackler
raf at durin42.com
Sun Mar 19 14:26:21 EDT 2017
# HG changeset patch
# User Augie Fackler <augie at google.com>
# Date 1489900139 14400
# Sun Mar 19 01:08:59 2017 -0400
# Node ID 9e6b585465b7ec033160326a4eb049329a2f83a9
# Parent d5e20f704fd722dbf8b0a011b3c9ab7437b4ac82
localrepo: ensure transaction id is fully bytes on py3
diff --git a/mercurial/localrepo.py b/mercurial/localrepo.py
--- a/mercurial/localrepo.py
+++ b/mercurial/localrepo.py
@@ -49,6 +49,7 @@ from . import (
peer,
phases,
pushkey,
+ pycompat,
repoview,
revset,
revsetlang,
@@ -1082,7 +1083,10 @@ class localrepository(object):
hint=_("run 'hg recover' to clean up transaction"))
idbase = "%.40f#%f" % (random.random(), time.time())
- txnid = 'TXN:' + hashlib.sha1(idbase).hexdigest()
+ ha = hashlib.sha1(idbase).hexdigest()
+ if pycompat.ispy3:
+ ha = ha.encode('latin1')
+ txnid = 'TXN:' + ha
self.hook('pretxnopen', throw=True, txnname=desc, txnid=txnid)
self._writejournal(desc)
More information about the Mercurial-devel
mailing list