##// END OF EJS Templates
filectx: add rename traversal for parents()
Matt Mackall -
r3122:da85145d default
parent child Browse files
Show More
@@ -1,126 +1,131 b''
1 1 # context.py - changeset and file context objects for mercurial
2 2 #
3 3 # Copyright 2006 Matt Mackall <mpm@selenic.com>
4 4 #
5 5 # This software may be used and distributed according to the terms
6 6 # of the GNU General Public License, incorporated herein by reference.
7 7
8 from node import *
9
8 10 class changectx(object):
9 11 """A changecontext object makes access to data related to a particular
10 12 changeset convenient."""
11 13 def __init__(self, repo, changeid):
12 14 """changeid is a revision number, node, or tag"""
13 15 self._repo = repo
14 16
15 17 self._node = self._repo.lookup(changeid)
16 18 self._rev = self._repo.changelog.rev(self._node)
17 19
18 20 def changeset(self):
19 21 try:
20 22 return self._changeset
21 23 except AttributeError:
22 24 self._changeset = self._repo.changelog.read(self.node())
23 25 return self._changeset
24 26
25 27 def manifest(self):
26 28 try:
27 29 return self._manifest
28 30 except AttributeError:
29 31 self._manifest = self._repo.manifest.read(self.changeset()[0])
30 32 return self._manifest
31 33
32 34 def rev(self): return self._rev
33 35 def node(self): return self._node
34 36 def user(self): return self.changeset()[1]
35 37 def date(self): return self.changeset()[2]
36 def changedfiles(self): return self.changeset()[3]
38 def files(self): return self.changeset()[3]
37 39 def description(self): return self.changeset()[4]
38 40
39 41 def parents(self):
40 42 """return contexts for each parent changeset"""
41 43 p = self._repo.changelog.parents(self._node)
42 44 return [ changectx(self._repo, x) for x in p ]
43 45
44 46 def children(self):
45 47 """return contexts for each child changeset"""
46 48 c = self._repo.changelog.children(self._node)
47 49 return [ changectx(self._repo, x) for x in c ]
48 50
49 51 def filenode(self, path):
50 52 node, flag = self._repo.manifest.find(self.changeset()[0], path)
51 53 return node
52 54
53 55 def filectx(self, path, fileid=None):
54 56 """get a file context from this changeset"""
55 57 if fileid is None:
56 58 fileid = self.filenode(path)
57 59 return filectx(self._repo, path, fileid=fileid)
58 60
59 61 def filectxs(self):
60 62 """generate a file context for each file in this changeset's
61 63 manifest"""
62 64 mf = self.manifest()
63 65 m = mf.keys()
64 66 m.sort()
65 67 for f in m:
66 68 yield self.filectx(f, fileid=mf[f])
67 69
68 70 class filectx(object):
69 71 """A filecontext object makes access to data related to a particular
70 72 filerevision convenient."""
71 73 def __init__(self, repo, path, changeid=None, fileid=None):
72 74 """changeid can be a changeset revision, node, or tag.
73 75 fileid can be a file revision or node."""
74 76 self._repo = repo
75 77 self._path = path
76 78
77 79 assert changeid or fileid
78 80
79 81 if not fileid:
80 82 # if given a changeset id, go ahead and look up the file
81 83 self._changeid = changeid
82 84 self._changectx = self.changectx()
83 85 self._filelog = self._repo.file(self._path)
84 86 self._filenode = self._changectx.filenode(self._path)
85 87 else:
86 88 # else be lazy
87 89 self._filelog = self._repo.file(self._path)
88 90 self._filenode = self._filelog.lookup(fileid)
89 91 self._changeid = self._filelog.linkrev(self._filenode)
90 92 self._filerev = self._filelog.rev(self._filenode)
91 93
92 94 def changectx(self):
93 95 try:
94 96 return self._changectx
95 97 except AttributeError:
96 98 self._changectx = changectx(self._repo, self._changeid)
97 99 return self._changectx
98 100
99 101 def filerev(self): return self._filerev
100 102 def filenode(self): return self._filenode
101 103 def filelog(self): return self._filelog
102 104
103 105 def rev(self): return self.changectx().rev()
104 106 def node(self): return self.changectx().node()
105 107 def user(self): return self.changectx().user()
106 108 def date(self): return self.changectx().date()
107 109 def files(self): return self.changectx().files()
108 110 def description(self): return self.changectx().description()
109 111 def manifest(self): return self.changectx().manifest()
110 112
111 113 def data(self): return self._filelog.read(self._filenode)
112 114 def metadata(self): return self._filelog.readmeta(self._filenode)
113 115 def renamed(self): return self._filelog.renamed(self._filenode)
116 def path(self): return self._path
114 117
115 118 def parents(self):
116 # need to fix for renames
117 p = self._filelog.parents(self._filenode)
118 return [ filectx(self._repo, self._path, fileid=x) for x in p ]
119 p = [ (self._path, n) for n in self._filelog.parents(self._filenode) ]
120 r = self.renamed()
121 if r:
122 p[0] = r
123 return [ filectx(self._repo, p, fileid=n) for p,n in p if n != nullid ]
119 124
120 125 def children(self):
121 126 # hard for renames
122 127 c = self._filelog.children(self._filenode)
123 128 return [ filectx(self._repo, self._path, fileid=x) for x in c ]
124 129
125 130 def annotate(self):
126 131 return self._filelog.annotate(self._filenode)
General Comments 0
You need to be logged in to leave comments. Login now