This document applies to search (CMD+SHIFT+F/CTRL+SHIFT+F) and quickopen (CMD+P/CTRL+P). By default, VS Code uses the ripgrep tool to drive search. Learn more about how to use search in the documentation.
By far, the most common reason that expected search results don't appear is because of exclude settings and ignore files. Search and quickopen ignore files using patterns specified in the search.exclude
and files.exclude
settings, or covered by a pattern in a .gitignore
file. So the very first thing to do is to carefully check these settings at the user and workspace levels, and your .gitignore
file.
Tip: You can set
"search.useIgnoreFiles": false
to disable using the.gitignore
file for search
An easy way to validate whether exclude setttings or ignore files are affecting your search is to turn off the "Use Exclude Settings and Ignore Files" button in the search viewlet. The button in the lower right corner:
Another thing to watch for is that it's possible to add a file covered by a .gitignore
file to git, and some tools like git grep
will still search these files. Ripgrep is looking at the .gitignore
file but doesn't know whether a file has been added to git. So if a file is covered by the .gitignore
file, it won't be searched, whether or not it's in git.
If your workspace has files with a non-UTF-8 encoding, you will need to set the files.encoding
setting to the correct encoding to search in those files. Note that the files.autoGuessEncoding
works for the editor, but isn't supported for search.
This is less common, but VS Code doesn't handle files with CR-only line endings well. Files that originated on older OS's may use these, and may have missing or inconsistent search results. There is an open issue for this.
When looking at issues with missing results, remember that search in open files is implemented by the editor. Search in all other files is implemented by ripgrep. Some issues that look like search is working only in a few random files can be explained by a problem that only affects the ripgrep side of the search.
If your search includes results that you expect to be excluded by search.exclude
and files.exclude
settings or a .gitignore
file, the first thing to do is to check those very carefully to ensure they cover what you expect them to cover. Your workspace may have settings that override your user settings. And setting "search.useIgnoreFiles": false
will disable checking the .gitignore
file.
The search viewlet has a toggle button, "Use Exclude Settings and Ignore Files", which will disable checking both of these things. Make sure that it's toggled on - it's not uncommon that users turn it off and forget about it.
Another thing that can cause excluded files to be shown is that open files are still searched even when they are excluded. This is a vscode bug.
Does your workspace have lots of symlinks? Search can take a long time if it has to follow lots of symlinks. Setting "search.followSymlinks": false
will disable this.
Does your search return results on very long lines? This will cause some slowdown and can even cause VS Code to hang. There is an open bug for this.
If your workspace is very large, you might want to use the exclude settings, or the "files to include/exclude" text boxes to narrow down your search to the parts you care about. Make sure the "Use Exclude Settings and Ignore Files" button is toggled on so your exclude settings are respected.
On Windows, the Windows Defender tool can sometimes kick in during a search and slow down searching. Look for a process named using high CPU named MsMpEng.exe
in the Task Manager to tell whether Defender is active.
You can start VS Code from the command line with the --status
flag, or use the Process Explorer (Help > Open Process Explorer) to see running processes owned by VS Code. The ripgrep process will show up as a command that invokes the rg
binary inside the VS Code install directory. The arguments passed to rg
tell you why it was started and are useful to include in an issue report. You can even copy the command and run it yourself to check for the correct output.
The steps on the [[Performance Issues]] wiki page may also be useful.
When filing a search-related issue on the VS Code repo, please try the steps above and include as many details as possible to help us diagnose the issue.
- If there's an issue with search, do you see the same issue with quickopen, (or vice versa)?
- If you see an issue with search when you have folder A open, do you see a similar issue with other folders on your computer?
Collecting search logs
Some details are logged for each search. To see these logs, run the command "Developer: Set Log Level..."
, select "Trace", and run the search again. Then in the output pane, see the logs in the channel named "Log (Window)"
. The logs show VS Code's internal query object, the arguments with which ripgrep was invoked, and any errors produced by ripgrep.
There may also be errors that only show up in the developer tools. Open the developer tools (Help > Toggle Developer Tools) and check the Console for errors.