Run prettify on the server using whole file contents
By executing prettify over the entire file contents, rather than on a single line at a time, we can be certain that multi-line comments and strings are rendered correctly all of the time, even if it starts or ends within a hidden context region. With this change we move prettify to run only on the server, within the Mozilla Rhino JavaScript engine, and send to the client only fully formatted HTML line arrays for the two files. Like before, the server only sends partial arrays, letting the client piece it all together at display time. In a future commit I plan to have the client format the file if we are showing all lines from both sides. This way the RPC response payload is smaller, and the server can offload the parsing and formatting load to some clients. While writing this change I considered using Pygments running inside of Jython, but chose to stick with prettify in Rhino. Pygments ran much slower for the same small file contents, and doesn't leave us with the option to execute formatting on the client side. As part of this change we now use the Mozilla chardet library to detect the character set of the file contents we are about to render as HTML. The chardet library is the same logic used inside of the Mozilla browser family to detect the character set when it isn't specified... so its pretty accurate for a wide range of files. In the future we should also start to honor .gitattributes to get the encoding. Bug: issue 250 Bug: issue 251 Change-Id: I155bb7abc560f01a3597b3be678a76a5aa7f9e68 Signed-off-by: Shawn O. Pearce <sop@google.com>
This commit is contained in:
		| @@ -14,14 +14,30 @@ | ||||
|  | ||||
| package com.google.gerrit.server.patch; | ||||
|  | ||||
| import com.google.gerrit.common.data.SparseFileContent; | ||||
|  | ||||
| import org.eclipse.jgit.diff.RawText; | ||||
| import org.eclipse.jgit.lib.Constants; | ||||
| import org.eclipse.jgit.util.RawParseUtils; | ||||
| import org.mozilla.universalchardet.UniversalDetector; | ||||
|  | ||||
| import java.io.UnsupportedEncodingException; | ||||
|  | ||||
| public class Text extends RawText { | ||||
|   public static final Text EMPTY = new Text(new byte[0]); | ||||
|   public static final byte[] NO_BYTES = {}; | ||||
|   public static final Text EMPTY = new Text(NO_BYTES); | ||||
|  | ||||
|   public static String asString(byte[] content, String encoding) | ||||
|       throws UnsupportedEncodingException { | ||||
|     if (encoding == null) { | ||||
|       UniversalDetector d = new UniversalDetector(null); | ||||
|       d.handleData(content, 0, content.length); | ||||
|       d.dataEnd(); | ||||
|       encoding = d.getDetectedCharset(); | ||||
|     } | ||||
|     if (encoding == null) { | ||||
|       encoding = "ISO-8859-1"; | ||||
|     } | ||||
|     return new String(content, encoding); | ||||
|   } | ||||
|  | ||||
|   public Text(final byte[] r) { | ||||
|     super(r); | ||||
| @@ -39,8 +55,4 @@ public class Text extends RawText { | ||||
|     } | ||||
|     return RawParseUtils.decode(Constants.CHARSET, content, s, e); | ||||
|   } | ||||
|  | ||||
|   public void addLineTo(final SparseFileContent out, final int i) { | ||||
|     out.addLine(i, getLine(i)); | ||||
|   } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Shawn O. Pearce
					Shawn O. Pearce