How to filter git diff based on file extensions?

GitFile Extension

Git Problem Overview


Is there an option to restrict git diff to a given set of file extensions?

Git Solutions


Solution 1 - Git

Yes, if you ensure that git expands a glob rather than your shell then it will match at any level so something like this (quotes are important) should work fine.

git diff -- '*.c' '*.h'

Solution 2 - Git

To include files recursively (including current dir) this worked for me:

git diff -- '***.py'

Solution 3 - Git

Either use your shell's globstar (which does a recursive search)1,2:

shopt -s globstar 
git diff -- *.py **/*.py

or use find:

find -name '*.py' -print0 | xargs -0 git diff --

Both of these are special-names and whitespace proof. Although you might want to filter for directories having the .py extension :)


1 I like to do git diff -- {.,**}/*.py usually

2 When globstar is enabled, git diff -- **/*.py already includes ./*.py. In Bash's manpage: 'If followed by a /, two adjacent *s will match only directories and subdirectories.'

Solution 4 - Git

For simple file patterns, this seems to work:

$ git ls-files -zm '*.txt' | xargs --null git diff

Whitespace safe, and you can have multiple extensions too:

$ git ls-files -zm '*.h|*.c|*.cpp' | xargs --null git diff

Solution 5 - Git

Command line argument for extension.

git diff *.py

In the alternative, you can pipe find into git diff:

find . -name '*.py' -type f | git diff --

Solution 6 - Git

As tested on git version 2.18.0, the file extension should be quoted with double quotes. If you want to find the last differences between your local repository and the remote one, after pulling, you can use:

git diff YourBranchName@{1} YourBranchName --name-only "*.YourFileExtionsion"

For example:

git diff master@{1} origin/master --name-only "*.cs"

Solution 7 - Git

Attention that params order makes difference...for example:

git diff master --name-only --relative -- "**/*.ts" "**/*.tsx" "**/*.js" "**/*.jsx" "**/*.vue"

'diff' need to be followed with 'master'

Solution 8 - Git

None of the answers above seem to work for me under git bash on Windows. I am not sure if it is a version thing (I'm using 1.8.4) or Windows/bash thing; also, in my case, I wanted to diff two branches where each branch had additional files not present in the other branch (thus the 'find' based ones are remiss).

Anyway this worked for me (in my example, looking for a diff between python files):

git diff branch1 branch2 -- `git diff --summary branch1 branch2 | egrep '\.py$' | cut -d ' ' -f 5`

Solution 9 - Git

git diff will only show differences in unstaged files.

I found this question because I wanted to exclude .info files from git diff. I achieved this by staging it with git add *.info, which reduces the files left.

Solution 10 - Git

I wound up with this:

commit=<the_commit_hash_goes_here> && git diff --name-only $commit | grep -i Test | egrep -v '\.sql$' | xargs git diff $commit --

This shows diffs for the specified commit only if the filename contains the word 'test' (case insensitive) and does not end with .sql, modify the pipeline as necessary for your case.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionvfclistsView Question on Stackoverflow
Solution 1 - GitCB BaileyView Answer on Stackoverflow
Solution 2 - GitBohumir ZamecnikView Answer on Stackoverflow
Solution 3 - GitseheView Answer on Stackoverflow
Solution 4 - GitMatView Answer on Stackoverflow
Solution 5 - GithughdbrownView Answer on Stackoverflow
Solution 6 - Gitmarjan.javidView Answer on Stackoverflow
Solution 7 - GitRevenantView Answer on Stackoverflow
Solution 8 - GitYonatanView Answer on Stackoverflow
Solution 9 - GitAlan WhitelawView Answer on Stackoverflow
Solution 10 - GitMatrixManAtYrServiceView Answer on Stackoverflow