ChatGPT解决这个技术问题 Extra ChatGPT

How to git ignore subfolders / subdirectories?

I have a lot of projects in my .Net solution. I would like to exclude all "bin/Debug" and "bin/Release" folders (and their contents), but still include the "bin" folder itself and any dll's contained therein.

.gitignore with "bin/" ignores "Debug" and "Release" folders, but also any dll's contained in the "bin" folder.

bin/Debug or bin/Release in the .gitignore file does not exclude the directories unless I fully qualify the ignore pattern as Solution/Project/bin/Debug - which I don't want to do as I will need to include this full pattern for each project in my solution, as well as add it for any new projects added.

Any suggestions?

Why add the DLL's? If you're referencing third party DLLs, it may make sense to add a common folder that all your projects then reference.
Paddy's right - if those are third-party DLLs, they should probably be organized away from your code. To me, though, it sounds like you're checking in your own build products, which is not generally the way you want to go. You use git to track the information, which is fully contained in the code and build configuration. The products are, well, products. Tracking them is asking for trouble - for example, what if you change the code but forget to build and check in new products?
I had a problem in excluding subfolders. Tried everything, including the exact samples written here, but with no success. Finally i added a additional blank line between folder patterns, and it's working. Maybe a encoding problem. I have windows and encoded this in UTF8.

J
Josh Lee

Have you tried wildcards?

Solution/*/bin/Debug
Solution/*/bin/Release

With version 1.8.2 of git, you can also use the ** wildcard to match any level of subdirectories:

**/bin/Debug/
**/bin/Release/

It works, except if there is a sub-folder with another project in e.g. Solution/Module/Project so for now I've added /*/*/bin/Debug and /*/*/*/bin/Debug (for sub folders). Looks like you have to add a wildcard sub folder for each level in your directory structure.
@Marcel: Well, git certainly isn't going to ignore any files you don't tell it to - it ignores whatever matches the wildcards, no more, no less.
I think that double star will cross directory boundaries, ie: /**/bin/Debug
@Taras: Unfortunately, it does not.
There was a bug on Visual Studio related to ** . Should be fixed by now. link
A
Andreas

You can use .gitignore in the top level to ignore all directories in the project with the same name. For example:

Debug/
Release/

This should update immediately so it's visible when you do git status. Ensure that these directories are not already added to git, as that will override the ignores.


The same could be done by adding the patterns to the OPs $GIT_DIR/.git/info/exclude file.
The difference is that the .gitignore file will follow the code, so it applies everywhere. Whereas the exclude file is local to only your repository, meaning it only applies for that specific repository. Unless other committers have a reason to want to commit these directories, I would recommend using .gitignore.
Another problem with this is if you have a project in your solution called Debug, which will then also be ignored. I think the solution is a combination of all the answers and comments - restructure the solution to keep common or referenced dll's in a different folder, then ignoring "bin/" and/or use wildcards.
+1 For comment on ensuring directories not already added to git. If already added to git, do: git rm -rf DirectoryName/
Doesn't work for me. directories created by build continue to pop up as unstaged. Driving me crazy. git rm -rf reports foo/ reports that foo is not present.
P
Phil

All the above answers are valid, but something that I don't think is mentioned is that once you add a file from that directory into the repo, you can't ignore that directory/subdirectory that contains that file (git will ignore that directive).

To ignore already added files run

$ git rm -r --cached .

Otherwise you'll have to remove all files from the repo's target directory first - and then you can ignore that folder.


git rm --cached if you want them untracked/irrelevant to history but want to keep the files intact locally.
Simply: git reset Solution , than add to .gitignore Solution/*/bin/Debug, Solution/*/bin/Release, and than git add Solutions
It should be git rm -r --cached .
How can undo this command?
m
mgold

The question isn't asking about ignoring all subdirectories, but I couldn't find the answer anywhere, so I'll post it: */*.


Any chance you could clarify? I've tried all sorts of variations on this and can't get git add to ignore a directory and all files in all subdirectories of that directory. I have tried dirname/, dirname/*, dirname/**, dirname/*/*, even in desperation dirname/*/*/*, dirname/*/*/*/*, dirname/*/*/*/*/*.
*/* ignores all subdirectories but not files in the current directory. To ignore a specific subdirectory is normal gitignore usage. dirname, dirname/, and dirname/* all work for me. Has anything in that directory already been committed?
It is a brand new repo - I delete the whole .git directory between attempts, then git init then git add --all . (have also tried without --all), using 1.9.4.msysgit.1. Every non-empty subdirectory under my named directory is added to the index (checked in TortoiseGit and git status). There are no relevant lines in .gitignore starting ! but must be some conflict. Solved for now by removing the folders during add. Guess this is something that'll require a bit more digging to provide the necessary info to diagnose. Thanks for reassuring me that I'm not misunderstanding the syntax.
What if I need to ignore a folder inside a folder, but not the first one? As in forum/ignorethisfolder/ ...but he is not to ignore the folder called forum
This doesn't work for me in ignoring a directory whose name starts with a dot. "/." and ".*/*" don't work either.
M
MidnightJava

Besides putting the correct entries in your .gitignore file, if you're trying to ignore something already added to the repo, you have to do git rm -r /path/to/dir and commit that before you add the dir to your .gitignore file. Otherwise the only thing git will ignore is your ignore directive.


r
ruttoa

The only way I got this to work on my machine was to do it this way:

# Ignore all directories, and all sub-directories, and it's contents:
*/*

#Now ignore all files in the current directory 
#(This fails to ignore files without a ".", for example 
#'file.txt' works, but 
#'file' doesn't):
/*.*

#Only Include these specific directories and subdirectories:
!wordpress/
!wordpress/*/
!wordpress/*/wp-content/
!wordpress/*/wp-content/themes/

Notice how you have to explicitly allow content for each level you want to include. So if I have subdirectories 5 deep under themes, I still need to spell that out.

This is from @Yarin's comment here: https://stackoverflow.com/a/5250314/1696153

These were useful topics:

How do negated patterns work in .gitignore?

How do gitignore exclusion rules actually work?

I also tried

*
*/*
**/**

and **/wp-content/themes/**

or /wp-content/themes/**/*

None of that worked for me, either. Lots of trail and error!


This negation pattern is the most correct method to accomplish the task put forward in the question.
A
A. Morel

To exclude content and subdirectories:

**/bin/*

To just exclude all subdirectories but take the content, add "/":

**/bin/*/

best answer in this thread thank you!
exactly what I was looking for
f
frederickjh

To ignore all subdirectories you can simply use:

**/

This works as of version 1.8.2 of git.


N
Nick F

The generic way to ignore all subfolders, while continuing to track the files that are in the /bin directory would be to add the following line to your project's .gitignore file:

bin/*/*

If you want to ignore only particular named subfolders, you can do:

bin/Debug/*
bin/Release/*

nb. if the bin directory is not in the root of your project (alongside the .gitignore file), then instead of eg. bin/*/* you might need path/to/bin/*/*


T
Tolga

The simplest form to ignore all subfolders of the root of your repo in your .gitignore file is:

*/

If you want ignore all subfolders of another subfolder:

subfolder/*/

If you have already commited items that need to be ignored, you will need to remove them from the repo before they are ignored.

To remove all subfolders of the root of your repo:

git rm -r --cached */*

To remove all subfolders of another subfolder:

git rm -r --cached subfolder/*/*

Thanks I used .vscode/*/ I would add to your solution "ignore subfolders but include the files at the root of this folder."
Thank you, was wondering why adding the files to .gitignore was not working; they were already committed into the repo
s
slackair

Seems this page still shows up on the top of Google search after so many years...

Modern versions of Git support nesting .gitignore files within a single repo. Just place a .gitignore file in the subdirectory that you want ignored. Use a single asterisk to match everything in that directory:

echo "*" > /path/to/bin/Debug/.gitignore
echo "*" > /path/to/bin/Release/.gitignore

If you've made previous commits, remember to remove previously tracked files:

git rm -rf /path/to/bin/Debug
git rm -rf /path/to/bin/Release

You can confirm it by doing git status to show you all the files removed from tracking.


e
edelwater

For ignoring subfolders but not main folder I could only get this to work in Visual Studio Code by placing a dummy readme.txt in the main folder. Only then /*/ checked in the main folder (and no subfolders).