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
Unknown Object (File)
Mon, Sep 9, 6:28 PM
Unknown Object (File)
Thu, Sep 5, 5:58 PM
Unknown Object (File)
Thu, Sep 5, 5:58 PM
Unknown Object (File)
Thu, Sep 5, 5:58 PM
Unknown Object (File)
Mon, Sep 2, 2:51 AM
Unknown Object (File)
Wed, Aug 28, 5:11 PM
Unknown Object (File)
Sat, Aug 24, 4:06 PM
Unknown Object (File)
Thu, Aug 22, 8:36 AM
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.