gitcli

优质
小牛编辑
121浏览
2023-12-01

命名

gitcli - Git 命令行界面和约定

概要

gitcli

描述

本手册介绍了在整个 Git CLI 中使用的约定。

许多命令都采用修订(通常是 “commits” ,但有时是 “ tree-ish ” ,取决于上下文和命令)和路径作为它们的参数。这是规则:

  • 修订首先是路径。例如在git diff v1.0 v2.0 arch/x86 include/asm-x86v1.0并且v2.0是修改,arch/x86并且include/asm-x86是路径。
  • 当一个论证可能会被误解为一个修订或一条路径时,他们可以通过放在--它们之间来消除歧义。例如git diff -- HEAD,“我的工作树中有一个名为 HEAD 的文件,请在索引中的版本I和我在该文件的工作树中显示的内容之间显示更改”,而不是“显示 HEAD 提交与工作之间的差异树整体“。你可以说git diff HEAD --要问后者。
  • 在没有歧义的情况下--,Git 会做出合理的猜测,但会出错并要求您在模棱两可时消除歧义。例如,如果你有一个在你的工作树叫 HEAD 的文件,git diff HEAD是模糊的,而你不得不说要么git diff HEAD --git diff -- HEAD消除歧义。在编写预期处理随机用户输入的脚本时,最好明确哪些参数是通过--在适当的位置进行消除歧义来明确的。
  • 许多命令允许在路径中使用通配符,但是您需要保护它们免受 shell 的影响。这两个意思是不同的东西:

$ git checkout -- *.c $ git checkout -- \*.c

前者允许 shell 扩展 fileglob ,并且要求工作树中的 dot-C 文件被索引中的版本覆盖。后者传递*.c给 Git,并且您要求索引中匹配模式的路径被检出到您的工作树上。跑步后git add hello.c; rm hello.c,你会not看到hello.c你的工作树与前者,但后者,你会。

  • 就像文件系统.(句点)引用当前目录一样,在Git 中使用.作为存储库名称(一个点存储库)是一个相对路径,并且表示您当前的存储库。这里是关于您应该遵循的“标志”的规则当你在编写 Git 时:
  • 它的最好使用的 Git 的非虚线形式的命令,这意味着你应该更喜欢git foogit-foo
  • 拆分短选项分隔单词(喜欢git foo -a -bgit foo -ab,后者甚至可能不工作)。
  • 当一个命令行选项带有参数时,请使用该stuck表单。换句话说,写出git foo -oArg代替git foo -o Arg短期期权,而git foo --long-opt=Arg不是git foo --long-opt Arg长期期权。采用可选选项参数的选项必须写入stuck表单中。
  • 当您为某个命令提供修订参数时,请确保该参数与工作树中文件的名称不混淆。例如,不要写,git log -1 HEAD而要写git log -1 HEAD --; 如果您碰巧HEAD在工作树中调用了一个文件,则前者不起作用。
  • 许多命令允许将一个长选项--option仅缩写为其唯一的前缀(例如,如果没有其他选项的名称以该名称开头opt,则可以拼写--opt来调用该--option标志),但是在编写脚本时应该将其完全拼出; 后来的 Git 版本可能会引入一个新的选项,其名称共享相同的前缀,例如--optimize,用于创建一个过去不再唯一的简短前缀。

增强的选项解析器

从 Git 1.5.4 系列和更进一步,许多 Git 命令(不是所有的这些在编写时)都带有一个增强的选项解析器。

这里是这个选项解析器提供的工具列表。

Magic 选项

具有增强的选项分析器的命令都可以理解一些神奇的命令行选项:

-h

给出了一个完美的打印使用该命令。

$ git describe -h
usage: git describe [options] <commit-ish>*
   or: git describe [options] --dirty    --contains            find the tag that comes after the commit    --debug               debug search strategy on stderr    --all                 use any ref    --tags                use any tag, even unannotated    --long                always use long format    --abbrev[=<n>]        use <n> digits to display SHA-1s

--help-all

有些 Git 命令会使用仅用于管道的选项或已弃用的选项,并且这些选项对于默认用法是隐藏的。该选项提供了完整的选项列表。

否定选项

具有较长选项名称的选项可以通过前缀来取消--no-。例如,git branch有选项--trackon默认。您可以使用--no-track来覆盖该行为。这也是--color--no-color

汇总短期选项

支持增强选项解析器的命令允许您汇总短选项。这意味着你可以例如使用git rm -rfgit clean -fdx

缩写长选项

支持增强选项解析器的命令接受长选项的唯一前缀,就像它完全拼出一样,但谨慎使用此选项。例如,git commit --amen你的行为就像你输入的一样git commit --amend,但是只有当 Git 的一个更新版本引入了另一个共享相同前缀的选项时,这是正确的,例如git commit --amenity选项。

从选项中分离参数

您可以在命令行中将强制选项参数作为单独的单词写入选项。这意味着以下所有用途都有效:

$ git foo --long-opt=Arg
$ git foo --long-opt Arg
$ git foo -oArg
$ git foo -o Arg

然而,这是允许与可选的值,其中,所述开关stuck,必须使用形式:

$ git describe --abbrev HEAD     # correct
$ git describe --abbrev=10 HEAD  # correct
$ git describe --abbrev 10 HEAD  # NOT WHAT YOU MEANT

注意经常混淆的选项

许多可用于工作树中和/或索引中的文件的命令可以采用--cached和/或--index选择。有时候人们错误地认为,因为索引最初称为缓存,这两个是同义词。他们不是 - 这两个选项意味着非常不同的事情。

  • --cached选项用于询问通常对工作树中的文件起作用的命令,以便与索引一起工作。例如,git grep如果在没有提交的情况下使用,指定从哪个提交中查找字符串,通常用于工作树中的文件,但使用该--cached选项时,它会在索引中查找字符串。
  • --index选项用于要求,通常在工作中的文件工作树的命令影响指数。例如,git stash apply通常会将存储条目中记录的更改合并到工作树中,但是通过该--index选项,它也会将更改合并到索引中。

git apply命令可以--cached--index(但不能同时)一起使用。通常,该命令只影响工作树中的文件,但是--index,它会对文件及其索引条目进行修补,而且--cached,它仅修改索引条目。