Почему я получаю конфликты деревьев в Subversion?
У меня была ветвь функций моего ствола, и я периодически сливал изменения из моего ствола в мою ветку, и все работало нормально. Сегодня я пошел, чтобы слить ветку обратно в ствол, и все файлы, которые были добавлены в мою ствол после создания моей ветки, были помечены как "конфликт дерева". Есть ли способ избежать этого в будущем?
Я не думаю, что они должным образом помечены.
11 ответов
Я нашел решение, прочитав ссылку, которую дал Гари (и я предлагаю пойти по этому пути).
Подводя итог, чтобы разрешить конфликт дерева, фиксируя ваш рабочий каталог с клиентом SVN 1.6.x, вы можете использовать:
svn resolve --accept working -R .
где .
каталог в конфликте.
ПРЕДУПРЕЖДЕНИЕ: "Подтверждение вашего рабочего каталога" означает, что ваша структура песочницы будет той, которую вы фиксируете, поэтому, если, например, вы удалили какой-то файл из своей песочницы, они также будут удалены и из репозитория. Это относится только к конфликтующей директории.
Таким образом, мы предлагаем SVN разрешить конфликт (--resolve
), принимая рабочую копию внутри вашей песочницы (--accept working
), рекурсивно (-R
), начиная с текущего каталога (.
).
В TortoiseSVN, выбрав "Resolved" при щелчке правой кнопкой мыши, фактически решается эта проблема.
Subversion 1.6 добавил Tree Conflicts для покрытия конфликтов на уровне каталогов. Хорошим примером может служить случай, когда вы локально удаляете файл, а затем обновление пытается внести изменение текста в этот файл. Другой случай, когда у вас есть subversion Rename файла, который вы редактируете, так как это действие Add/Delete.
В блоге CollabNet Subversion есть отличная статья о конфликтах деревьев.
По моему опыту, SVN создает конфликт дерева, КОГДА я удаляю папку. Кажется, нет никаких причин.
Я единственный, кто работает над моим кодом -> удалить каталог -> зафиксировать -> конфликт!
Я не могу дождаться, чтобы переключиться на Git.
Я должен уточнить - я использую Subclipse. Это, наверное, проблема! Снова, я не могу ждать, чтобы переключиться...
Я не знаю, происходит ли это с вами, но иногда я выбираю неправильный каталог для слияния и получаю эту ошибку, даже если все файлы выглядят совершенно нормально.
Пример:
Слияние /svn/Project/branch / some-branch / Исходники /svn/Project/trunk ---> Конфликт дерева
Объединить / svn / Project / филиалы /some-branch to /svn/Project/trunk ---> OK
Это может быть глупой ошибкой, но это не всегда очевидно, потому что вы думаете, что это что-то более сложное.
Здесь происходит следующее: вы создаете новый файл в своей стволе, а затем объединяете его со своей веткой. В коммит-слиянии этот файл будет создан и в вашей ветке.
Когда вы объединяете свою ветку обратно в ствол, SVN снова пытается сделать то же самое: он видит, что файл был создан в вашей ветке, и пытается создать его в вашей стволе в коммите слияния, но он уже существует! Это создает конфликт дерева.
Чтобы избежать этого, нужно сделать специальное слияние, реинтеграцию. Вы можете достичь этого с --reintegrate
переключатель.
Вы можете прочитать об этом в документации: http://svnbook.red-bean.com/en/1.7/svn.branchmerge.basicmerging.html
Однако при слиянии вашей ветви обратно в ствол базовая математика сильно отличается. Ваша ветвь функций теперь представляет собой путаницу как дублированных изменений ствола, так и изменений частной ветви, поэтому нет простого непрерывного диапазона ревизий для копирования. Указав параметр --reintegrate, вы просите Subversion тщательно реплицировать только те изменения, которые уникальны для вашей ветви. (И на самом деле, он делает это, сравнивая последнее ствол дерева с последним деревом ветвей: результирующая разница - это именно ваши изменения веток!)
После реинтеграции ветки настоятельно рекомендуется удалить ее, в противном случае вы будете продолжать получать конфликты деревьев при каждом слиянии в другом направлении: от ствола к вашей ветке. (По той же причине, что и описанная ранее.)
Есть способ обойти это тоже, но я никогда не пробовал. Вы можете прочитать это в этом посте: Реинтеграция ветки Subversion в v1.6
Это может быть вызвано тем, что клиенты не используют одни и те же версии.
Использование клиента версии 1.5 и клиента версии 1.6 в одном и том же хранилище может создать такую проблему. (Я только что укусил себя.)
До сегодняшнего дня, по крайней мере, 3 месяца назад, я регулярно сталкивался с сотнями конфликтов деревьев при попытке объединить ветку обратно в ствол (используя TortoiseSVN 1.11). Будь перебазирован или нет, кстати. Я использую TortoiseSVN начиная с его версии 1, еще в 2004 году, и я все время реинтегрировал ветки. Наверное, что-то случилось недавно?
Итак, сегодня я провел этот простой эксперимент и обнаружил, что создавало эти сумасшедшие конфликты:
- Я раздвоил багажник @393;
- Я изменял десятки файлов случайным образом, а также создавал новые;
- Я совершил. Теперь @395 (коллега раскошелился на 394, чтобы исполнить свои собственные вещи).
- Затем я попытался реинтегрировать ветку обратно в ствол, только тест; Следуя рекомендациям TortoiseSVN в мастере: "Чтобы объединить все ревизии (реинтегрировать), оставьте это поле пустым". Чтобы добиться этого, я щелкнул правой кнопкой мыши на папке ствола и выбрал "TortoiseSVN > Merge, from /path/to/branch", и я оставил диапазон оборотов пустым, как рекомендовано в диалоговом окне.
Обсуждение: (см. Вложение)
все ревизии... чего? Мало ли я знал, что клиент, должно быть, имел в виду " все ревизии цели! (Транк)", так как в процессе реинтеграции этой ветки я увидел упоминание "Слияние ревизий 1-HEAD"! О, МОЙ БОГ. Бедный дьявол, ты погиб здесь. Та ветка родилась @393, не могли бы вы прочитать свидетельство о рождении, ради бога?
Разрешение:
- Вопреки тому, что посоветовал волшебник, укажите диапазон, который охватывает ВСЕ пересмотры... жизни филиала! следовательно, 394-ГОЛОВА;
- Теперь снова запустите тест слияния и возьмите сигару. ( ).
Мораль: я не могу понять, почему они до сих пор не исправили эту ошибку, потому что это одна, извините. Я должен уделить время, чтобы сообщить об этом им.
Если вы сталкиваетесь с конфликтами деревьев, которые не имеют смысла, потому что вы не редактировали / не удаляли / не располагались где-либо рядом с файлом, также есть большая вероятность, что в команде слияния произошла ошибка.
Может случиться так, что вы ранее уже слили кучу изменений, которые вы включили в текущее слияние. Например, в транке кто-то отредактировал файл, а затем переименовал его. Если в ваше первое слияние вы включаете редактирование, а затем во второе слияние включаете и редактирование, и переименование (по сути, удаление), это также вызовет конфликт дерева. Причина этого заключается в том, что ранее объединенное редактирование отображается как ваше собственное, и поэтому удаление не будет выполняться автоматически.
Это может произойти по крайней мере в 1.4 репозиториях, я не уверен, поможет ли здесь слияние, введенное в 1.5.
У меня была похожая проблема. Единственное, что на самом деле мне помогло, - это удалить конфликтующие подкаталоги с помощью:
svn delete --force ./SUB_DIR_NAME
Затем скопируйте их снова из другого корневого каталога в рабочую копию, которая имеет их с:
svn copy ROOT_DIR_NAME/SUB_DIR_NAME
Тогда делай
svn cleanup
а также
svn add *
Вы можете получать предупреждения с последним, но просто игнорируйте их и, наконец,
svn ci .
Я столкнулся с этой проблемой и сегодня, хотя моя конкретная проблема, вероятно, не связана с вашей. Изучив список файлов, я понял, что сделал - я временно использовал файл в одной сборке из другой сборки. Я внес в него множество изменений и не хотел потерять связь с историей SVN, поэтому в своей ветке я переместил файл из папки другой сборки. Это не отслеживается SVN, поэтому похоже, что файл удален, а затем снова добавлен. Это приводит к конфликту деревьев.
Я решил проблему, переместив файл обратно, зафиксировав, а затем объединив свою ветку. Затем я переместил файл обратно потом.:) Это, казалось, добилось цели.
У меня была такая же проблема, и я решил ее заново, выполнив слияние с помощью этих инструкций. В основном, он использует SVN "слияние 2-URL" для обновления trunk
к текущему состоянию вашей ветви, не беспокоясь об истории и конфликтах деревьев. Спасло меня от ручного исправления 114 древовидных конфликтов.
Я не уверен, сохраняет ли она историю так, как хотелось бы, но в моем случае это стоило того.
Сценарий, с которым я иногда сталкиваюсь:
Предположим, у вас есть ствол, из которого вы создали ветку релиза. После некоторых изменений в стволе (в частности, создания каталога "some-dir"), вы создаете ветку Feature/ Fix, которую вы хотите позже объединить с веткой Release (поскольку изменения были достаточно малы, а функция / Fix важна для выпуска),
trunk -- ... -- create "some-dir" -- ...
\ \-feature/fix branch
\- release branch
Если вы затем попытаетесь объединить ветку feature/fix непосредственно с веткой release, вы получите конфликт дерева (даже если каталог не существовал даже в ветке feature/fix):
svn status
! C some-dir
> local missing or deleted or moved away, incoming file edit upon merge
Таким образом, вам нужно явно объединить коммиты, которые были сделаны в транке, перед созданием ветки feature/fix, которая создала каталог some-dir, перед слиянием ветки feature/fix.
Я часто забываю об этом, поскольку это не нужно в git.