Я работаю над командой на большом репо. Недавно мы решили перенести одну из папок в собственный подмодуль
-- aaa
-- .git
-- bbb
-- ccc
-- www # this folder is going into its own repo.
Я выполнил инструкции по отфильтровыванию папки www
в своем собственном репо, указанном здесь: Отсоединить (переместить) подкаталог в отдельный репозиторий Git. Я переместил папку www
из репо aaa
.
Я удалил каталог из основной ветки, выполнив следующие команды:
$ cd aaa
$ git checkout master
$ git rm -rf www
$ git commit -m "remove the www/ folder from the aaa repo."
Итак, теперь на мастере дерево выглядит следующим образом:
-- aaa
-- .git
-- bbb
-- ccc
Я хотел бы добавить www
в качестве подмодуля, выполнив:
$ cd aaa
$ git checkout master
$ git submodule add [email protected]:kevinburke/www.git www
Cloning into 'www'...
remote: Counting objects: 717, done.
remote: Compressing objects: 100% (392/392), done.
remote: Total 717 (delta 318), reused 711 (delta 317)
Receiving objects: 100% (717/717), 440.52 KiB | 58 KiB/s, done.
Resolving deltas: 100% (318/318), done.
Это отлично работает на хозяине. Однако, когда я пытаюсь переключиться на другую ветку, я получаю следующую ошибку:
$ cd aaa
$ git checkout other-old-branch
error: The following untracked working tree files would be overwritten by checkout:
www/1...
www/2...
www/3...
www/4...
Aborting
Как удалить папку www
из всех ветвей в репозитории aaa
? Есть около 100 веток, поэтому делать это вручную было бы хлопот.
Я не беспокоюсь о сохранении каких-либо выдающихся изменений, которые существуют в папках www
старых ветвей.