Retirer des dossiers du suivi de Git, après un ajout dans .gitignore
Si j'utilisais déjà Git pour suivre les modifications de CaMykS, le CMS sur lequel je travaille, mais aussi quelques autres projects d'importance, ce n'était pas encore le cas pour tous mes projets, en particulier les sites internet.
Mais de plus en plus, je m'en sers aussi pour suivre le développement de ces projets là. Cependant, contrairement aux autres projets, les sites internet disposent de données qui évoluent, il ne s'agit pas uniquement de contenu fixe.
Alors bien sur, il suffit de rajouter le ou les dossiers en question dans le fichier .gitignore pour que Git ne s'en occupe plus. Mais voilà, si l'on eu eu le malheur de stage/commit un ou plusieurs fichiers avant de mettre la définition dans .gitignore, ils seront alors ignoré du .gitignore et continueront de s'afficher dans la liste des fichiers modifiés.
N'ayant commencer à utiliser Git que récemment, je ne suis pas encore très au fait, de toutes ces subtilités, mais pourtant, il a bien fallut que je trouve une solution. Et si possible une solution propre, car je ne voulais pas planté mon projet.
Et bien la voilà, sachant que je n'ai pas réussi à l'exécuter depuis Fork, je suis allé dans les lignes de commande.
Pour commencer, vérifiez bien que votre règle de gitignore fonctionne bien. Il serait dommage de tout enlever et que cela revienne instantanément.
Ensuite, si certains fichiers sont déjà dans git, et on été modifié entre temps, faites un commit avec l'ensemble des fichiers. Ainsi ils sont plus marqués comme modifiés et vous allez pouvoir les supprimer sans soucis.
Ensuite, dans votre dossier du projet, il faut exécuter la commande
git rm -r --cached mon-dossier
pour demander à Git de retirer le dossier "mon-dossier", ainsi que tout ce qu'il contient avec le paramètre -r . Le paramètre --cached est extrêmement important, car il indique à Git que l'on souhaite conserver la copie locale des fichiers, sinon, il les supprimerait aussi.
Il suffit ensuite de faire un commit pour valider tout ça.
git commit -m 'Retire le dossier mon-dossier du suivi git.'
En renouvelant la première commande, vous pouvez retirer plusieurs dossiers, un seul commit suffit en toute fin.
Alors certes cela apparait toujours dans l'historique des modifications, mais finalement, il s'agit bien d'une modification, et cela s'est fait simplement, et proprement.