Есть какие-нибудь советы по использованию Subversion с файлами проекта .net?

Мы только что перешли с TFS на SVN, и пока нам это нравится.

Однако при этом появилось несколько новых проблем.

Один из них - это способ обработки файлов проекта (в частности, .vbproj). Файл .vbproj, конечно, всегда меняется по мере изменения файлов и ссылок, и если несколько человек будут сотрудничать, возникнут конфликты.

Как ни странно, в TFS нам никогда не приходилось иметь дело с управлением этими конфликтами, эта конкретная часть обрабатывалась автоматически. Теперь в SVN мы просматриваем XML в инструменте слияния, и уже были некоторые ошибки.

Как ты с этим справишься? Какие-нибудь советы?

Обновлено:, кстати, мы используем VisualSVN.

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
3
0
3 583
7
Перейти к ответу Данный вопрос помечен как решенный

Ответы 7

Эта конкретная проблема возникает, если несколько разработчиков добавляют файлы в один и тот же проект.

Чтобы разрешить конфликт, когда несколько разработчиков добавили файлы в один и тот же проект, вы обычно можете заставить его работать, разрешив его с помощью опции «мой, прежде чем их». Он добавит оба ваших изменения вместе.

Эта проблема и другие проблемы слияния решаются частым коммитом и обновлением. По возможности фиксируйте один раз в день или чаще. Чем дольше вы будете обходиться без обновлений и фиксации, тем больше боли вы и ваша команда почувствуете.

Как насчет объединения веток? Здесь мы всегда чувствуем боль.

Mike Cole 02.03.2011 18:21

Вам нужен достойный клиент, такой как Toroise. Иногда возникают конфликты при автоматическом слиянии, но у ive никогда не было конфликтов с .vbproj, и их очень легко исправить с помощью программы diff.

id использует _svn вместо .svn, по нескольким причинам, я не могу вспомнить, почему сейчас не в моей голове, но "." причинил мне горе.

убедитесь, что вы не фиксируете файлы .user и .suo, иначе вы будете продолжать получать друг от друга настройки VS для проекта, что будет раздражать!

Вы также можете получить клиентские надстройки для VS, такие как ankh и visual svn, ive только немного использовал ankh, но это было немного медленно, но, вероятно, это была ошибка моего ПК.

_svn vs .svn - это совместимость с ASP.NET.

wasker 08.11.2008 21:41

Если быть более точным, _svn требуется только при использовании Visual Studio .NET или Visual Studio .NET 2003, 2005 и более поздних версий.

Sander Rijken 01.12.2008 02:21
Ответ принят как подходящий

В SVN основные проблемы с файлами * proj возникают, когда люди перемещают файлы в разные папки и / или когда они добавляют и удаляют файлы с одинаковыми именами одновременно, обычно в начале проекта.

Как только имена файлов и структура проекта станут более стабильными, этого больше не произойдет.

Кроме того, включайте только файлы .sln и .vbproj, не включайте постоянно меняющиеся файлы .suo, чтобы уменьшить головную боль.

Обычно мы обновляем * файл proj + добавляем или перемещаем заглушку файла + фиксируем все сразу. Сделайте операцию как можно более атомарной, а продолжительность - как можно короче.

Вы уверены, что файл вашего проекта не помечен как двоичный? Если ваш файл .vbproj имеет свойство svn: mime-type со значением, которое не начинается с 'text /', автоматическое слияние субверсий будет отключено.

Когда пару лет назад мы перешли с VSS, большинство файлов проекта были помечены как двоичные. Удаление свойств MIME-типа устраняет большинство конфликтных ситуаций.

Попробуйте VisualSVN. Он работает вместе с TortoiseSVN, чтобы управлять всем за вас и интегрировать функциональность Subversion с Visual Studio. Он также настраивает svn: ignore для пользовательских файлов проекта и двоичных файлов, чтобы сохранить их в репозитории. Стоит затраченных усилий.

Да, VisualSVN - это то, что вам нужно.

Brian MacKay 15.02.2011 01:40

Мне тоже нравится VisualSVN (по крайней мере, до тех пор, пока я не переключился на Mercurial), но, как предлагает Майк С. в комментарии к моему ответу, это не ответ на заданный OP более конкретный вопрос относительно конфликтов слияния в проекте на основе .NET XML. файлы.

David Cuccia 07.03.2011 04:02

Попробуйте АнхСВН. Очень доволен версией 2. Изначально он игнорирует файлы .suo и т. д., Работает безупречно с VS 2008, и это бесплатно !!

Как это отвечает на заданный вопрос?

Mike Cole 02.03.2011 18:20

Хорошая точка зрения. Похоже, я ответил на вопрос заголовка, а не на тот, который встроен в тело. Последовал за ответом X-Cubed, как мотылек на пламя. Предположим, заголовок должен быть больше похож на «Какие-нибудь советы по разрешению конфликтов слияния проектов .NET с помощью инструментов на основе Subversion?»

David Cuccia 07.03.2011 04:00

Другие вопросы по теме