aboutsummaryrefslogtreecommitdiffstats
path: root/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Log.java
diff options
context:
space:
mode:
Diffstat (limited to 'org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Log.java')
-rw-r--r--org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Log.java62
1 files changed, 26 insertions, 36 deletions
diff --git a/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Log.java b/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Log.java
index d27793c5be..4a92ea624f 100644
--- a/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Log.java
+++ b/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Log.java
@@ -64,16 +64,15 @@ import org.eclipse.jgit.diff.DiffFormatter;
import org.eclipse.jgit.diff.RawText;
import org.eclipse.jgit.diff.RawTextComparator;
import org.eclipse.jgit.diff.RenameDetector;
+import org.eclipse.jgit.errors.LargeObjectException;
import org.eclipse.jgit.lib.AnyObjectId;
import org.eclipse.jgit.lib.Constants;
import org.eclipse.jgit.lib.ObjectId;
-import org.eclipse.jgit.lib.ObjectReader;
import org.eclipse.jgit.lib.PersonIdent;
import org.eclipse.jgit.lib.Ref;
import org.eclipse.jgit.notes.NoteMap;
import org.eclipse.jgit.revwalk.RevCommit;
import org.eclipse.jgit.revwalk.RevTree;
-import org.eclipse.jgit.revwalk.RevWalk;
import org.kohsuke.args4j.Option;
@Command(common = true, usage = "usage_viewCommitHistory")
@@ -89,10 +88,6 @@ class Log extends RevWalkTextBuiltin {
private Map<String, NoteMap> noteMaps;
- private ObjectReader reader;
-
- private RevWalk revWalk;
-
@Option(name="--decorate", usage="usage_showRefNamesMatchingCommits")
private boolean decorate;
@@ -183,14 +178,6 @@ class Log extends RevWalkTextBuiltin {
}
@Override
- protected RevWalk createWalk() {
- RevWalk ret = super.createWalk();
- if (decorate)
- allRefsByPeeledObjectId = getRepository().getAllRefsByPeeledObjectId();
- return ret;
- }
-
- @Override
protected void run() throws Exception {
diffFmt.setRepository(db);
try {
@@ -202,40 +189,39 @@ class Log extends RevWalkTextBuiltin {
rd.setRenameLimit(renameLimit.intValue());
}
- if (!noStandardNotes || additionalNoteRefs != null) {
- reader = db.newObjectReader();
- revWalk = new RevWalk(db);
+ if (!noStandardNotes || !additionalNoteRefs.isEmpty()) {
+ createWalk();
noteMaps = new LinkedHashMap<String, NoteMap>();
if (!noStandardNotes) {
- noteMaps.put(Constants.R_NOTES_COMMITS,
- getNoteMap(Constants.R_NOTES_COMMITS));
+ addNoteMap(Constants.R_NOTES_COMMITS);
}
- if (additionalNoteRefs != null) {
+ if (!additionalNoteRefs.isEmpty()) {
for (String notesRef : additionalNoteRefs) {
if (!notesRef.startsWith(Constants.R_NOTES)) {
notesRef = Constants.R_NOTES + notesRef;
}
- noteMaps.put(notesRef, getNoteMap(notesRef));
+ addNoteMap(notesRef);
}
}
}
+ if (decorate)
+ allRefsByPeeledObjectId = getRepository()
+ .getAllRefsByPeeledObjectId();
+
super.run();
} finally {
diffFmt.release();
- if (reader != null)
- reader.release();
- if (revWalk != null)
- revWalk.release();
}
}
- private NoteMap getNoteMap(String notesRef) throws IOException {
+ private void addNoteMap(String notesRef) throws IOException {
Ref notes = db.getRef(notesRef);
if (notes == null)
- return null;
- RevCommit notesCommit = revWalk.parseCommit(notes.getObjectId());
- return NoteMap.read(reader, notesCommit);
+ return;
+ RevCommit notesCommit = argWalk.parseCommit(notes.getObjectId());
+ noteMaps.put(notesRef,
+ NoteMap.read(argWalk.getObjectReader(), notesCommit));
}
@Override
@@ -304,7 +290,7 @@ class Log extends RevWalkTextBuiltin {
}
boolean printedNote = showNotes(c, e.getValue(), label,
printEmptyLine);
- atLeastOnePrinted = atLeastOnePrinted || printedNote;
+ atLeastOnePrinted |= printedNote;
printEmptyLine = printedNote;
}
return atLeastOnePrinted;
@@ -334,12 +320,16 @@ class Log extends RevWalkTextBuiltin {
out.print(")");
}
out.println(":");
- RawText rawText = new RawText(reader.open(blobId).getBytes());
- String s = rawText.getString(0, rawText.size(), false);
- final String[] lines = s.split("\n");
- for (final String l : lines) {
- out.print(" ");
- out.println(l);
+ try {
+ RawText rawText = new RawText(argWalk.getObjectReader()
+ .open(blobId).getCachedBytes(Integer.MAX_VALUE));
+ for (int i = 0; i < rawText.size(); i++) {
+ out.print(" ");
+ out.println(rawText.getString(i));
+ }
+ } catch (LargeObjectException e) {
+ out.println(MessageFormat.format(
+ CLIText.get().noteObjectTooLargeToPrint, blobId.name()));
}
return true;
}