Я собираюсь работать с другими людьми над кодом из проекта, который использует cvs. Мы хотим использовать распределенный vcs для выполнения нашей работы, и когда мы закончим или, может быть, время от времени, мы хотим зафиксировать наш код и всю нашу историю изменений в cvs. У нас нет доступа на запись в репозиторий cvs проекта, поэтому мы не можем коммитить очень часто. Какой инструмент мы можем использовать для экспорта нашей истории изменений в cvs? В настоящее время мы думали об использовании git или mercurial, но мы могли бы использовать другой распределенный виртуальный компьютер, если это упростит экспорт.
100
Ответы:
К счастью для тех из нас, кто все еще вынужден использовать CVS, git предоставляет довольно хорошие инструменты, чтобы делать именно то, что вы хотите. Мои предложения (и что мы делаем здесь, в $ work):
Создание исходного клона
Используйте
git cvsimport
для клонирования истории ревизий CVS в репозиторий git. Я использую следующий вызов:Этот
-A
параметр не является обязательным, но он помогает сделать вашу историю изменений, импортированную из CVS, более похожей на git (см.man git-cvsimport
Дополнительную информацию о том, как это настроить).В зависимости от размера и истории репозитория CVS, этот первый импорт займет ОЧЕНЬ много времени. Вы можете добавить -v к приведенной выше команде, если хотите быть уверенными в том, что что-то действительно происходит.
Когда этот процесс будет завершен, у вас будет
master
ветка, которая должна отражать HEAD CVS (за исключением того, чтоgit cvsimport
по умолчанию игнорирует последние 10 минут коммитов, чтобы не поймать наполовину завершенный коммит). Затем вы можете использоватьgit log
и друзей, чтобы изучить всю историю репозитория, как если бы он использовал git с самого начала.Настройки конфигурации
Есть несколько настроек конфигурации, которые упростят инкрементный импорт из CVS (а также экспорт) в будущем. Они не задокументированы на
git cvsimport
странице руководства, поэтому я предполагаю, что они могут быть изменены без предварительного уведомления, но FWIW:Все эти параметры можно указать в командной строке, поэтому вы можете спокойно пропустить этот шаг.
Инкрементальный импорт
Последующий
git cvsimport
вызов должен быть намного быстрее, чем первый вызов. Однако он выполняет операцию дляcvs rlog
каждого каталога (даже для тех, в которых есть только файлыAttic
), поэтому это может занять несколько минут. Если вы указали предложенные выше конфигурации, все, что вам нужно сделать, это выполнить:Если вы не настроили свои конфигурации, чтобы указать значения по умолчанию, вам нужно указать их в командной строке:
В любом случае, нужно помнить о двух вещах:
cvsimport
что снова займет вечность.master
ветке, чтобы изменения можно было объединить (или переназначить) в локальные / тематические ветки.Внесение локальных изменений
На практике я рекомендую всегда вносить изменения в ветки и выполнять слияние только
master
тогда, когда вы будете готовы экспортировать эти изменения обратно в репозиторий CVS. Вы можете использовать любой рабочий процесс, который вам нравится, в своих ветках (слияние, ребазирование, сжатие и т. Д.), Но, конечно, применяются стандартные правила переназначения: не переназначайте, если кто-то еще основывал свои изменения на вашей ветке.Экспорт изменений в CVS
Команда
git cvsexportcommit
позволяет вам экспортировать одиночный коммит на сервер CVS. Вы можете указать один идентификатор фиксации (или что-нибудь, что описывает конкретную фиксацию, как определено вman git-rev-parse
). Затем создается diff, применяется к проверке CVS и затем (необязательно) передается в CVS с использованием реальногоcvs
клиента. Вы можете экспортировать каждую микрокоммит в свои тематические ветки, но обычно мне нравится создавать коммит слияния в актуальном состоянииmaster
и экспортировать этот единственный коммит слияния в CVS. Когда вы экспортируете коммит слияния, вы должны указать git, какой родительский коммит использовать для генерации diff. Кроме того, это не сработает, если ваше слияние было перемоткой вперед (см. Раздел «КАК РАБОТАЕТ СЛИЯНИЕ»man git-merge
для описания слияния с перемоткой вперед), поэтому вы должны использовать--no-ff
вариант при выполнении слияния. Вот пример:Вы можете увидеть, что означает каждый из этих параметров, на странице руководства для git-cvsexportcommit . У вас есть возможность установить этот
-w
параметр в конфигурации git:Если патч не работает по какой-либо причине, мой опыт показывает, что вам (к сожалению), вероятно, будет лучше скопировать измененные файлы вручную и зафиксировать с помощью клиента cvs. Однако этого не должно происходить, если вы убедитесь, что у вас установлена
master
последняя версия CVS, прежде чем объединять тематическую ветку в.Если фиксация не удалась по какой-либо причине (проблемы с сетью / разрешениями и т. Д.), Вы можете взять команду, напечатанную на вашем терминале в конце сообщения об ошибке, и выполнить ее в своем рабочем каталоге CVS. Обычно это выглядит примерно так:
В следующий раз, когда вы сделаете
git cvsimport
(ожидая не менее 10 минут), вы увидите, что патч экспортированного коммита повторно импортирован в ваш локальный репозиторий. У них будут разные идентификаторы фиксации, так как фиксация CVS будет иметь другую метку времени и, возможно, другое имя коммиттера (в зависимости от того, настроили ли вы файл авторов в исходномcvsimport
выше).Клонирование вашего клона CVS
Если у вас есть несколько человек, которые должны сделать это
cvsimport
, было бы более эффективно иметь один репозиторий git, который выполняет cvsimport, а все остальные репозитории созданы как клоны. Это работает отлично, и клонированный репозиторий может выполнять cvsexportcommit, как описано выше. Однако есть один нюанс. Из-за того, что коммиты CVS возвращаются с разными идентификаторами коммитов (как описано выше), вы не хотите, чтобы ваша клонированная ветка отслеживала центральный репозиторий git. По умолчаниюgit clone
ваш репозиторий настраивается так, но это легко исправить:После того, как вы удалили эти конфигурации, вам нужно будет явно указать, где и что извлекать, когда вы хотите получить новые коммиты из центрального репозитория:
В целом, я обнаружил, что этот рабочий процесс вполне управляем, и «следующая лучшая вещь» при полном переходе на git непрактична.
источник
git cvsimport
Debian, попробуйтеapt-get install git-cvs
Initialized empty Git repository in /Users/gus/projects/foo/foobar/.git/ Can't exec "cvsps": No such file or directory at /Applications/Xcode.app/Contents/Developer/usr/libexec/git-core/git-cvsimport line 777. Could not start cvsps: No such file or directory git cvsimport: fatal: cvsps reported error
Так что, к сожалению, это не поможет вам обойтись без CVS :(Вы не должны слепо доверять cvsimport и проверять, совпадает ли импортированное дерево с тем, что находится в репозитории CVS. Я сделал это, поделившись новым проектом с помощью подключаемого модуля eclipse CVS, и обнаружил несоответствия ..
Две фиксации, которые были выполнены менее чем за минуту с одним и тем же сообщением фиксации (для восстановления ошибочно удаленного файла), были сгруппированы в одну большую фиксацию, что привело к отсутствию файла в дереве ..
Мне удалось решить эту проблему, изменив параметр «fuzz» до менее чем минуты.
пример:
Итог: проверьте свое дерево после импорта
источник
В дополнение к ответу Брайана Филлипса: есть также git-cvsserver, который работает как сервер CVS, но фактически обращается к репозиторию git ... но имеет некоторые ограничения.
источник