[PATCH 09 of 41] basefilectx: move __repr__ from filectx

Sean Farley sean.michael.farley at gmail.com
Mon Aug 12 11:27:05 CDT 2013


# HG changeset patch
# User Sean Farley <sean.michael.farley at gmail.com>
# Date 1376279214 18000
#      Sun Aug 11 22:46:54 2013 -0500
# Node ID df530f9dbdc05968658a2ec706ecfc24ca79612e
# Parent  964844d64ef8fdb02cc5330f70a1acab158fdfb7
basefilectx: move __repr__ from filectx

We change the hardcoded 'filectx' to instead use type(self).__name__ so that objects that
inherit from basefilectx in the future will be able to use the same representation.

diff --git a/mercurial/context.py b/mercurial/context.py
--- a/mercurial/context.py
+++ b/mercurial/context.py
@@ -456,10 +456,13 @@
             return False
 
     def __str__(self):
         return "%s@%s" % (self.path(), short(self.node()))
 
+    def __repr__(self):
+        return "<%s %s>" % (type(self).__name__, str(self))
+
 class filectx(basefilectx):
     """A filecontext object makes access to data related to a particular
        filerevision convenient."""
     def __init__(self, repo, path, changeid=None, fileid=None,
                  filelog=None, changectx=None):
@@ -505,13 +508,10 @@
             # Linkrevs have several serious troubles with filtering that are
             # complicated to solve. Proper handling of the issue here should be
             # considered when solving linkrev issue are on the table.
             return changectx(self._repo.unfiltered(), self._changeid)
 
-    def __repr__(self):
-        return "<filectx %s>" % str(self)
-
     def __hash__(self):
         try:
             return hash((self._path, self._filenode))
         except AttributeError:
             return id(self)


More information about the Mercurial-devel mailing list