Browse Source

Merge "Add debugging toString to TreeFormatter"

tags/v0.10.1
Chris Aniszczyk 13 years ago
parent
commit
34554e4f1c
1 changed files with 36 additions and 0 deletions
  1. 36
    0
      org.eclipse.jgit/src/org/eclipse/jgit/lib/TreeFormatter.java

+ 36
- 0
org.eclipse.jgit/src/org/eclipse/jgit/lib/TreeFormatter.java View File

@@ -52,9 +52,11 @@ import static org.eclipse.jgit.lib.FileMode.TREE;

import java.io.IOException;

import org.eclipse.jgit.errors.CorruptObjectException;
import org.eclipse.jgit.revwalk.RevBlob;
import org.eclipse.jgit.revwalk.RevCommit;
import org.eclipse.jgit.revwalk.RevTree;
import org.eclipse.jgit.treewalk.CanonicalTreeParser;
import org.eclipse.jgit.util.TemporaryBuffer;

/**
@@ -311,4 +313,38 @@ public class TreeFormatter {
throw new RuntimeException(err);
}
}

@Override
public String toString() {
byte[] raw = toByteArray();

CanonicalTreeParser p = new CanonicalTreeParser();
p.reset(raw);

StringBuilder r = new StringBuilder();
r.append("Tree={");
if (!p.eof()) {
r.append('\n');
try {
new ObjectChecker().checkTree(raw);
} catch (CorruptObjectException error) {
r.append("*** ERROR: ").append(error.getMessage()).append("\n");
r.append('\n');
}
}
while (!p.eof()) {
final FileMode mode = p.getEntryFileMode();
r.append(mode);
r.append(' ');
r.append(Constants.typeString(mode.getObjectType()));
r.append(' ');
r.append(p.getEntryObjectId().name());
r.append(' ');
r.append(p.getEntryPathString());
r.append('\n');
p.next();
}
r.append("}");
return r.toString();
}
}

Loading…
Cancel
Save