Mercurial > hg4j
annotate src/org/tmatesoft/hg/repo/HgBlameFacility.java @ 556:e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
| author | Artem Tikhomirov <tikhomirov.artem@gmail.com> | 
|---|---|
| date | Fri, 22 Feb 2013 20:21:24 +0100 | 
| parents | src/org/tmatesoft/hg/internal/AnnotateFacility.java@e623aa2ca526 | 
| children | b9e5ac26dd83 | 
| rev | line source | 
|---|---|
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 1 /* | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 2 * Copyright (c) 2013 TMate Software Ltd | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 3 * | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 4 * This program is free software; you can redistribute it and/or modify | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 5 * it under the terms of the GNU General Public License as published by | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 6 * the Free Software Foundation; version 2 of the License. | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 7 * | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 8 * This program is distributed in the hope that it will be useful, | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 9 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 11 * GNU General Public License for more details. | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 12 * | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 13 * For information on how to redistribute this software under | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 14 * the terms of a license other than GNU General Public License | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 15 * contact TMate Software at support@hg4j.com | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 16 */ | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 17 package org.tmatesoft.hg.repo; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 18 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 19 import static org.tmatesoft.hg.repo.HgRepository.NO_REVISION; | 
| 548 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 20 import static org.tmatesoft.hg.repo.HgRepository.TIP; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 21 | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 22 import java.util.BitSet; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 23 import java.util.LinkedList; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 24 import java.util.ListIterator; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 25 | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 26 import org.tmatesoft.hg.core.HgIterateDirection; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 27 import org.tmatesoft.hg.core.Nodeid; | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 28 import org.tmatesoft.hg.internal.ByteArrayChannel; | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 29 import org.tmatesoft.hg.internal.Callback; | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 30 import org.tmatesoft.hg.internal.DiffHelper; | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 31 import org.tmatesoft.hg.internal.Experimental; | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 32 import org.tmatesoft.hg.internal.IntMap; | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 33 import org.tmatesoft.hg.internal.IntVector; | 
| 551 
4ea0351ca878
Better (precise) name for diff facility, tests
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
549diff
changeset | 34 import org.tmatesoft.hg.internal.DiffHelper.LineSequence; | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 35 import org.tmatesoft.hg.internal.DiffHelper.LineSequence.ByteChain; | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 36 import org.tmatesoft.hg.repo.HgBlameFacility.RevisionDescriptor.Recipient; | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 37 import org.tmatesoft.hg.util.Adaptable; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 38 import org.tmatesoft.hg.util.CancelledException; | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 39 import org.tmatesoft.hg.util.Pair; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 40 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 41 /** | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 42 * Facility with diff/annotate functionality. | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 43 * | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 44 * @author Artem Tikhomirov | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 45 * @author TMate Software Ltd. | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 46 */ | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 47 @Experimental(reason="Unstable API") | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 48 public final class HgBlameFacility { | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 49 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 50 /** | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 51 * mimic 'hg diff -r clogRevIndex1 -r clogRevIndex2' | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 52 */ | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 53 public void diff(HgDataFile df, int clogRevIndex1, int clogRevIndex2, BlockInspector insp) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 54 int fileRevIndex1 = fileRevIndex(df, clogRevIndex1); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 55 int fileRevIndex2 = fileRevIndex(df, clogRevIndex2); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 56 FileLinesCache fileInfoCache = new FileLinesCache(df, 5); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 57 LineSequence c1 = fileInfoCache.lines(fileRevIndex1); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 58 LineSequence c2 = fileInfoCache.lines(fileRevIndex2); | 
| 551 
4ea0351ca878
Better (precise) name for diff facility, tests
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
549diff
changeset | 59 DiffHelper<LineSequence> pg = new DiffHelper<LineSequence>(); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 60 pg.init(c1, c2); | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 61 pg.findMatchingBlocks(new BlameBlockInspector(fileRevIndex2, insp, clogRevIndex1, clogRevIndex2)); | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 62 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 63 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 64 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 65 * Walk file history up to revision at given changeset and report changes for each revision | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 66 */ | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 67 public void annotate(HgDataFile df, int changelogRevisionIndex, BlockInspector insp, HgIterateDirection iterateOrder) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 68 if (!df.exists()) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 69 return; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 70 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 71 // Note, changelogRevisionIndex may be TIP, while #implAnnotateChange doesn't tolerate constants | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 72 // | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 73 // XXX df.indexWalk(0, fileRevIndex, ) might be more effective | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 74 int fileRevIndex = fileRevIndex(df, changelogRevisionIndex); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 75 int[] fileRevParents = new int[2]; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 76 IntVector fileParentRevs = new IntVector((fileRevIndex+1) * 2, 0); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 77 fileParentRevs.add(NO_REVISION, NO_REVISION); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 78 for (int i = 1; i <= fileRevIndex; i++) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 79 df.parents(i, fileRevParents, null, null); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 80 fileParentRevs.add(fileRevParents[0], fileRevParents[1]); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 81 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 82 // collect file revisions to visit, from newest to oldest | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 83 IntVector fileRevsToVisit = new IntVector(fileRevIndex + 1, 0); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 84 LinkedList<Integer> queue = new LinkedList<Integer>(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 85 BitSet seen = new BitSet(fileRevIndex + 1); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 86 queue.add(fileRevIndex); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 87 do { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 88 int x = queue.removeFirst(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 89 if (seen.get(x)) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 90 continue; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 91 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 92 seen.set(x); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 93 fileRevsToVisit.add(x); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 94 int p1 = fileParentRevs.get(2*x); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 95 int p2 = fileParentRevs.get(2*x + 1); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 96 if (p1 != NO_REVISION) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 97 queue.addLast(p1); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 98 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 99 if (p2 != NO_REVISION) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 100 queue.addLast(p2); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 101 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 102 } while (!queue.isEmpty()); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 103 FileLinesCache fileInfoCache = new FileLinesCache(df, 10); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 104 // fileRevsToVisit now { r10, r7, r6, r5, r0 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 105 // and we'll iterate it from behind, e.g. old to new unless reversed | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 106 if (iterateOrder == HgIterateDirection.NewToOld) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 107 fileRevsToVisit.reverse(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 108 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 109 for (int i = fileRevsToVisit.size() - 1; i >= 0; i--) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 110 int fri = fileRevsToVisit.get(i); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 111 int clogRevIndex = df.getChangesetRevisionIndex(fri); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 112 fileRevParents[0] = fileParentRevs.get(fri * 2); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 113 fileRevParents[1] = fileParentRevs.get(fri * 2 + 1); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 114 implAnnotateChange(fileInfoCache, clogRevIndex, fri, fileRevParents, insp); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 115 } | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 116 } | 
| 548 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 117 | 
| 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 118 /** | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 119 * Annotates changes of the file against its parent(s). | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 120 * Unlike {@link #annotate(HgDataFile, int, BlockInspector, HgIterateDirection)}, doesn't | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 121 * walk file history, looks at the specified revision only. Handles both parents (if merge revision). | 
| 548 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 122 */ | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 123 public void annotateSingleRevision(HgDataFile df, int changelogRevisionIndex, BlockInspector insp) { | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 124 // TODO detect if file is text/binary (e.g. looking for chars < ' ' and not \t\r\n\f | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 125 int fileRevIndex = fileRevIndex(df, changelogRevisionIndex); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 126 int[] fileRevParents = new int[2]; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 127 df.parents(fileRevIndex, fileRevParents, null, null); | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 128 if (changelogRevisionIndex == TIP) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 129 changelogRevisionIndex = df.getChangesetRevisionIndex(fileRevIndex); | 
| 548 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 130 } | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 131 implAnnotateChange(new FileLinesCache(df, 5), changelogRevisionIndex, fileRevIndex, fileRevParents, insp); | 
| 548 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 132 } | 
| 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 133 | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 134 private void implAnnotateChange(FileLinesCache fl, int csetRevIndex, int fileRevIndex, int[] fileParentRevs, BlockInspector insp) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 135 final LineSequence fileRevLines = fl.lines(fileRevIndex); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 136 if (fileParentRevs[0] != NO_REVISION && fileParentRevs[1] != NO_REVISION) { | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 137 LineSequence p1Lines = fl.lines(fileParentRevs[0]); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 138 LineSequence p2Lines = fl.lines(fileParentRevs[1]); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 139 int p1ClogIndex = fl.getChangesetRevisionIndex(fileParentRevs[0]); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 140 int p2ClogIndex = fl.getChangesetRevisionIndex(fileParentRevs[1]); | 
| 551 
4ea0351ca878
Better (precise) name for diff facility, tests
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
549diff
changeset | 141 DiffHelper<LineSequence> pg = new DiffHelper<LineSequence>(); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 142 pg.init(p2Lines, fileRevLines); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 143 EqualBlocksCollector p2MergeCommon = new EqualBlocksCollector(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 144 pg.findMatchingBlocks(p2MergeCommon); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 145 // | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 146 pg.init(p1Lines); | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 147 BlameBlockInspector bbi = new BlameBlockInspector(fileRevIndex, insp, p1ClogIndex, csetRevIndex); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 148 bbi.setMergeParent2(p2MergeCommon, p2ClogIndex); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 149 pg.findMatchingBlocks(bbi); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 150 } else if (fileParentRevs[0] == fileParentRevs[1]) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 151 // may be equal iff both are unset | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 152 assert fileParentRevs[0] == NO_REVISION; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 153 // everything added | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 154 BlameBlockInspector bbi = new BlameBlockInspector(fileRevIndex, insp, NO_REVISION, csetRevIndex); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 155 bbi.begin(LineSequence.newlines(new byte[0]), fileRevLines); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 156 bbi.match(0, fileRevLines.chunkCount()-1, 0); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 157 bbi.end(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 158 } else { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 159 int soleParent = fileParentRevs[0] == NO_REVISION ? fileParentRevs[1] : fileParentRevs[0]; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 160 assert soleParent != NO_REVISION; | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 161 LineSequence parentLines = fl.lines(soleParent); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 162 | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 163 int parentChangesetRevIndex = fl.getChangesetRevisionIndex(soleParent); | 
| 551 
4ea0351ca878
Better (precise) name for diff facility, tests
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
549diff
changeset | 164 DiffHelper<LineSequence> pg = new DiffHelper<LineSequence>(); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 165 pg.init(parentLines, fileRevLines); | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 166 pg.findMatchingBlocks(new BlameBlockInspector(fileRevIndex, insp, parentChangesetRevIndex, csetRevIndex)); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 167 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 168 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 169 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 170 private static int fileRevIndex(HgDataFile df, int csetRevIndex) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 171 Nodeid fileRev = df.getRepo().getManifest().getFileRevision(csetRevIndex, df.getPath()); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 172 return df.getRevisionIndex(fileRev); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 173 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 174 | 
| 552 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 175 private static class FileLinesCache { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 176 private final HgDataFile df; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 177 private final LinkedList<Pair<Integer, LineSequence>> lruCache; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 178 private final int limit; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 179 private IntMap<Integer> fileToClogIndexMap = new IntMap<Integer>(20); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 180 | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 181 public FileLinesCache(HgDataFile file, int lruLimit) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 182 df = file; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 183 limit = lruLimit; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 184 lruCache = new LinkedList<Pair<Integer, LineSequence>>(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 185 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 186 | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 187 public int getChangesetRevisionIndex(int fileRevIndex) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 188 Integer cached = fileToClogIndexMap.get(fileRevIndex); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 189 if (cached == null) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 190 cached = df.getChangesetRevisionIndex(fileRevIndex); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 191 fileToClogIndexMap.put(fileRevIndex, cached); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 192 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 193 return cached.intValue(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 194 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 195 | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 196 public LineSequence lines(int fileRevIndex) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 197 Pair<Integer, LineSequence> cached = checkCache(fileRevIndex); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 198 if (cached != null) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 199 return cached.second(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 200 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 201 try { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 202 ByteArrayChannel c; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 203 df.content(fileRevIndex, c = new ByteArrayChannel()); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 204 LineSequence rv = LineSequence.newlines(c.toArray()); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 205 lruCache.addFirst(new Pair<Integer, LineSequence>(fileRevIndex, rv)); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 206 if (lruCache.size() > limit) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 207 lruCache.removeLast(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 208 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 209 return rv; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 210 } catch (CancelledException ex) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 211 // TODO likely it was bad idea to throw cancelled exception from content() | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 212 // deprecate and provide alternative? | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 213 HgInvalidStateException ise = new HgInvalidStateException("ByteArrayChannel never throws CancelledException"); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 214 ise.initCause(ex); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 215 throw ise; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 216 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 217 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 218 | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 219 private Pair<Integer,LineSequence> checkCache(int fileRevIndex) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 220 Pair<Integer, LineSequence> rv = null; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 221 for (ListIterator<Pair<Integer, LineSequence>> it = lruCache.listIterator(); it.hasNext(); ) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 222 Pair<Integer, LineSequence> p = it.next(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 223 if (p.first() == fileRevIndex) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 224 rv = p; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 225 it.remove(); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 226 break; | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 227 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 228 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 229 if (rv != null) { | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 230 lruCache.addFirst(rv); | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 231 } | 
| 
45751456b471
Annotate file changes through few revisions, walking either direction (old to new and vice versa)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
551diff
changeset | 232 return rv; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 233 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 234 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 235 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 236 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 237 * Client's sink for revision differences. | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 238 * | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 239 * When implemented, clients shall not expect new {@link Block blocks} instances in each call. | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 240 * | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 241 * In case more information about annotated revision is needed, inspector instances may supply | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 242 * {@link RevisionDescriptor.Recipient} through {@link Adaptable}. | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 243 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 244 @Callback | 
| 546 
cd78e8b9d7bc
File annotate test. Refactored FileAnnotation as standalone class, introduced LineInspector to make line offset calc code shared
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
545diff
changeset | 245 public interface BlockInspector { | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 246 void same(EqualBlock block); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 247 void added(AddBlock block); | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 248 void changed(ChangeBlock block); | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 249 void deleted(DeleteBlock block); | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 250 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 251 | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 252 /** | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 253 * Represents content of a block, either as a sequence of bytes or a | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 254 * sequence of smaller blocks (lines), if appropriate (according to usage context). | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 255 * | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 256 * This approach allows line-by-line access to content data along with complete byte sequence for the whole block, i.e. | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 257 * <pre> | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 258 * BlockData bd = addBlock.addedLines() | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 259 * // bd describes data from the addition completely. | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 260 * // elements of the BlockData are lines | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 261 * bd.elementCount() == addBlock.totalAddedLines(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 262 * // one cat obtain complete addition with | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 263 * byte[] everythingAdded = bd.asArray(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 264 * // or iterate line by line | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 265 * for (int i = 0; i < bd.elementCount(); i++) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 266 * byte[] lineContent = bd.elementAt(i); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 267 * String line = new String(lineContent, fileEncodingCharset); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 268 * } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 269 * where bd.elementAt(0) is the line at index addBlock.firstAddedLine() | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 270 * </pre> | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 271 * | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 272 * LineData or ChunkData? | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 273 */ | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 274 public interface BlockData { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 275 BlockData elementAt(int index); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 276 int elementCount(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 277 byte[] asArray(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 278 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 279 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 280 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 281 * {@link BlockInspector} may optionally request extra information about revisions | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 282 * being inspected, denoting itself as a {@link RevisionDescriptor.Recipient}. This class | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 283 * provides complete information about file revision under annotation now. | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 284 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 285 public interface RevisionDescriptor { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 286 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 287 * @return complete source of the diff origin, never <code>null</code> | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 288 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 289 BlockData origin(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 290 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 291 * @return complete source of the diff target, never <code>null</code> | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 292 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 293 BlockData target(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 294 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 295 * @return changeset revision index of original file, or {@link HgRepository#NO_REVISION} if it's the very first revision | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 296 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 297 int originChangesetIndex(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 298 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 299 * @return changeset revision index of the target file | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 300 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 301 int targetChangesetIndex(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 302 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 303 * @return <code>true</code> if this revision is merge | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 304 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 305 boolean isMerge(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 306 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 307 * @return changeset revision index of the second, merged parent | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 308 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 309 int mergeChangesetIndex(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 310 /** | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 311 * @return revision index of the change in target file's revlog | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 312 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 313 int fileRevisionIndex(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 314 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 315 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 316 * Implement to indicate interest in {@link RevisionDescriptor}. | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 317 * | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 318 * Note, instance of {@link RevisionDescriptor} is the same for | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 319 * {@link #start(RevisionDescriptor)} and {@link #done(RevisionDescriptor)} | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 320 * methods, and not necessarily a new one (i.e. <code>==</code>) for the next | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 321 * revision announced. | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 322 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 323 @Callback | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 324 public interface Recipient { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 325 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 326 * Comes prior to any change {@link Block blocks} | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 327 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 328 void start(RevisionDescriptor revisionDescription); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 329 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 330 * Comes after all change {@link Block blocks} were dispatched | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 331 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 332 void done(RevisionDescriptor revisionDescription); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 333 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 334 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 335 | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 336 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 337 * Each change block comes from a single origin, blocks that are result of a merge | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 338 * have {@link #originChangesetIndex()} equal to {@link RevisionDescriptor#mergeChangesetIndex()}. | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 339 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 340 public interface Block { | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 341 int originChangesetIndex(); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 342 int targetChangesetIndex(); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 343 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 344 | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 345 public interface EqualBlock extends Block { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 346 int originStart(); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 347 int targetStart(); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 348 int length(); | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 349 BlockData content(); | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 350 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 351 | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 352 public interface AddBlock extends Block { | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 353 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 354 * @return line index in the origin where this block is inserted | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 355 */ | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 356 int insertedAt(); | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 357 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 358 * @return line index of the first added line in the target revision | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 359 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 360 int firstAddedLine(); | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 361 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 362 * @return number of added lines in this block | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 363 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 364 int totalAddedLines(); | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 365 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 366 * @return content of added lines | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 367 */ | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 368 BlockData addedLines(); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 369 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 370 public interface DeleteBlock extends Block { | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 371 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 372 * @return line index in the target revision were this deleted block would be | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 373 */ | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 374 int removedAt(); | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 375 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 376 * @return line index of the first removed line in the original revision | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 377 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 378 int firstRemovedLine(); | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 379 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 380 * @return number of deleted lines in this block | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 381 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 382 int totalRemovedLines(); | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 383 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 384 * @return content of deleted lines | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 385 */ | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 386 BlockData removedLines(); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 387 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 388 public interface ChangeBlock extends AddBlock, DeleteBlock { | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 389 } | 
| 546 
cd78e8b9d7bc
File annotate test. Refactored FileAnnotation as standalone class, introduced LineInspector to make line offset calc code shared
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
545diff
changeset | 390 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 391 private static class BlameBlockInspector extends DiffHelper.DeltaInspector<LineSequence> { | 
| 546 
cd78e8b9d7bc
File annotate test. Refactored FileAnnotation as standalone class, introduced LineInspector to make line offset calc code shared
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
545diff
changeset | 392 private final BlockInspector insp; | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 393 private final int csetOrigin; | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 394 private final int csetTarget; | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 395 private EqualBlocksCollector p2MergeCommon; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 396 private int csetMergeParent; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 397 private IntVector mergeRanges; | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 398 private final AnnotateRev annotatedRevision; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 399 | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 400 public BlameBlockInspector(int fileRevIndex, BlockInspector inspector, int originCset, int targetCset) { | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 401 assert inspector != null; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 402 insp = inspector; | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 403 annotatedRevision = new AnnotateRev(); | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 404 annotatedRevision.set(fileRevIndex); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 405 csetOrigin = originCset; | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 406 csetTarget = targetCset; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 407 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 408 | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 409 public void setMergeParent2(EqualBlocksCollector p2Merge, int parentCset2) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 410 p2MergeCommon = p2Merge; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 411 csetMergeParent = parentCset2; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 412 mergeRanges = new IntVector(3*10, 3*10); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 413 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 414 | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 415 @Override | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 416 public void begin(LineSequence s1, LineSequence s2) { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 417 super.begin(s1, s2); | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 418 ContentBlock originContent = new ContentBlock(s1); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 419 ContentBlock targetContent = new ContentBlock(s2); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 420 annotatedRevision.set(originContent, targetContent); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 421 annotatedRevision.set(csetOrigin, csetTarget, p2MergeCommon != null ? csetMergeParent : NO_REVISION); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 422 Recipient curious = Adaptable.Factory.getAdapter(insp, Recipient.class, null); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 423 if (curious != null) { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 424 curious.start(annotatedRevision); | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 425 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 426 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 427 | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 428 @Override | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 429 public void end() { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 430 super.end(); | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 431 Recipient curious = Adaptable.Factory.getAdapter(insp, Recipient.class, null); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 432 if (curious != null) { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 433 curious.done(annotatedRevision); | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 434 } | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 435 p2MergeCommon = null; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 436 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 437 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 438 @Override | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 439 protected void changed(int s1From, int s1To, int s2From, int s2To) { | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 440 if (p2MergeCommon != null) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 441 mergeRanges.clear(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 442 p2MergeCommon.combineAndMarkRangesWithTarget(s2From, s2To - s2From, csetOrigin, csetMergeParent, mergeRanges); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 443 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 444 /* | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 445 * Usecases: | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 446 * 3 lines changed to 10 lines. range of 10 lines breaks down to 2 from p2, 3 from p1, and 5 from p2. | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 447 * We report: 2 lines changed to 2(p2), then 1 line changed with 3(p1) and 5 lines added from p2. | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 448 * | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 449 * 10 lines changed to 3 lines, range of 3 lines breaks down to 2 line from p1 and 1 line from p2. | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 450 * We report: 2 lines changed to 2(p1) and 8 lines changed to 1(p2) | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 451 */ | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 452 int s1TotalLines = s1To - s1From, s1ConsumedLines = 0, s1Start = s1From; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 453 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 454 for (int i = 0; i < mergeRanges.size(); i += 3) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 455 final int rangeOrigin = mergeRanges.get(i); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 456 final int rangeStart = mergeRanges.get(i+1); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 457 final int rangeLen = mergeRanges.get(i+2); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 458 final boolean lastRange = i+3 >= mergeRanges.size(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 459 final int s1LinesLeft = s1TotalLines - s1ConsumedLines; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 460 // how many lines we may reported as changed (don't use more than in range unless it's the very last range) | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 461 final int s1LinesToBorrow = lastRange ? s1LinesLeft : Math.min(s1LinesLeft, rangeLen); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 462 if (s1LinesToBorrow > 0) { | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 463 ChangeBlockImpl block = getChangeBlock(s1Start, s1LinesToBorrow, rangeStart, rangeLen); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 464 block.setOriginAndTarget(rangeOrigin, csetTarget); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 465 insp.changed(block); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 466 s1ConsumedLines += s1LinesToBorrow; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 467 s1Start += s1LinesToBorrow; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 468 } else { | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 469 ChangeBlockImpl block = getAddBlock(rangeStart, rangeLen, s1Start); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 470 block.setOriginAndTarget(rangeOrigin, csetTarget); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 471 insp.added(block); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 472 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 473 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 474 if (s1ConsumedLines != s1TotalLines) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 475 throw new HgInvalidStateException(String.format("Expected to process %d lines, but actually was %d", s1TotalLines, s1ConsumedLines)); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 476 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 477 } else { | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 478 ChangeBlockImpl block = getChangeBlock(s1From, s1To - s1From, s2From, s2To - s2From); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 479 block.setOriginAndTarget(csetOrigin, csetTarget); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 480 insp.changed(block); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 481 } | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 482 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 483 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 484 @Override | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 485 protected void added(int s1InsertPoint, int s2From, int s2To) { | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 486 if (p2MergeCommon != null) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 487 mergeRanges.clear(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 488 p2MergeCommon.combineAndMarkRangesWithTarget(s2From, s2To - s2From, csetOrigin, csetMergeParent, mergeRanges); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 489 int insPoint = s1InsertPoint; // track changes to insertion point | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 490 for (int i = 0; i < mergeRanges.size(); i += 3) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 491 int rangeOrigin = mergeRanges.get(i); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 492 int rangeStart = mergeRanges.get(i+1); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 493 int rangeLen = mergeRanges.get(i+2); | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 494 ChangeBlockImpl block = getAddBlock(rangeStart, rangeLen, insPoint); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 495 block.setOriginAndTarget(rangeOrigin, csetTarget); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 496 insp.added(block); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 497 // indicate insPoint moved down number of lines we just reported | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 498 insPoint += rangeLen; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 499 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 500 } else { | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 501 ChangeBlockImpl block = getAddBlock(s2From, s2To - s2From, s1InsertPoint); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 502 block.setOriginAndTarget(csetOrigin, csetTarget); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 503 insp.added(block); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 504 } | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 505 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 506 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 507 @Override | 
| 543 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 508 protected void deleted(int s2DeletePoint, int s1From, int s1To) { | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 509 ChangeBlockImpl block = new ChangeBlockImpl(annotatedRevision.origin, null, s1From, s1To - s1From, -1, -1, -1, s2DeletePoint); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 510 block.setOriginAndTarget(csetOrigin, csetTarget); | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 511 insp.deleted(block); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 512 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 513 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 514 @Override | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 515 protected void unchanged(int s1From, int s2From, int length) { | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 516 EqualBlockImpl block = new EqualBlockImpl(s1From, s2From, length, annotatedRevision.target); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 517 block.setOriginAndTarget(csetOrigin, csetTarget); | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 518 insp.same(block); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 519 } | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 520 | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 521 private ChangeBlockImpl getAddBlock(int start, int len, int insPoint) { | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 522 return new ChangeBlockImpl(null, annotatedRevision.target, -1, -1, start, len, insPoint, -1); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 523 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 524 | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 525 private ChangeBlockImpl getChangeBlock(int start1, int len1, int start2, int len2) { | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 526 return new ChangeBlockImpl(annotatedRevision.origin, annotatedRevision.target, start1, len1, start2, len2, start1, start2); | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 527 } | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 528 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 529 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 530 private static class BlockImpl implements Block { | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 531 private int originCset; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 532 private int targetCset; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 533 | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 534 void setOriginAndTarget(int originChangesetIndex, int targetChangesetIndex) { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 535 // XXX perhaps, shall be part of Inspector API, rather than Block's | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 536 // as they don't change between blocks (although the moment about merged revisions) | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 537 // is not yet clear to me | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 538 originCset = originChangesetIndex; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 539 targetCset = targetChangesetIndex; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 540 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 541 | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 542 public int originChangesetIndex() { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 543 return originCset; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 544 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 545 | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 546 public int targetChangesetIndex() { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 547 return targetCset; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 548 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 549 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 550 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 551 private static class EqualBlockImpl extends BlockImpl implements EqualBlock { | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 552 private final int start1, start2; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 553 private final int length; | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 554 private final ContentBlock fullContent; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 555 private FilterBlock myContent; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 556 | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 557 EqualBlockImpl(int blockStartSeq1, int blockStartSeq2, int blockLength, ContentBlock targetContent) { | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 558 start1 = blockStartSeq1; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 559 start2 = blockStartSeq2; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 560 length = blockLength; | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 561 fullContent = targetContent; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 562 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 563 | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 564 public int originStart() { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 565 return start1; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 566 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 567 | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 568 public int targetStart() { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 569 return start2; | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 570 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 571 | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 572 public int length() { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 573 return length; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 574 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 575 | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 576 public BlockData content() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 577 if (myContent == null) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 578 myContent = new FilterBlock(fullContent, start2, length); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 579 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 580 return myContent; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 581 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 582 | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 583 @Override | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 584 public String toString() { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 585 return String.format("@@ [%d..%d) == [%d..%d) @@", start1, start1+length, start2, start2+length); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 586 } | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 587 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 588 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 589 private static class ChangeBlockImpl extends BlockImpl implements ChangeBlock { | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 590 private final ContentBlock oldContent; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 591 private final ContentBlock newContent; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 592 private final int s1Start; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 593 private final int s1Len; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 594 private final int s2Start; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 595 private final int s2Len; | 
| 543 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 596 private final int s1InsertPoint; | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 597 private final int s2DeletePoint; | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 598 private FilterBlock addedBlock, removedBlock; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 599 | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 600 public ChangeBlockImpl(ContentBlock c1, ContentBlock c2, int s1Start, int s1Len, int s2Start, int s2Len, int s1InsertPoint, int s2DeletePoint) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 601 oldContent = c1; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 602 newContent = c2; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 603 this.s1Start = s1Start; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 604 this.s1Len = s1Len; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 605 this.s2Start = s2Start; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 606 this.s2Len = s2Len; | 
| 543 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 607 this.s1InsertPoint = s1InsertPoint; | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 608 this.s2DeletePoint = s2DeletePoint; | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 609 } | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 610 | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 611 public int insertedAt() { | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 612 return s1InsertPoint; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 613 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 614 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 615 public int firstAddedLine() { | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 616 return s2Start; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 617 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 618 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 619 public int totalAddedLines() { | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 620 return s2Len; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 621 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 622 | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 623 public BlockData addedLines() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 624 if (addedBlock == null) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 625 addedBlock = new FilterBlock(newContent, firstAddedLine(), totalAddedLines()); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 626 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 627 return addedBlock; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 628 } | 
| 543 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 629 | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 630 public int removedAt() { | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 631 return s2DeletePoint; | 
| 
1e95f48d9886
Report line index for insertion and deletion, test against 'hg diff' output
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
542diff
changeset | 632 } | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 633 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 634 public int firstRemovedLine() { | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 635 return s1Start; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 636 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 637 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 638 public int totalRemovedLines() { | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 639 return s1Len; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 640 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 641 | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 642 public BlockData removedLines() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 643 if (removedBlock == null) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 644 removedBlock = new FilterBlock(oldContent, firstRemovedLine(), totalRemovedLines()); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 645 } | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 646 return removedBlock; | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 647 } | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 648 | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 649 @Override | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 650 public String toString() { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 651 if (s2DeletePoint == -1) { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 652 return String.format("@@ -%d,0 +%d,%d @@", insertedAt(), firstAddedLine(), totalAddedLines()); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 653 } else if (s1InsertPoint == -1) { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 654 // delete only | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 655 return String.format("@@ -%d,%d +%d,0 @@", firstRemovedLine(), totalRemovedLines(), removedAt()); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 656 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 657 return String.format("@@ -%d,%d +%d,%d @@", firstRemovedLine(), totalRemovedLines(), firstAddedLine(), totalAddedLines()); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 658 } | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 659 } | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 660 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 661 private static class SingleLine implements BlockData { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 662 private final ByteChain line; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 663 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 664 public SingleLine(ByteChain lineContent) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 665 line = lineContent; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 666 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 667 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 668 public BlockData elementAt(int index) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 669 assert false; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 670 return null; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 671 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 672 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 673 public int elementCount() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 674 return 0; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 675 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 676 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 677 public byte[] asArray() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 678 return line.data(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 679 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 680 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 681 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 682 private static class ContentBlock implements BlockData { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 683 private final LineSequence seq; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 684 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 685 public ContentBlock(LineSequence sequence) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 686 seq = sequence; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 687 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 688 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 689 public BlockData elementAt(int index) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 690 return new SingleLine(seq.chunk(index)); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 691 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 692 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 693 public int elementCount() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 694 return seq.chunkCount() - 1; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 695 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 696 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 697 public byte[] asArray() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 698 return seq.data(0, seq.chunkCount() - 1); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 699 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 700 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 701 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 702 private static class FilterBlock implements BlockData { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 703 private final ContentBlock contentBlock; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 704 private final int from; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 705 private final int length; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 706 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 707 public FilterBlock(ContentBlock bd, int startFrom, int len) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 708 assert bd != null; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 709 assert startFrom + len < bd.seq.chunkCount(); // there's one extra chunk in the end, so strict less is ok | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 710 contentBlock = bd; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 711 from = startFrom; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 712 length = len; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 713 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 714 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 715 public BlockData elementAt(int index) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 716 if (index < 0 || index >= length) { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 717 throw new IllegalArgumentException(String.format("Expected value from [0..%d), got %d", length, index)); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 718 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 719 return contentBlock.elementAt(from + index); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 720 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 721 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 722 public int elementCount() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 723 return length; | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 724 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 725 | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 726 public byte[] asArray() { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 727 return contentBlock.seq.data(from, from + length); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 728 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 729 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 730 | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 731 | 
| 551 
4ea0351ca878
Better (precise) name for diff facility, tests
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
549diff
changeset | 732 static class EqualBlocksCollector implements DiffHelper.MatchInspector<LineSequence> { | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 733 private final IntVector matches = new IntVector(10*3, 2*3); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 734 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 735 public void begin(LineSequence s1, LineSequence s2) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 736 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 737 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 738 public void match(int startSeq1, int startSeq2, int matchLength) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 739 matches.add(startSeq1); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 740 matches.add(startSeq2); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 741 matches.add(matchLength); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 742 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 743 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 744 public void end() { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 745 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 746 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 747 // true when specified line in origin is equal to a line in target | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 748 public boolean includesOriginLine(int ln) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 749 return includes(ln, 0); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 750 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 751 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 752 // true when specified line in target is equal to a line in origin | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 753 public boolean includesTargetLine(int ln) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 754 return includes(ln, 1); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 755 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 756 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 757 public void intersectWithTarget(int start, int length, IntVector result) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 758 int s = start; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 759 for (int l = start, x = start + length; l < x; l++) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 760 if (!includesTargetLine(l)) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 761 if (l - s > 0) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 762 result.add(s); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 763 result.add(l - s); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 764 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 765 s = l+1; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 766 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 767 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 768 if (s < start+length) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 769 result.add(s); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 770 result.add((start + length) - s); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 771 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 772 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 773 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 774 /* | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 775 * intersects [start..start+length) with ranges of target lines, and based on the intersection | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 776 * breaks initial range into smaller ranges and records them into result, with marker to indicate | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 777 * whether the range is from initial range (markerSource) or is a result of the intersection with target | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 778 * (markerTarget) | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 779 */ | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 780 public void combineAndMarkRangesWithTarget(int start, int length, int markerSource, int markerTarget, IntVector result) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 781 int sourceStart = start, targetStart = start, sourceEnd = start + length; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 782 for (int l = sourceStart; l < sourceEnd; l++) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 783 if (includesTargetLine(l)) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 784 // l is from target | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 785 if (sourceStart < l) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 786 // few lines from source range were not in the target, report them | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 787 result.add(markerSource); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 788 result.add(sourceStart); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 789 result.add(l - sourceStart); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 790 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 791 // indicate the earliest line from source range to use | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 792 sourceStart = l + 1; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 793 } else { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 794 // l is not in target | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 795 if (targetStart < l) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 796 // report lines from target range | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 797 result.add(markerTarget); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 798 result.add(targetStart); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 799 result.add(l - targetStart); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 800 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 801 // next line *may* be from target | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 802 targetStart = l + 1; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 803 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 804 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 805 // if source range end with line from target, sourceStart would be == sourceEnd, and we need to add range with markerTarget | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 806 // if source range doesn't end with target line, targetStart == sourceEnd, while sourceStart < sourceEnd | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 807 if (sourceStart < sourceEnd) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 808 assert targetStart == sourceEnd; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 809 // something left from the source range | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 810 result.add(markerSource); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 811 result.add(sourceStart); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 812 result.add(sourceEnd - sourceStart); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 813 } else if (targetStart < sourceEnd) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 814 assert sourceStart == sourceEnd; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 815 result.add(markerTarget); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 816 result.add(targetStart); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 817 result.add(sourceEnd - targetStart); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 818 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 819 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 820 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 821 private boolean includes(int ln, int o) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 822 for (int i = 2; i < matches.size(); o += 3, i+=3) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 823 int rangeStart = matches.get(o); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 824 if (rangeStart > ln) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 825 return false; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 826 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 827 int rangeLen = matches.get(i); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 828 if (rangeStart + rangeLen > ln) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 829 return true; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 830 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 831 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 832 return false; | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 833 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 834 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 835 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 836 private static class AnnotateRev implements RevisionDescriptor { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 837 public ContentBlock origin, target; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 838 public int originCset, targetCset, mergeCset, fileRevIndex; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 839 | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 840 public void set(int fileRev) { | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 841 fileRevIndex = fileRev; | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 842 } | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 843 public void set(ContentBlock o, ContentBlock t) { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 844 origin = o; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 845 target = t; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 846 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 847 public void set(int o, int t, int m) { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 848 originCset = o; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 849 targetCset = t; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 850 mergeCset = m; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 851 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 852 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 853 public BlockData origin() { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 854 return origin; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 855 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 856 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 857 public BlockData target() { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 858 return target; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 859 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 860 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 861 public int originChangesetIndex() { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 862 return originCset; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 863 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 864 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 865 public int targetChangesetIndex() { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 866 return targetCset; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 867 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 868 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 869 public boolean isMerge() { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 870 return mergeCset != NO_REVISION; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 871 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 872 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 873 public int mergeChangesetIndex() { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 874 return mergeCset; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 875 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 876 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 877 public int fileRevisionIndex() { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 878 return fileRevIndex; | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 879 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 880 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 881 | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 882 public static void main(String[] args) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 883 EqualBlocksCollector bc = new EqualBlocksCollector(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 884 bc.match(-1, 5, 3); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 885 bc.match(-1, 10, 2); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 886 bc.match(-1, 15, 3); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 887 bc.match(-1, 20, 3); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 888 assert !bc.includesTargetLine(4); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 889 assert bc.includesTargetLine(7); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 890 assert !bc.includesTargetLine(8); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 891 assert bc.includesTargetLine(10); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 892 assert !bc.includesTargetLine(12); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 893 IntVector r = new IntVector(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 894 bc.intersectWithTarget(7, 10, r); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 895 for (int i = 0; i < r.size(); i+=2) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 896 System.out.printf("[%d..%d) ", r.get(i), r.get(i) + r.get(i+1)); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 897 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 898 System.out.println(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 899 r.clear(); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 900 bc.combineAndMarkRangesWithTarget(0, 16, 508, 514, r); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 901 for (int i = 0; i < r.size(); i+=3) { | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 902 System.out.printf("%d:[%d..%d) ", r.get(i), r.get(i+1), r.get(i+1) + r.get(i+2)); | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 903 } | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 904 } | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 905 } | 
