设置和配置
获取和创建项目
基本快照
分支与合并
共享和更新项目
检查和比较
打补丁
调试
电子邮件
外部系统
服务器管理
指南
管理
底层命令
- 2.43.1 → 2.52.0 无更改
-
2.43.0
2023-11-20
- 2.36.1 → 2.42.4 无变更
-
2.36.0
2022-04-18
- 2.1.4 → 2.35.8 无更改
-
2.0.5
2014-12-17
概要
git checkout-index [-u] [-q] [-a] [-f] [-n] [--prefix=<string>] [--stage=<number>|all] [--temp] [--ignore-skip-worktree-bits] [-z] [--stdin] [--] [<file>…]
选项
- -u
- --index
-
更新索引文件中已检出条目的统计信息。
- -q
- --quiet
-
如果文件存在或不在索引中,则保持安静
- -f
- --force
-
强制覆盖现有文件
- -a
- --all
-
检出索引中的所有文件,但排除那些设置了 skip-worktree 位的文件(参见
--ignore-skip-worktree-bits)。不能与显式文件名一起使用。 - -n
- --no-create
-
不要检出新文件,只刷新已检出的文件。
- --prefix=<string>
-
创建文件时,在文件名前加上 <string>(通常是包含末尾斜杠的目录)
- --stage=<number>|all
-
不是检出未合并的条目,而是从指定的阶段复制文件。<number> 必须在 1 到 3 之间。注意:--stage=all 自动包含 --temp。
- --temp
-
不是将文件复制到工作目录,而是将内容写入临时文件。临时文件名关联将写入 stdout。
- --ignore-skip-worktree-bits
-
检出所有文件,包括那些设置了 skip-worktree 位的文件。
- --stdin
-
不是从命令行获取路径列表,而是从标准输入读取路径列表。默认情况下,路径由 LF 分隔(即每行一个路径)。
- -z
-
仅在
--stdin有效时才有意义;路径由 NUL 字符而不是 LF 分隔。 - --
-
不再将任何后续参数解释为选项。
标志的顺序曾经很重要,但现在不再是了。
仅运行 git checkout-index 不执行任何操作。您可能想要 git checkout-index -a。如果您想强制执行,您需要 git checkout-index -f -a。
直观性不是目标。可重复性才是。命令行“无参数表示无操作”的原因是,从脚本中您可以执行
$ find . -name '*.h' -print0 | xargs -0 git checkout-index -f --
这将用其缓存的副本替换所有现有的 *.h 文件。如果空命令行意味着“全部”,那么这将强制刷新索引中的所有内容,但这并非目的。但是,由于 git checkout-index 接受 --stdin,因此使用以下命令会更快
$ find . -name '*.h' -print0 | git checkout-index -f -z --stdin
-- 只是一个好习惯,当您知道后面的都是文件名时;它可以避免文件名(例如 -a)引起的问题。在脚本中使用 -- 可能是一个好策略。
使用 --temp 或 --stage=all
当使用 --temp(或 --stage=all 暗示)时,git checkout-index 将为每个要检出的索引条目创建一个临时文件。索引不会用统计信息进行更新。如果调用者需要所有未合并条目的所有阶段,以便外部合并工具可以处理这些未合并的文件,则这些选项可能很有用。
将向 stdout 写入一个列表,提供临时文件名与跟踪路径名的关联。列表格式有两种变体
-
tempname TAB path RS
第一种格式是在省略
--stage或它不是--stage=all时使用的。字段 tempname 是包含文件内容的临时文件名,path 是索引中的跟踪路径名。只输出请求的条目。 -
stage1temp SP stage2temp SP stage3tmp TAB path RS
第二种格式是在使用
--stage=all时使用的。三个阶段的临时字段(stage1temp、stage2temp、stage3temp)列出了索引中阶段条目的临时文件名,如果没有阶段条目,则为.。只有阶段 0 条目的路径将始终从输出中省略。
在这两种格式中,RS(记录分隔符)默认为换行符,但如果命令行上传递了 -z,则为 null 字节。临时文件名始终是安全的字符串;它们永远不会包含目录分隔符或空格字符。路径字段始终相对于当前目录,临时文件名始终相对于顶级目录。
如果复制到临时文件的对象是符号链接,则链接的内容将写入一个普通文件。由最终用户或 Porcelain 来利用此信息。
示例
- 仅更新和刷新已检出的文件
-
$ git checkout-index -n -f -a && git update-index --ignore-missing --refresh
- 使用 git checkout-index “导出整个树”
-
前缀功能基本上使 git checkout-index 易于用作“导出为树”功能。只需将所需的树读入索引,然后执行
$ git checkout-index --prefix=git-export-dir/ -a
gitcheckout-index将“导出”索引到指定目录。最后的斜杠很重要。导出的名称只是简单地加上指定字符串作为前缀。与以下示例进行对比。
- 导出带前缀的文件
-
$ git checkout-index --prefix=.merged- Makefile
这将把 `Makefile` 的当前缓存副本检出到文件 `.merged-Makefile`。