Mercurial > jhg
annotate src/org/tmatesoft/hg/repo/HgBlameFacility.java @ 596:43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
| author | Artem Tikhomirov <tikhomirov.artem@gmail.com> | 
|---|---|
| date | Thu, 02 May 2013 19:23:53 +0200 | 
| parents | e49f9d9513fa | 
| children | 
| 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 | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 19 import static org.tmatesoft.hg.core.HgIterateDirection.OldToNew; | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 20 import static org.tmatesoft.hg.repo.HgInternals.wrongRevisionIndex; | 
| 596 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 21 import static org.tmatesoft.hg.repo.HgRepository.NO_REVISION; | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 22 import static org.tmatesoft.hg.repo.HgRepository.TIP; | 
| 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 | 23 | 
| 562 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 24 import org.tmatesoft.hg.core.HgCallbackTargetException; | 
| 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 | 25 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 | 26 import org.tmatesoft.hg.core.Nodeid; | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 27 import org.tmatesoft.hg.internal.BlameHelper; | 
| 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.Callback; | 
| 
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.Experimental; | 
| 596 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 30 import org.tmatesoft.hg.internal.FileHistory; | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 31 import org.tmatesoft.hg.internal.FileRevisionHistoryChunk; | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 32 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 | 33 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 34 /** | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 35 * 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 | 36 * | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 37 * @author Artem Tikhomirov | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 38 * @author TMate Software Ltd. | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 39 */ | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 40 @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 | 41 public final class HgBlameFacility { | 
| 568 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 42 private final HgDataFile df; | 
| 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 43 | 
| 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 44 public HgBlameFacility(HgDataFile file) { | 
| 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 45 if (file == null) { | 
| 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 46 throw new IllegalArgumentException(); | 
| 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 47 } | 
| 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 48 df = file; | 
| 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 49 } | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 50 | 
| 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 51 /** | 
| 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 | 52 * 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 | 53 */ | 
| 568 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 54 public void diff(int clogRevIndex1, int clogRevIndex2, Inspector insp) throws HgCallbackTargetException { | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 55 // FIXME clogRevIndex1 and clogRevIndex2 may point to different files, need to decide whether to throw an exception | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 56 // or to attempt to look up correct file node (tricky) | 
| 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 | 57 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 | 58 int fileRevIndex2 = fileRevIndex(df, clogRevIndex2); | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 59 BlameHelper bh = new BlameHelper(insp, 5); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 60 bh.useFileUpTo(df, clogRevIndex2); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 61 bh.diff(fileRevIndex1, clogRevIndex1, fileRevIndex2, 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 /** | 
| 568 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 65 * Walk file history up/down to revision at given changeset and report changes for each revision | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 66 */ | 
| 568 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 67 public void annotate(int changelogRevisionIndex, Inspector insp, HgIterateDirection iterateOrder) throws HgCallbackTargetException { | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 68 annotate(0, changelogRevisionIndex, insp, iterateOrder); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 69 } | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 70 | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 71 /** | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 72 * Walk file history range and report changes for each revision | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 73 */ | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 74 public void annotate(int changelogRevIndexStart, int changelogRevIndexEnd, Inspector insp, HgIterateDirection iterateOrder) throws HgCallbackTargetException { | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 75 if (wrongRevisionIndex(changelogRevIndexStart) || wrongRevisionIndex(changelogRevIndexEnd)) { | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 76 throw new IllegalArgumentException(); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 77 } | 
| 573 
e49f9d9513fa
Partial blame when start/end revisions are in the middle of a single filename history
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
570diff
changeset | 78 // Note, changelogRevIndexEnd may be TIP, while the code below doesn't tolerate constants | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 79 // | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 80 int lastRevision = df.getRepo().getChangelog().getLastRevision(); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 81 if (changelogRevIndexEnd == TIP) { | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 82 changelogRevIndexEnd = lastRevision; | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 83 } | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 84 HgInternals.checkRevlogRange(changelogRevIndexStart, changelogRevIndexEnd, lastRevision); | 
| 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 | 85 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 | 86 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 | 87 } | 
| 596 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 88 FileHistory fileHistory = new FileHistory(df, changelogRevIndexStart, changelogRevIndexEnd); | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 89 fileHistory.build(); | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 90 BlameHelper bh = new BlameHelper(insp, 10); | 
| 596 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 91 for (FileRevisionHistoryChunk fhc : fileHistory.iterate(OldToNew)) { | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 92 // iteration order is not important here | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 93 bh.useFileUpTo(fhc.getFile(), fhc.getEndChangeset()); | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 94 } | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 95 int[] fileClogParentRevs = new int[2]; | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 96 int[] fileParentRevs = new int[2]; | 
| 596 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 97 for (FileRevisionHistoryChunk fhc : fileHistory.iterate(iterateOrder)) { | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 98 for (int fri : fhc.fileRevisions(iterateOrder)) { | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 99 int clogRevIndex = fhc.changeset(fri); | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 100 // the way we built fileHistory ensures we won't walk past [changelogRevIndexStart..changelogRevIndexEnd] | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 101 assert clogRevIndex >= changelogRevIndexStart; | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 102 assert clogRevIndex <= changelogRevIndexEnd; | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 103 fhc.fillFileParents(fri, fileParentRevs); | 
| 
43cfa08ff3fd
HgBlameFacility refactoring: extract code to build file history that spans renames
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
573diff
changeset | 104 fhc.fillCsetParents(fri, fileClogParentRevs); | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 105 bh.annotateChange(fri, clogRevIndex, fileParentRevs, fileClogParentRevs); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 106 } | 
| 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 | 107 } | 
| 549 
83afa680555d
Annotate merge revision (combined diff against two parents without looking further)
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
548diff
changeset | 108 } | 
| 548 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 109 | 
| 
ab21ac7dd833
Line-by-line annotation API and support code in place
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
546diff
changeset | 110 /** | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 111 * Annotates changes of the file against its parent(s). | 
| 562 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 112 * Unlike {@link #annotate(HgDataFile, int, Inspector, HgIterateDirection)}, doesn't | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 113 * 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 | 114 */ | 
| 568 
8ed4f4f4f0a6
Blame facility refactored, get ready for follow/no-follow support
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
562diff
changeset | 115 public void annotateSingleRevision(int changelogRevisionIndex, Inspector insp) throws HgCallbackTargetException { | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 116 // 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 | 117 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 | 118 int[] fileRevParents = new int[2]; | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 119 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 | 120 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 | 121 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 | 122 } | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 123 BlameHelper bh = new BlameHelper(insp, 5); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 124 bh.useFileUpTo(df, changelogRevisionIndex); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 125 int[] fileClogParentRevs = new int[2]; | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 126 fileClogParentRevs[0] = fileRevParents[0] == NO_REVISION ? NO_REVISION : df.getChangesetRevisionIndex(fileRevParents[0]); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 127 fileClogParentRevs[1] = fileRevParents[1] == NO_REVISION ? NO_REVISION : df.getChangesetRevisionIndex(fileRevParents[1]); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 128 bh.annotateChange(fileRevIndex, changelogRevisionIndex, fileRevParents, fileClogParentRevs); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 129 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 130 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 131 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 132 * 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 | 133 * | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 134 * 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 | 135 * | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 136 * 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 | 137 * {@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 | 138 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 139 @Callback | 
| 562 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 140 public interface Inspector { | 
| 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 141 void same(EqualBlock block) throws HgCallbackTargetException; | 
| 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 142 void added(AddBlock block) throws HgCallbackTargetException; | 
| 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 143 void changed(ChangeBlock block) throws HgCallbackTargetException; | 
| 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 144 void deleted(DeleteBlock block) throws HgCallbackTargetException; | 
| 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 145 } | 
| 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 146 | 
| 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 147 /** | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 148 * 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 | 149 * 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 | 150 * | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 151 * 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 | 152 * <pre> | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 153 * BlockData bd = addBlock.addedLines() | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 154 * // 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 | 155 * // 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 | 156 * bd.elementCount() == addBlock.totalAddedLines(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 157 * // 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 | 158 * byte[] everythingAdded = bd.asArray(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 159 * // or iterate line by line | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 160 * 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 | 161 * byte[] lineContent = bd.elementAt(i); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 162 * 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 | 163 * } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 164 * 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 | 165 * </pre> | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 166 * | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 167 * LineData or ChunkData? | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 168 */ | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 169 public interface BlockData { | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 170 BlockData elementAt(int index); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 171 int elementCount(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 172 byte[] asArray(); | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 173 } | 
| 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 174 | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 175 /** | 
| 562 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 176 * {@link Inspector} may optionally request extra information about revisions | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 177 * 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 | 178 * 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 | 179 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 180 public interface RevisionDescriptor { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 181 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 182 * @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 | 183 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 184 BlockData origin(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 185 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 186 * @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 | 187 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 188 BlockData target(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 189 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 190 * @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 | 191 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 192 int originChangesetIndex(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 193 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 194 * @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 | 195 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 196 int targetChangesetIndex(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 197 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 198 * @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 | 199 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 200 boolean isMerge(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 201 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 202 * @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 | 203 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 204 int mergeChangesetIndex(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 205 /** | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 206 * @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 | 207 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 208 int fileRevisionIndex(); | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 209 | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 210 /** | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 211 * @return file object under blame (target file) | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 212 */ | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 213 HgDataFile file(); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 214 | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 215 /** | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 216 * 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 | 217 * | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 218 * 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 | 219 * {@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 | 220 * 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 | 221 * revision announced. | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 222 */ | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 223 @Callback | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 224 public interface Recipient { | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 225 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 226 * 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 | 227 */ | 
| 562 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 228 void start(RevisionDescriptor revisionDescription) throws HgCallbackTargetException; | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 229 /** | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 230 * 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 | 231 */ | 
| 562 
6fbca6506bb5
Allow HgBlameFacility.Inspector (former BlockInspector) to throw an exception
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
561diff
changeset | 232 void done(RevisionDescriptor revisionDescription) throws HgCallbackTargetException; | 
| 555 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 233 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 234 } | 
| 
e623aa2ca526
Annotate: RevisionDescriptor provides extra knowledge about inspected/annotated revision
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
554diff
changeset | 235 | 
| 556 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 236 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 237 * 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 | 238 * 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 | 239 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 240 public interface Block { | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 241 int originChangesetIndex(); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 242 int targetChangesetIndex(); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 243 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 244 | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 245 public interface EqualBlock extends Block { | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 246 int originStart(); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 247 int targetStart(); | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 248 int length(); | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 249 BlockData content(); | 
| 545 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 250 } | 
| 
15b406c7cd9d
First round of annotate file is functional
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
544diff
changeset | 251 | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 252 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 | 253 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 254 * @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 | 255 */ | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 256 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 | 257 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 258 * @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 | 259 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 260 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 | 261 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 262 * @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 | 263 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 264 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 | 265 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 266 * @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 | 267 */ | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 268 BlockData addedLines(); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 269 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 270 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 | 271 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 272 * @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 | 273 */ | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 274 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 | 275 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 276 * @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 | 277 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 278 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 | 279 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 280 * @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 | 281 */ | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 282 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 | 283 /** | 
| 
e55f17a7a195
AnnotateFacility renamed to HgBlameFacility and exposed, API shapes out and got some javadoc
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
555diff
changeset | 284 * @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 | 285 */ | 
| 554 
a5fd757d1b5d
Access to content of annotated files through BlockData interface
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
553diff
changeset | 286 BlockData removedLines(); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 287 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 288 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 | 289 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 290 | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 291 | 
| 569 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 292 private static int fileRevIndex(HgDataFile df, int csetRevIndex) { | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 293 Nodeid fileRev = df.getRepo().getManifest().getFileRevision(csetRevIndex, df.getPath()); | 
| 
c4fd1037bc6f
Support for copy/rename follow/no-follow for annotate
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: 
568diff
changeset | 294 return df.getRevisionIndex(fileRev); | 
| 542 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 295 } | 
| 
a71a05ec11bc
Towards annotate/blame support: general outline of the functionality
 Artem Tikhomirov <tikhomirov.artem@gmail.com> parents: diff
changeset | 296 } | 
