mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-22 20:51:09 +01:00
Strip colorized diffs, show line numbers in context
Summary: - When users pipe in colorized diffs, strip the colors instead of failing. - When showing context, show line numbers (we do show 3 lines around the failure, the failure was just on the first line). - Remove an irrelevant TODO comment (we handle this elsewhere now). Test Plan: Unit tests. Reviewers: Makinde, btrahan Reviewed By: Makinde CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1887
This commit is contained in:
parent
7494a95c40
commit
f673ab10b1
3 changed files with 39 additions and 2 deletions
|
@ -936,12 +936,37 @@ final class ArcanistDiffParser {
|
|||
}
|
||||
|
||||
protected function didStartParse($text) {
|
||||
// TODO: Removed an fb_utf8ize() call here. -epriestley
|
||||
|
||||
// Eat leading whitespace. This may happen if the first change in the diff
|
||||
// is an SVN property change.
|
||||
$text = ltrim($text);
|
||||
|
||||
// Try to strip ANSI color codes from colorized diffs. ANSI color codes
|
||||
// might be present in two cases:
|
||||
//
|
||||
// - You piped a colorized diff into 'arc --raw' or similar (normally
|
||||
// we're able to disable colorization on diffs we control the generation
|
||||
// of).
|
||||
// - You're diffing a file which actually contains ANSI color codes.
|
||||
//
|
||||
// The former is vastly more likely, but we try to distinguish between the
|
||||
// two cases by testing for a color code at the beginning of a line. If
|
||||
// we find one, we know it's a colorized diff (since the beginning of the
|
||||
// line should be "+", "-" or " " if the code is in the diff text).
|
||||
//
|
||||
// While it's possible a diff might be colorized and fail this test, it's
|
||||
// unlikely, and it covers hg's color extension which seems to be the most
|
||||
// stubborn about colorizing text despite stdout not being a TTY.
|
||||
//
|
||||
// We might incorrectly strip color codes from a colorized diff of a text
|
||||
// file with color codes inside it, but this case is stupid and pathological
|
||||
// and you've dug your own grave.
|
||||
|
||||
$ansi_color_pattern = '\x1B\[[\d;]*m';
|
||||
if (preg_match('/^'.$ansi_color_pattern.'/m', $text)) {
|
||||
$text = preg_replace('/'.$ansi_color_pattern.'/', '', $text);
|
||||
}
|
||||
|
||||
$this->text = explode("\n", $text);
|
||||
$this->line = 0;
|
||||
}
|
||||
|
@ -981,8 +1006,9 @@ final class ArcanistDiffParser {
|
|||
$context = '';
|
||||
for ($ii = $min; $ii <= $max; $ii++) {
|
||||
$context .= sprintf(
|
||||
"%8.8s %s\n",
|
||||
"%8.8s %6.6s %s\n",
|
||||
($ii == $this->line) ? '>>> ' : '',
|
||||
$ii + 1,
|
||||
$this->text[$ii]);
|
||||
}
|
||||
|
||||
|
|
|
@ -38,6 +38,9 @@ final class ArcanistDiffParserTestCase extends ArcanistPhutilTestCase {
|
|||
$changes = $parser->parseDiff($contents);
|
||||
|
||||
switch ($file) {
|
||||
case 'colorized.hggitdiff':
|
||||
$this->assertEqual(1, count($changes));
|
||||
break;
|
||||
case 'basic-missing-both-newlines-plus.udiff':
|
||||
case 'basic-missing-both-newlines.udiff':
|
||||
case 'basic-missing-new-newline-plus.udiff':
|
||||
|
|
8
src/parser/diff/__tests__/data/colorized.hggitdiff
Normal file
8
src/parser/diff/__tests__/data/colorized.hggitdiff
Normal file
|
@ -0,0 +1,8 @@
|
|||
[0;1mdiff --git a/FILE b/FILE[0m
|
||||
[0;31;1m--- a/FILE[0m
|
||||
[0;32;1m+++ b/FILE[0m
|
||||
[0;35m@@ -1,3 +1,4 @@[0m
|
||||
asdf
|
||||
asdf
|
||||
quack
|
||||
[0;32m+z[0m
|
Loading…
Reference in a new issue