Please accept output from "git diff --binary" as input
This bug was originally reported by Axel Beckert (abe@debian.org) in Debian bug #880109:
after the discussion around strip-nd's png backend, I tried
"strip-nondeterminism -t png t/fixtures/png/tEXt.png.in" in a checkout
of strip-nd's git repository.
Now the file t/fixtures/png/tEXt.png.in is locally modified:
→ git status --short
M t/fixtures/png/tEXt.png.in
I would like to be able to use diffoscope to show the difference between
the checked in version and the local (or staged) version of a binary
file.
So I tried
So I tried
→ git diff --binary | diffoscope
Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/diffoscope/main.py", line 412, in main
sys.exit(run_diffoscope(parsed_args))
File "/usr/lib/python3/dist-packages/diffoscope/main.py", line 377, in run_diffoscope
difference = load_diff(sys.stdin, "stdin")
File "/usr/lib/python3/dist-packages/diffoscope/readers/__init__.py", line 31, in load_diff
return JSONReaderV1().load(fp, path)
File "/usr/lib/python3/dist-packages/diffoscope/readers/json.py", line 32, in load
raw = json.load(fp)
File "/usr/lib/python3.6/json/__init__.py", line 299, in load
parse_constant=parse_constant, object_pairs_hook=object_pairs_hook, **kw)
File "/usr/lib/python3.6/json/__init__.py", line 354, in loads
return _default_decoder.decode(s)
File "/usr/lib/python3.6/json/decoder.py", line 339, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/usr/lib/python3.6/json/decoder.py", line 357, in raw_decode
raise JSONDecodeError("Expecting value", s, err.value) from None
json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)
but it bails out as shown above.
I can imagine three ways of calling diffoscope to provide such a
feature:
1) Maybe least effort, at least for diffoscope's CLI:
Make "git diff --binary | diffoscope" work, i.e. make it understand
git binary patches, at least while being inside the according git
repository (not sure if that's necessary).
2) Maybe even easier to implement (doesn't need to understand git binary
patches) and would contain a nice CLI:
diffoscope --git [file […]]
diffoscope --git --cached [file […]] (for staged changes)
3) Really super cool solution:
Provide a git diff plugin which outputs diffoscope output instead of
"Binary files a/t/fixtures/png/tEXt.png.in and
b/t/fixtures/png/tEXt.png.in differ". :-)
(That's the Pony I would like to have. :-)
Edited by Chris Lamb