Mercurial > jhg
comparison src/org/tmatesoft/hg/repo/HgBranches.java @ 657:6334b0267103
ParentChildMap can supply RevisionMap. Refactor ArrayHelper to keep most of sorted/reverse index magic inside
author | Artem Tikhomirov <tikhomirov.artem@gmail.com> |
---|---|
date | Thu, 04 Jul 2013 20:27:45 +0200 |
parents | a937e63b6e02 |
children | af5223b86dd3 |
comparison
equal
deleted
inserted
replaced
656:a937e63b6e02 | 657:6334b0267103 |
---|---|
44 import org.tmatesoft.hg.internal.Internals; | 44 import org.tmatesoft.hg.internal.Internals; |
45 import org.tmatesoft.hg.repo.HgChangelog.RawChangeset; | 45 import org.tmatesoft.hg.repo.HgChangelog.RawChangeset; |
46 import org.tmatesoft.hg.util.ProgressSupport; | 46 import org.tmatesoft.hg.util.ProgressSupport; |
47 | 47 |
48 /** | 48 /** |
49 * | 49 * Access information about branches in the repository |
50 * | |
50 * @author Artem Tikhomirov | 51 * @author Artem Tikhomirov |
51 * @author TMate Software Ltd. | 52 * @author TMate Software Ltd. |
52 */ | 53 */ |
53 public class HgBranches { | 54 public class HgBranches { |
54 | 55 |
123 } | 124 } |
124 | 125 |
125 void collect(final ProgressSupport ps) throws HgRuntimeException { | 126 void collect(final ProgressSupport ps) throws HgRuntimeException { |
126 branches.clear(); | 127 branches.clear(); |
127 final HgRepository repo = internalRepo.getRepo(); | 128 final HgRepository repo = internalRepo.getRepo(); |
128 ps.start(1 + repo.getChangelog().getRevisionCount() * 2); | 129 final HgChangelog clog = repo.getChangelog(); |
130 final HgRevisionMap<HgChangelog> rmap; | |
131 ps.start(1 + clog.getRevisionCount() * 2); | |
129 // | 132 // |
130 int lastCached = readCache(); | 133 int lastCached = readCache(); |
131 isCacheActual = lastCached == repo.getChangelog().getLastRevision(); | 134 isCacheActual = lastCached == clog.getLastRevision(); |
132 if (!isCacheActual) { | 135 if (!isCacheActual) { |
133 final HgParentChildMap<HgChangelog> pw = new HgParentChildMap<HgChangelog>(repo.getChangelog()); | 136 // XXX need a way to share HgParentChildMap<HgChangelog> |
137 final HgParentChildMap<HgChangelog> pw = new HgParentChildMap<HgChangelog>(clog); | |
134 pw.init(); | 138 pw.init(); |
135 ps.worked(repo.getChangelog().getRevisionCount()); | 139 ps.worked(clog.getRevisionCount()); |
136 // | 140 // |
137 // first revision branch found at | 141 // first revision branch found at |
138 final HashMap<String, Nodeid> branchStart = new HashMap<String, Nodeid>(); | 142 final HashMap<String, Nodeid> branchStart = new HashMap<String, Nodeid>(); |
139 // revisions from the branch that have no children at all | 143 // revisions from the branch that have no children at all |
140 final HashMap<String, List<Nodeid>> branchHeads = new HashMap<String, List<Nodeid>>(); | 144 final HashMap<String, List<Nodeid>> branchHeads = new HashMap<String, List<Nodeid>>(); |
165 ps.worked(1); | 169 ps.worked(1); |
166 } | 170 } |
167 }; | 171 }; |
168 // XXX alternatively may iterate with pw.all().subList(lastCached) | 172 // XXX alternatively may iterate with pw.all().subList(lastCached) |
169 // but need an effective way to find out branch of particular changeset | 173 // but need an effective way to find out branch of particular changeset |
170 repo.getChangelog().range(lastCached == -1 ? 0 : lastCached+1, HgRepository.TIP, insp); | 174 clog.range(lastCached == -1 ? 0 : lastCached+1, HgRepository.TIP, insp); |
171 // | 175 // |
172 // build BranchInfo, based on found and cached | 176 // build BranchInfo, based on found and cached |
173 for (String bn : branchStart.keySet()) { | 177 for (String bn : branchStart.keySet()) { |
174 BranchInfo bi = branches.get(bn); | 178 BranchInfo bi = branches.get(bn); |
175 if (bi != null) { | 179 if (bi != null) { |
190 Nodeid[] heads = branchHeads.get(bn).toArray(new Nodeid[0]); | 194 Nodeid[] heads = branchHeads.get(bn).toArray(new Nodeid[0]); |
191 bi = new BranchInfo(bn, branchStart.get(bn), heads); | 195 bi = new BranchInfo(bn, branchStart.get(bn), heads); |
192 } | 196 } |
193 branches.put(bn, bi); | 197 branches.put(bn, bi); |
194 } | 198 } |
195 } // !cacheActual | 199 rmap = pw.getRevisionMap(); |
196 final HgChangelog clog = repo.getChangelog(); | 200 } else { // !cacheActual |
197 /// FIXME use HgParentChildMap if available (need to decide how to get HgRevisionMap and HgParentChildMap to a common denominator) | 201 rmap = new HgRevisionMap<HgChangelog>(clog).init(); |
198 final HgRevisionMap<HgChangelog> rmap = new HgRevisionMap<HgChangelog>(clog).init(); | 202 } |
199 for (BranchInfo bi : branches.values()) { | 203 for (BranchInfo bi : branches.values()) { |
200 bi.validate(clog, rmap); | 204 bi.validate(clog, rmap); |
201 } | 205 } |
202 repoChangeTracker.touch(); | 206 repoChangeTracker.touch(); |
203 ps.done(); | 207 ps.done(); |