Почему мой мерзавец вдруг волшебным образом способен показывать текстовые различия для файлов PDF?
У меня есть мерзавец версия 2.17.0.windows.1
на моем компьютере с Windows 10. Насколько я знаю, git не должен быть в состоянии различать pdf файлы из коробки. Я всегда ожидал, что сообщение diff просто скажет что-то вроде "Двоичные файлы a.pdf и b.pdf отличаются".
Поэтому я был удивлен, увидев, что консоль распечатывает это однажды в репозитории с обновленным pdf-файлом:
diff --git a/assign6.pdf b/assign6.pdf
index 6e6e292..cf8f0bc 100644
--- a/assign6.pdf
+++ b/assign6.pdf
@@ -6,7 +6,7 @@
Late Date: NO LATE
- November 10, 2018
+ November 26, 2018
This assignment introduces tasks with public members, direct communication and high-level techniques for structuring
complex interactions among tasks (versus monitor and semaphore structuring approaches). Use it to become familiar
Я знаю, что есть способ показать читаемые человеком разностные файлы для двоичных файлов, используя параметр textconv в gitconfig и атрибуты diff для определенных расширений файлов в gitattributes, но я, конечно, не сделал ничего подобного для своего компьютера. Я просто установил git с помощью программы установки exe, и с тех пор я не изменил никаких настроек конфигурации.
Это то, что git config --list
показывает, когда внутри этой папки:
core.symlinks=false
core.autocrlf=false
core.fscache=true
color.diff=auto
color.status=auto
color.branch=auto
color.interactive=true
help.format=html
rebase.autosquash=true
http.sslcainfo=C:/Program Files/Git/mingw64/ssl/certs/ca-bundle.crt
http.sslbackend=openssl
diff.astextplain.textconv=astextplain
filter.lfs.clean=git-lfs clean -- %f
filter.lfs.smudge=git-lfs smudge -- %f
filter.lfs.process=git-lfs filter-process
filter.lfs.required=true
credential.helper=manager
user.email={{super secret email}}
user.name={{super secret username}}
core.pager=less
core.autocrlf=false
core.whitespace=cr-at-eol
color.ui=auto
core.repositoryformatversion=0
core.filemode=false
core.bare=false
core.logallrefupdates=true
core.symlinks=false
core.ignorecase=true
remote.origin.url={{super secret url}}
remote.origin.fetch=+refs/heads/*:refs/remotes/origin/*
branch.master.remote=origin
branch.master.merge=refs/heads/master
Сначала я думал, что это была какая-то новая необычная функция, которая была недавно добавлена в git, но когда я попробовал diff на машине с Ubuntu 16.04 с версией git 2.19.0
Вот что распечатала консоль:
diff --git a/assign6.pdf b/assign6.pdf
index 6e6e292..cf8f0bc 100644
Binary files a/assign6.pdf and b/assign6.pdf differ
Так... не похоже на это?
Тогда откуда взялся этот магический единорог pdf diff? Где это настроено?
1 ответ
Поскольку Git для Windows 2.18 упоминает
Фильтр diff для файлов.pdf был исправлен.
Само собой разумеется, что 2.17 включил diff фильтр вместо pdf.
Вы можете увидеть его настройки в git-for-windows / build-extra /.