Mercurial внутренний: слияние и конфликт двоичных файлов - PullRequest
3 голосов
/ 14 июня 2009

Ребята, я использую инструмент i nternal: merge , так как я не большой поклонник инструментов различного графического интерфейса. Мне действительно это нравится, и единственное, что я нахожу немного запутанным и не совсем удобным, это его поведение при конфликтах двоичных файлов.

Он не может объединять двоичные файлы и выходы, что абсолютно правильно. Однако в каталоге с конфликтующим файлом " foo " он создает только файл " foo.orig ".

Может ли он хотя бы создать " foo.other ", чтобы я мог выбрать, какую версию файла использовать (мою или извлеченную)?

P.S. Я задавал тот же вопрос в списке рассылки Mercurial, но никто не отвечал мне в течение нескольких дней, может, мне повезет больше:)

1 Ответ

4 голосов
/ 16 июня 2009

Вы уже получили некоторую информацию по вашему вопросу в списке рассылки Mercurial - я попытался сделать сценарий, предложенный в ветке. Прошло много времени с тех пор, как я использовал Subversion, но я думаю, что этот простой скрипт делает свое дело:

#!/bin/sh
cp "$1" "$1.mine"
cp "$2" "$1.base"
cp "$3" "$1.other"
false

Последняя команда false заставляет скрипт возвращать ненулевой код завершения, сообщая Mercurial, что слияние не удалось. Для Windows это выглядит так (спасибо Павел):

@copy %1 %1.mine
@copy %2 %1.base
@copy %3 %1.other
exit 1

Я сохранил версию Unix в ~/tmp/m.sh и попробовал ее без каких-либо других настроек слияния, кроме

[ui]
merge = ~/tmp/m.sh

Я сделал репозиторий с двумя головами, каждая с конфликтующим изменением в файл JPEG (mg.jpg). Я также добавил неконфликтующее изменение в текстовый файл (a.txt). Слияние дало:

% hg --debug merge
  searching for copies back to rev 1
resolving manifests
 overwrite None partial False
 ancestor 0848c2f8f8f8 local 845b8aa076bd+ remote f611c55aa8ec
 mg.jpg: versions differ -> m
 a.txt: versions differ -> m
preserving a.txt for resolve of a.txt
preserving mg.jpg for resolve of mg.jpg
picked tool '~/tmp/m.sh' for a.txt (binary False symlink False)
merging a.txt
my a.txt@845b8aa076bd+ other a.txt@f611c55aa8ec ancestor a.txt@0848c2f8f8f8
 premerge successful
picked tool '~/tmp/m.sh' for mg.jpg (binary True symlink False)
merging mg.jpg
my mg.jpg@845b8aa076bd+ other mg.jpg@f611c55aa8ec ancestor mg.jpg@0848c2f8f8f8
merging mg.jpg failed!
0 files updated, 1 files merged, 0 files removed, 1 files unresolved
use 'hg resolve' to retry unresolved file merges or 'hg up --clean' to abandon

Приятно то, что предварительное объединение может объединить a.txt само по себе, поэтому файлы a.txt.* не созданы:

% hg stat
M a.txt
M mg.jpg
? mg.jpg.base
? mg.jpg.mine
? mg.jpg.orig
? mg.jpg.other

Вероятно, вы можете доработать этот сценарий в соответствии с вашими потребностями - если вы это сделаете, подумайте о добавлении информации в вики Mercurial или, по крайней мере, опубликуйте результаты в списке рассылки.

...