src/com/gitblit/utils/GitBlitDiffFormatter.java | ●●●●● patch | view | raw | blame | history | |
src/com/gitblit/utils/GitWebDiffFormatter.java | ●●●●● patch | view | raw | blame | history | |
tests/com/gitblit/tests/GitServletTest.java | ●●●●● patch | view | raw | blame | history |
src/com/gitblit/utils/GitBlitDiffFormatter.java
@@ -15,11 +15,14 @@ */ package com.gitblit.utils; import static org.eclipse.jgit.lib.Constants.encode; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.OutputStream; import org.eclipse.jgit.diff.RawText; import org.eclipse.jgit.util.RawParseUtils; /** * Generates an html snippet of a diff in Gitblit's style. @@ -86,11 +89,9 @@ break; } os.write(prefix); ByteArrayOutputStream bos = new ByteArrayOutputStream(); text.writeLine(bos, cur); String line = bos.toString(); String line = text.getString(cur); line = StringUtils.escapeForHtml(line, false); os.write(line.getBytes()); os.write(encode(line)); switch (prefix) { case '+': case '-': @@ -110,7 +111,8 @@ */ @Override public String getHtml() { String html = os.toString(); ByteArrayOutputStream bos = (ByteArrayOutputStream) os; String html = RawParseUtils.decode(bos.toByteArray()); String[] lines = html.split("\n"); StringBuilder sb = new StringBuilder(); boolean inFile = false; src/com/gitblit/utils/GitWebDiffFormatter.java
@@ -15,6 +15,7 @@ */ package com.gitblit.utils; import static org.eclipse.jgit.lib.Constants.encode; import static org.eclipse.jgit.lib.Constants.encodeASCII; import java.io.ByteArrayOutputStream; @@ -23,6 +24,7 @@ import org.eclipse.jgit.diff.DiffFormatter; import org.eclipse.jgit.diff.RawText; import org.eclipse.jgit.util.RawParseUtils; /** * Returns an html snippet of the diff in the standard Gitweb style. @@ -111,11 +113,9 @@ break; } os.write(prefix); ByteArrayOutputStream bos = new ByteArrayOutputStream(); text.writeLine(bos, cur); String line = bos.toString(); String line = text.getString(cur); line = StringUtils.escapeForHtml(line, false); os.write(line.getBytes()); os.write(encode(line)); switch (prefix) { case '+': case '-': @@ -133,7 +133,8 @@ * @return */ public String getHtml() { String html = os.toString(); ByteArrayOutputStream bos = (ByteArrayOutputStream) os; String html = RawParseUtils.decode(bos.toByteArray()); String[] lines = html.split("\n"); StringBuilder sb = new StringBuilder(); sb.append("<div class=\"diff\">"); tests/com/gitblit/tests/GitServletTest.java
@@ -13,6 +13,7 @@ import org.eclipse.jgit.api.CloneCommand; import org.eclipse.jgit.api.Git; import org.eclipse.jgit.lib.Constants; import org.eclipse.jgit.transport.UsernamePasswordCredentialsProvider; import org.eclipse.jgit.util.FileUtils; import org.junit.AfterClass; @@ -113,9 +114,9 @@ public void testAnonymousPush() throws Exception { Git git = Git.open(ticgitFolder); File file = new File(ticgitFolder, "TODO"); OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file, true)); OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file, true), Constants.CHARSET); BufferedWriter w = new BufferedWriter(os); w.write("// " + new Date().toString() + "\n"); w.write("// hellol中文 " + new Date().toString() + "\n"); w.close(); git.add().addFilepattern(file.getName()).call(); git.commit().setMessage("test commit").call(); @@ -136,7 +137,7 @@ Git git = Git.open(jgitFolder); File file = new File(jgitFolder, "TODO"); OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file, true)); OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file, true), Constants.CHARSET); BufferedWriter w = new BufferedWriter(os); w.write("// " + new Date().toString() + "\n"); w.close(); @@ -159,7 +160,7 @@ Git git = Git.open(jgit2Folder); File file = new File(jgit2Folder, "NONBARE"); OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file, true)); OutputStreamWriter os = new OutputStreamWriter(new FileOutputStream(file, true), Constants.CHARSET); BufferedWriter w = new BufferedWriter(os); w.write("// " + new Date().toString() + "\n"); w.close();