Изменения

Перейти к: навигация, поиск

Сравнение DVCS - несколько задач

990 байтов добавлено, 12:06, 26 ноября 2009
Git
=== Git ===
'''Git''': очень хорошо отлично (5-)! <tt>[http://git-svn.yhbt.net/ git-svn]</tt> встроен в git и умеет всё, что нужно: клонирование, синхронизация (<tt>fetch</tt>, <tt>pull</tt> или <tt>merge</tt>), фиксация изменений в Subversion-репозиториях (<tt>dcommit</tt>) и <tt>rebase</tt> работают с сохранением веток и меток, причём стандартная схема их именования <tt>trunk/branches/tags</tt> не является обязательной. Ветки SVN импортируются как [http://www.gitready.com/beginner/2009/03/09/remote-tracking-branches.html Remote Tracking Branches]. Можно начинать историю ветки в git’е не с сотворения миров, а с любого момента. Также <tt>git-svn</tt> поддерживает подключаемые внешние репозитории Subversion (т. н. [http://svnbook.red-bean.com/en/1.0/ch07s03.html Externals]). Граф ветвлений сохраняется, хоть и не так круто, как в Mercurial’е. В общем, можно сказать, что функционал фактически полон. Как всегда с Git’ом, есть различные нетривиальности, что-то бывает нужно настроить (''гитара настроена? нас двое, на! играй, на!''), синтаксис не совмещён с обычными командами Git — то есть например для синхронизации копии с Subversion нужно сказать не <tt>git pull</tt>, а <tt>git svn fetch</tt>, посему всё-таки 5-, а не твёрдое 5. Кстати, проходит (пока ещё проходит, продолжаясь уже пару дней) очень мощный тест — полное клонирование [http://svn.wikimedia.org/ SVN-репозитория Wikimedia]. Пару раз прерывалось из-за каких-то сетевых катаклизмов, но по <tt>git svn fetch</tt> успешно возобновлялось.
=== Bazaar ===

Навигация