diff options
author | Chris Aniszczyk <caniszczyk@gmail.com> | 2012-03-05 23:44:44 -0500 |
---|---|---|
committer | Gerrit Code Review @ Eclipse.org <gerrit@eclipse.org> | 2012-03-05 23:44:45 -0500 |
commit | db29665e64f508eefa12ba8c3c692312f4c9a73e (patch) | |
tree | fafd9f95000c9f067abb99c7aa777bfeb76c9a21 | |
parent | eedd77a97b3eb5c404ac8464ea3a59498a121c72 (diff) | |
parent | 88fe2836edab8d8ce82d28acd9d07b061988ff3a (diff) | |
download | jgit-db29665e64f508eefa12ba8c3c692312f4c9a73e.tar.gz jgit-db29665e64f508eefa12ba8c3c692312f4c9a73e.zip |
Merge "Quickfix for AutoCRLF handling"
4 files changed, 57 insertions, 5 deletions
diff --git a/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/AddCommandTest.java b/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/AddCommandTest.java index 632288ec64..2fb228e01d 100644 --- a/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/AddCommandTest.java +++ b/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/AddCommandTest.java @@ -111,7 +111,7 @@ public class AddCommandTest extends RepositoryTestCase { } @Test - public void testAddExistingSingleFileWithNewLine() throws IOException, + public void testAddExistingSingleSmallFileWithNewLine() throws IOException, NoFilepatternException { File file = new File(db.getWorkTree(), "a.txt"); FileUtils.createNewFile(file); @@ -135,6 +135,35 @@ public class AddCommandTest extends RepositoryTestCase { } @Test + public void testAddExistingSingleMediumSizeFileWithNewLine() + throws IOException, NoFilepatternException { + File file = new File(db.getWorkTree(), "a.txt"); + FileUtils.createNewFile(file); + StringBuilder data = new StringBuilder(); + for (int i = 0; i < 1000; ++i) { + data.append("row1\r\nrow2"); + } + String crData = data.toString(); + PrintWriter writer = new PrintWriter(file); + writer.print(crData); + writer.close(); + String lfData = data.toString().replaceAll("\r", ""); + Git git = new Git(db); + db.getConfig().setString("core", null, "autocrlf", "false"); + git.add().addFilepattern("a.txt").call(); + assertEquals("[a.txt, mode:100644, content:" + data + "]", + indexState(CONTENT)); + db.getConfig().setString("core", null, "autocrlf", "true"); + git.add().addFilepattern("a.txt").call(); + assertEquals("[a.txt, mode:100644, content:" + lfData + "]", + indexState(CONTENT)); + db.getConfig().setString("core", null, "autocrlf", "input"); + git.add().addFilepattern("a.txt").call(); + assertEquals("[a.txt, mode:100644, content:" + lfData + "]", + indexState(CONTENT)); + } + + @Test public void testAddExistingSingleBinaryFile() throws IOException, NoFilepatternException { File file = new File(db.getWorkTree(), "a.txt"); diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/lib/ObjectInserter.java b/org.eclipse.jgit/src/org/eclipse/jgit/lib/ObjectInserter.java index 0355e56f5f..e03fe35719 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/lib/ObjectInserter.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/lib/ObjectInserter.java @@ -109,6 +109,29 @@ public abstract class ObjectInserter { return tempBuffer; } + static private final int tempBufSize; + static { + String s = System.getProperty("jgit.tempbufmaxsize"); + if (s != null) + tempBufSize = Integer.parseInt(s); + else + tempBufSize = 1000000; + } + + /** + * @param hintSize + * @return a temporary byte array for use by the caller + */ + protected byte[] buffer(long hintSize) { + if (hintSize >= tempBufSize) + tempBuffer = new byte[0]; + else if (tempBuffer == null) + tempBuffer = new byte[(int) hintSize]; + else if (tempBuffer.length < hintSize) + tempBuffer = new byte[(int) hintSize]; + return tempBuffer; + } + /** @return digest to help compute an ObjectId */ protected MessageDigest digest() { digest.reset(); @@ -172,7 +195,7 @@ public abstract class ObjectInserter { md.update((byte) ' '); md.update(Constants.encodeASCII(length)); md.update((byte) 0); - byte[] buf = buffer(); + byte[] buf = buffer(length); while (length > 0) { int n = in.read(buf, 0, (int) Math.min(length, buf.length)); if (n < 0) diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/storage/dfs/DfsInserter.java b/org.eclipse.jgit/src/org/eclipse/jgit/storage/dfs/DfsInserter.java index 335e284e2b..e80a324752 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/storage/dfs/DfsInserter.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/storage/dfs/DfsInserter.java @@ -116,7 +116,7 @@ public class DfsInserter extends ObjectInserter { @Override public ObjectId insert(int type, long len, InputStream in) throws IOException { - byte[] buf = buffer(); + byte[] buf = buffer(len); if (len <= buf.length) { IO.readFully(in, buf, 0, (int) len); return insert(type, buf, 0, (int) len); diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/storage/file/ObjectDirectoryInserter.java b/org.eclipse.jgit/src/org/eclipse/jgit/storage/file/ObjectDirectoryInserter.java index ffd5c4149f..75f6b0bdaa 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/storage/file/ObjectDirectoryInserter.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/storage/file/ObjectDirectoryInserter.java @@ -95,8 +95,8 @@ class ObjectDirectoryInserter extends ObjectInserter { @Override public ObjectId insert(final int type, long len, final InputStream is) throws IOException { - if (len <= buffer().length) { - byte[] buf = buffer(); + byte[] buf = buffer(len); + if (len <= buf.length) { int actLen = IO.readFully(is, buf, 0); return insert(type, buf, 0, actLen); |