Перемещенная папка в субмодуль, теперь сообщение "Отслеживаемые файлы будут перезаписаны"

Я работаю над командой на большом репо. Недавно мы решили перенести одну из папок в собственный подмодуль

-- 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 старых ветвей.

Ответ 1

Просто используйте git checkout -f для обмена ветвями, а затем удалите их, как обычно, и объедините мастер, чтобы получить представление о подмодуле.