Можно ли запустить vimdiff для git diffs на вкладке текущего процесса?
Скажем, у меня открыт файловый буфер и :terminal
разделен на одну вкладку. Я хотел бы создать новую вкладку, на которой я бегу, vimdiff
но показывает мой git diff. Я пытаюсь появиться git difftool HEAD~1
в моем текущем процессе vim, просто на другой странице вкладки.
Возможно ли это на Vim 8 без плагинов?
У меня возникает иллюзия, когда я это делаю, :tab terminal
а потом убегаю git difftool HEAD~1
. Однако это запускает подпроцесс vim, и я бы хотел этого избежать.
Что-то вроде этого вопроса: как мне войти в режим vimdiff, если два разделения уже открыты? но для git diffs.
Ответы
Хотя это, безусловно, можно сделать в ванили vim
, я предлагаю вам взглянуть на отличный vim-fugitiveплагин tpope . Тогда вам просто нужно сделать, :tab Gdiff
чтобы получить то, что вы хотите.
Если вы действительно не хотите устанавливать какие-либо плагины, следующее может работать, если текущий файл находится в буфере №. 1:
:tabnew | r! git show HEAD^:$(git rev-parse --show-prefix)#1:t
- Во вновь открытой вкладке
:vert sb 1 | windo diffthis
Объяснение
- сначала открывает новую вкладку
tabnew
и загружаетHEAD^
в нее содержимое версии файла из буфера 1. - открывает вертикальное разделение, содержащее буфер 1 с
vert sb 1
, затем выдает:diffthis
все буферы на вкладке для перехода в режим сравнения.
Редактировать
OP запросил дополнительные объяснения на шаге 1. git show
требуется ввод формы, <rev>:<path>
где <path>
он должен быть относительно корня рабочего дерева. Например, если абсолютный путь к файлу в буфере 1 /a/b/foo.ext
таков, что он b
содержит вашу .git
папку (то есть b
является корнем вашего репо), для git show
правильной работы вам нужно будет вызвать его с помощью HEAD^:b/foo.e
. Использование любого из них /a/b/foo.ext
или foo.ext
не сработает. Поэтому я использовал git rev-parse --show-prefix
для получения пути к текущей папке относительно корня git (который был бы b/
) в этом примере.
Затем я использовал vim
расширение пути, чтобы добавить имя файла (то есть foo.ext
). #1
сообщает, что vim
нужно получить путь к любому файлу, загруженному в буфер 1, и :t
извлекает "хвост", который представляет собой все, что находится после последнего /
в пути, возвращаемом #1
. В некоторых случаях #1
и #1:t
равны, но это не всегда так. Например, если вы побежали, vim b/foo.ext
то #1
вернетесь, b/foo.ext
а не просто foo.ext
. Проверьте :help expand
для получения дополнительной информации.
Конечно, вы можете просто ввести путь вручную, как в :tabnew | r! git show HEAD^:b/foo.ext
, и это сработает. Но версия, приведенная выше, поддерживает скрипт или вы можете назначить ее на карту.