列出Git存储库中存在的所有文件

时间:2009-02-12 21:23:43

标签: git

您是否有一种干净的方法来列出指定分支中存在的所有文件?

4 个答案:

答案 0 :(得分:121)

这是Strager solution的简化版本:

git log --pretty=format: --name-status | cut -f2- | sort -u

编辑:感谢Jakub在评论中教我一点,这个版本有一个更短的管道,让git有更多机会把事情做好。

git log --pretty=format: --name-only --diff-filter=A | sort -u

答案 1 :(得分:12)

这对于检查 repo 中是否存在文件名而不仅仅是在当前分支上是正确的。

git log --all --pretty=format: --name-only --diff-filter=A | sort - | grep fubar

答案 2 :(得分:2)

您可以运行git-log --name-status,其中包含以下内容:

commit afdbbaf52ab24ef7ce1daaf75f3aaf18c4d2fee0
Author: Your Name <your@email.com>
Date:   Tue Aug 12 13:28:34 2008 -0700

    Added test file.

A       test

然后提取文件:

git-log --name-status | sed -ne 's/^A[^u]//p' | sort -u

答案 3 :(得分:0)

以下是两个有用的别名:FindFile ff和FindFilewithCopies ffc

# Find if one file ever had into repository
ff = "!git log --pretty=format: --name-status --all -M -B | sort -u | grep $1   #"
# The same as above but showing copied files
ffc = "!git log --pretty=format: --name-status --all -C -M -B | sort -u | grep $1 #"

您可以获得有关文件名和操作的信息。

样品使用:

$ git ff create
A       database/migrations/2014_10_12_000000_create_users_table.php
A       database/migrations/2014_10_12_100000_create_password_resets_table.php
A       database/migrations/2015_05_11_200932_create_boletin_table.php
A       database/migrations/2015_05_15_133500_create_usuarios_table.php
D       database/migrations/2015_05_12_000000_create_users_table.php
M       database/migrations/2015_05_11_200932_create_boletin_table.php
R051    database/migrations/2014_10_12_000000_create_users_table.php    database/migrations/2015_05_12_000000_create_users_table.php

$ git ffc create
A       database/migrations/2014_10_12_000000_create_users_table.php
A       database/migrations/2014_10_12_100000_create_password_resets_table.php
A       database/migrations/2015_05_11_200932_create_boletin_table.php
A       database/migrations/2015_05_15_133500_create_usuarios_table.php
C052    database/migrations/2014_10_12_000000_create_users_table.php    database/migrations/2015_05_11_210246_create_boletin_nosend_table.php
D       database/migrations/2015_05_12_000000_create_users_table.php
M       database/migrations/2015_05_11_200932_create_boletin_table.php
R051    database/migrations/2014_10_12_000000_create_users_table.php    database/migrations/2015_05_12_000000_create_users_table.php