Page MenuHomePhabricator

Use "--whitespace nowarn" in `arc patch` to respect trailing whitespace
ClosedPublic

Authored by epriestley on Dec 18 2015, 12:18 AM.
Tags
None
Referenced Files
F19889582: D14816.diff
Tue, Mar 24, 4:59 PM
F19850838: D14816.id.diff
Mar 12 2026, 10:10 PM
F19755489: D14816.id.diff
Feb 17 2026, 4:50 PM
F19716711: D14816.diff
Feb 12 2026, 11:59 AM
F19648688: D14816.id35822.diff
Feb 6 2026, 6:22 AM
F19565778: D14816.id.diff
Jan 31 2026, 6:37 PM
F19354157: D14816.id35822.diff
Dec 26 2025, 5:55 AM
F18854006: D14816.id35822.diff
Oct 31 2025, 9:28 PM
Subscribers
None
Tokens
"Mountain of Wealth" token, awarded by joshuaspence.

Details

Summary

Fixes T10008. Git tries to fix some issues by default (apparently? empirically; not consistent with documentation, I think?), but patches from arc patch are "always" accurate (disregarding other bugs we might have -- basically, they haven't been emailed or copy/pasted or anything like that) so we can just tell it to apply the patch exactly as-is.

Test Plan

Screen Shot 2015-12-17 at 4.16.53 PM.png (138×683 px, 28 KB)

Diff Detail

Repository
rARC Arcanist
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

icat is this little "invisible cat" (show whitespace, etc) script:

icat
#!/usr/bin/env php
<?php

if ($argc > 1) {
  $args = array_slice($argv, 1);
} else {
  $args = array('php://stdin');
}

foreach ($args as $arg) {
  $data = file_get_contents($arg);
  for ($ii = 0; $ii < strlen($data); $ii++) {
    $s = $data[$ii];
    $n = isset($data[$ii + 1]) ? $data[$ii + 1] : null;
    $c = ord($s);
    if ($c >= 33 && $c <= 127) {
      echo $s;
    } else if ($s == "\r") {
      echo special(' \\r ');
      if ($n !== "\n") {
        echo "\n";
      }
    } else if ($s == "\n") {
      echo special(' \\n ')."\n";
    } else if ($s == "\t") {
      echo special(' \\t ');
    } else if ($s == ' ') {
      echo under(' ');
    } else {
      echo special('\\x'.sprintf('%02x', $c));
    }
  }
  echo "\n";
}

function special($x) {
  return chr(27).'[7m'.$x.chr(27).'[m';
}

function under($x) {
  return chr(27).'[31m'.chr(27).'[4m'.$x.chr(27).'[m'.chr(27).'[39m';
}
chad edited edge metadata.
This revision is now accepted and ready to land.Dec 18 2015, 1:31 AM
joshuaspence edited edge metadata.
joshuaspence awarded a token.
This revision was automatically updated to reflect the committed changes.