[PATCH 6 of 8 v2] convert: hg use absolute_import
timeless
timeless at mozdev.org
Wed Mar 2 11:09:48 EST 2016
# HG changeset patch
# User timeless <timeless at mozdev.org>
# Date 1456932409 0
# Wed Mar 02 15:26:49 2016 +0000
# Node ID 3582004ebd6767523e2d8a3f07dcdfb24a46406e
# Parent 441c7030734e10ada37c99049917c8f1dd3050a5
convert: hg use absolute_import
diff --git a/hgext/convert/hg.py b/hgext/convert/hg.py
--- a/hgext/convert/hg.py
+++ b/hgext/convert/hg.py
@@ -16,24 +16,36 @@
# identifier to be stored in the converted revision. This will cause
# the converted revision to have a different identity than the
# source.
+from __future__ import absolute_import
+import cStringIO
+import os
+import re
+import time
-import os, time, cStringIO
+from mercurial import (
+ bookmarks,
+ context,
+ error,
+ exchange,
+ hg,
+ lock as lockmod,
+ merge as mergemod,
+ node,
+ phases,
+ scmutil,
+ util,
+)
from mercurial.i18n import _
-from mercurial.node import bin, hex, nullid
-from mercurial import hg, util, context, bookmarks, error, scmutil, exchange
-from mercurial import phases
-from mercurial import lock as lockmod
-from mercurial import merge as mergemod
+from . import common
+mapfile = common.mapfile
+NoRepo = common.NoRepo
-from common import NoRepo, commit, converter_source, converter_sink, mapfile
-
-import re
sha1re = re.compile(r'\b[0-9a-f]{12,40}\b')
-class mercurial_sink(converter_sink):
+class mercurial_sink(common.converter_sink):
def __init__(self, ui, path):
- converter_sink.__init__(self, ui, path)
+ common.converter_sink.__init__(self, ui, path)
self.branchnames = ui.configbool('convert', 'hg.usebranchnames', True)
self.clonebranches = ui.configbool('convert', 'hg.clonebranches', False)
self.tagsbranch = ui.config('convert', 'hg.tagsbranch', 'default')
@@ -132,7 +144,7 @@
continue
revid = revmap.get(source.lookuprev(s[0]))
if not revid:
- if s[0] == hex(nullid):
+ if s[0] == node.nullhex:
revid = s[0]
else:
continue
@@ -148,7 +160,7 @@
revid = s[0]
subpath = s[1]
- if revid != hex(nullid):
+ if revid != node.nullhex:
revmap = self.subrevmaps.get(subpath)
if revmap is None:
revmap = mapfile(self.ui,
@@ -250,13 +262,13 @@
parents = pl
nparents = len(parents)
if self.filemapmode and nparents == 1:
- m1node = self.repo.changelog.read(bin(parents[0]))[0]
+ m1node = self.repo.changelog.read(node.bin(parents[0]))[0]
parent = parents[0]
if len(parents) < 2:
- parents.append(nullid)
+ parents.append(node.nullid)
if len(parents) < 2:
- parents.append(nullid)
+ parents.append(node.nullid)
p2 = parents.pop(0)
text = commit.desc
@@ -276,19 +288,19 @@
for label in ('source', 'transplant_source', 'rebase_source',
'intermediate-source'):
- node = extra.get(label)
+ n = extra.get(label)
- if node is None:
+ if n is None:
continue
# Only transplant stores its reference in binary
if label == 'transplant_source':
- node = hex(node)
+ n = node.hex(n)
- newrev = revmap.get(node)
+ newrev = revmap.get(n)
if newrev is not None:
if label == 'transplant_source':
- newrev = bin(newrev)
+ newrev = node.bin(newrev)
extra[label] = newrev
@@ -302,7 +314,7 @@
p2 = parents.pop(0)
p1ctx = self.repo[p1]
p2ctx = None
- if p2 != nullid:
+ if p2 != node.nullid:
p2ctx = self.repo[p2]
fileset = set(files)
if full:
@@ -324,23 +336,23 @@
phases.phasenames[commit.phase], 'convert')
with self.repo.transaction("convert") as tr:
- node = hex(self.repo.commitctx(ctx))
+ n = node.hex(self.repo.commitctx(ctx))
# If the node value has changed, but the phase is lower than
# draft, set it back to draft since it hasn't been exposed
# anywhere.
- if commit.rev != node:
- ctx = self.repo[node]
+ if commit.rev != n:
+ ctx = self.repo[n]
if ctx.phase() < phases.draft:
phases.retractboundary(self.repo, tr, phases.draft,
[ctx.node()])
text = "(octopus merge fixup)\n"
- p2 = node
+ p2 = n
if self.filemapmode and nparents == 1:
man = self.repo.manifest
- mnode = self.repo.changelog.read(bin(p2))[0]
+ mnode = self.repo.changelog.read(node.bin(p2))[0]
closed = 'close' in commit.extra
if not closed and not man.cmp(m1node, man.revision(mnode)):
self.ui.status(_("filtering out empty revision\n"))
@@ -354,7 +366,7 @@
tagparent = parentctx.node()
except error.RepoError:
parentctx = None
- tagparent = nullid
+ tagparent = node.nullid
oldlines = set()
for branch, heads in self.repo.branchmap().iteritems():
@@ -396,8 +408,8 @@
ctx = context.memctx(self.repo, (tagparent, None), "update tags",
[".hgtags"], getfilectx, "convert-repo", date,
extra)
- node = self.repo.commitctx(ctx)
- return hex(node), hex(tagparent)
+ n = self.repo.commitctx(ctx)
+ return node.hex(n), node.hex(tagparent)
def setfilemapmode(self, active):
self.filemapmode = active
@@ -413,7 +425,7 @@
self.ui.status(_("updating bookmarks\n"))
destmarks = self.repo._bookmarks
for bookmark in updatedbookmark:
- destmarks[bookmark] = bin(updatedbookmark[bookmark])
+ destmarks[bookmark] = node.bin(updatedbookmark[bookmark])
destmarks.recordchange(tr)
tr.close()
finally:
@@ -430,9 +442,9 @@
'are not implemented)') % rev)
return rev in self.repo
-class mercurial_source(converter_source):
+class mercurial_source(common.converter_source):
def __init__(self, ui, path, revs=None):
- converter_source.__init__(self, ui, path, revs)
+ common.converter_source.__init__(self, ui, path, revs)
self.ignoreerrors = ui.configbool('convert', 'hg.ignoreerrors', False)
self.ignored = set()
self.saverev = ui.configbool('convert', 'hg.saverev', False)
@@ -493,7 +505,7 @@
return [p for p in ctx.parents() if p and self.keep(p.node())]
def getheads(self):
- return [hex(h) for h in self._heads if self.keep(h)]
+ return [node.hex(h) for h in self._heads if self.keep(h)]
def getfile(self, name, rev):
try:
@@ -572,19 +584,24 @@
parents = [p.hex() for p in self._parents(ctx)]
crev = rev
- return commit(author=ctx.user(),
- date=util.datestr(ctx.date(), '%Y-%m-%d %H:%M:%S %1%2'),
- desc=ctx.description(), rev=crev, parents=parents,
- branch=ctx.branch(), extra=ctx.extra(),
- sortkey=ctx.rev(), saverev=self.saverev,
- phase=ctx.phase())
+ return common.commit(author=ctx.user(),
+ date=util.datestr(ctx.date(),
+ '%Y-%m-%d %H:%M:%S %1%2'),
+ desc=ctx.description(),
+ rev=crev,
+ parents=parents,
+ branch=ctx.branch(),
+ extra=ctx.extra(),
+ sortkey=ctx.rev(),
+ saverev=self.saverev,
+ phase=ctx.phase())
def gettags(self):
# This will get written to .hgtags, filter non global tags out.
tags = [t for t in self.repo.tagslist()
if self.repo.tagtype(t[0]) == 'global']
- return dict([(name, hex(node)) for name, node in tags
- if self.keep(node)])
+ return dict([(name, node.hex(n)) for name, n in tags
+ if self.keep(n)])
def getchangedfiles(self, rev, i):
ctx = self._changectx(rev)
@@ -622,7 +639,7 @@
def lookuprev(self, rev):
try:
- return hex(self.repo.lookup(rev))
+ return node.hex(self.repo.lookup(rev))
except (error.RepoError, error.LookupError):
return None
diff --git a/tests/test-check-py3-compat.t b/tests/test-check-py3-compat.t
--- a/tests/test-check-py3-compat.t
+++ b/tests/test-check-py3-compat.t
@@ -38,7 +38,6 @@
hgext/convert/common.py not using absolute_import
hgext/convert/convcmd.py not using absolute_import
hgext/convert/cvs.py not using absolute_import
- hgext/convert/hg.py not using absolute_import
hgext/convert/monotone.py not using absolute_import
hgext/convert/p4.py not using absolute_import
hgext/convert/subversion.py not using absolute_import
More information about the Mercurial-devel
mailing list