54

Is there a way to get the list of all new/deleted/modified directories/files in local/remote repository w.r.t each other in GIT ?

Jean
  • 20,165
  • 23
  • 64
  • 110
  • 8
    `git status` seems to do that. – Blender Mar 28 '12 at 20:58
  • 3
    This question is broad and not very clear -- with the result that the following answers cover quite different scenarios and use cases. Unfortunately, it's too late to make the question more specific as this would invalidate some of the (good) answers. – Anthony Geoghegan Jan 04 '19 at 17:09
  • Does this answer your question? [How to list only the names of files that changed between two commits](https://stackoverflow.com/questions/1552340/how-to-list-only-the-names-of-files-that-changed-between-two-commits) – cyreb7 Apr 07 '22 at 16:32

10 Answers10

50

The best way to list these file is using git status --porcelain

For example: To remove previously deleted files:

git status --porcelain | awk 'match($1, "D"){print $2}' | xargs git rm
Alex Sharapov
  • 516
  • 4
  • 2
  • Removing the final pipe at the end is a good way to list what files have been deleted. Helpful if you have a very long git status and want to filter on a particular status. – IanVS Nov 24 '14 at 02:30
34

I'm not sure what you mean by with respect to each other, but if you want an individual listing (e.g. all modified files) you can use git ls-files with the right flags (for modified files it's -m). If you want all of this info at once, you can use git status --porcelain to get a script-parsable output of the status.

Lily Ballard
  • 176,187
  • 29
  • 372
  • 338
18

To get just file names and status of the currently changed files you can simply:

git diff --name-status

You will get the bare output like this:

M       a.txt
M       b.txt

Now, pipe the output to cut to extract the second column:

git diff --name-status | cut -f2

Then you'll have just the file names:

a.txt
b.txt
LeandroN.
  • 602
  • 8
  • 17
  • cut : The term 'cut' is not recognized as the name of a cmdlet, function, script file, or operable program. Check the spelling of the name, or if a path was included, verify that the path is correct and try again. At line:1 char:26 – amuliar Nov 12 '18 at 08:18
  • This example was created assuming you have a linux bash available. On windows, depending on your version, you'll need to install "Windows subsystem for Linux" on Windows 10 or something like Cygwin on previous windows versions. – LeandroN. Nov 12 '18 at 09:05
  • 10
    Wouldn't `git diff --name-only` do the same thing as `cut -f2`? – Old Geezer Mar 02 '19 at 01:44
  • What is this magical `cut` command and why didn't I know about it sooner? Nice! – Paul Sturm Nov 04 '21 at 01:10
17

Use the dry-run (-n) option of git add:

git add -A -n

Trident D'Gao
  • 17,538
  • 18
  • 90
  • 151
15

One way to do this is with the whatchanged command:

$ git whatchanged

This shows which files changed for each commit in the tree and can be used to look at specifics as well. Take a look at git help whatchanged

sparrow
  • 1,758
  • 10
  • 22
11

What you probably want is something like:

git fetch     # update what you know about the remote repo
git diff --name-status master origin/master

But it's pretty difficult to tell exactly what branches you want to diff from your question.

Cascabel
  • 451,903
  • 67
  • 363
  • 314
3

In my case I needed the list of all new/modified/untracked files. The below command did the trick:

git status --porcelain | cut -c 1-3 --complement

The cut -c 1-3 --complement part is for removing the three initial status characters so that I could run arbitrary scripts with xargs against the files. For instance, run eslint against all new/changed JavaScript files (in a nodejs repo):

git status --porcelain | cut -c 1-3 --complement | egrep .js$ | xargs npm run lint -- --fix
Alfeu
  • 921
  • 8
  • 12
2

use with command --name-status

example with tags:

git diff v1.0.1 v1.0.2 --name-status

example with commits:

git diff b79810fc4d be69e41d1c --name-status

it will list all the updated files with their statuses: M - modified D - deleted A - added

Oleksa O.
  • 635
  • 5
  • 14
0

Do git diff and you will see all the files changed and the details of what changed in those files

Sandeep Amarnath
  • 2,957
  • 1
  • 22
  • 31
0

To git all files that your are added, modified deleted and new files you use two commands git ls-files -o to get all new files and git checkout for get delete files , modified files and added files

git ls-files -o && git checkout

How I know deleted, modified , deleted files and new files if you see before the file

  • A this is added file to git
  • D this is deleted file
  • M this is Modified file
  • Nothing before the file this is a new file

see this gif image get added, deleted, modified and new files in git

Eng_Farghly
  • 934
  • 1
  • 14
  • 25