术语表

最后更新于:2022-04-01 01:01:11

我们把在Git里常用的一些名词做了解释列在这里。这些名词(terms)全部来自[Git Glossary](http://www.kernel.org/pub/software/scm/git/docs/gitglossary.html)。 _alternate object database_ > Via the alternates mechanism, a repository > > ~~~ > can inherit part of its object database > from another object database, which is called "alternate". > > ~~~ _bare repository_ > A bare repository is normally an appropriately > > ~~~ > named directory with a `.git` suffix that does not > have a locally checked-out copy of any of the files under > revision control. That is, all of the `git` > administrative and control files that would normally be present in the > hidden `.git` sub-directory are directly present in the > `repository.git` directory instead, > and no other files are present and checked out. Usually publishers of > public repositories make bare repositories available. > > ~~~ _祼仓库_ > ~~~ > A bare repository is normally an appropriately > named directory with a `.git` suffix that does not > have a locally checked-out copy of any of the files under > revision control. That is, all of the `git` > administrative and control files that would normally be present in the > hidden `.git` sub-directory are directly present in the > `repository.git` directory instead, > and no other files are present and checked out. Usually publishers of > public repositories make bare repositories available. > > ~~~ _blob object(二进制对象)_ > 没有类型的数据对象。例如:一个文件的内容。 _branch_ > A "branch" is an active line of development. The most recent > > ~~~ > commit on a branch is referred to as the tip of > that branch. The tip of the branch is referenced by a branch > head, which moves forward as additional development > is done on the branch. A single git > repository can track an arbitrary number of > branches, but your working tree is > associated with just one of them (the "current" or "checked out" > branch), and HEAD points to that branch. > > ~~~ _分支_ > ~~~ > 一个“分支”是开发过程中的(active line)。。。。 > > ~~~ _cache(缓存)_ > 索引(index)的旧称(obsolete). _chain(链表)_ > 一串对象,其中每个对象都有指向其后继对象的引用(reference to its successor)。例如:一个提交(commit)的后继对象就是它的父对象。 _changeset(修改集)_ > BitKeeper/cvsps 里对于提交(commit)的说法。但是 git 只存储快照(states),不存储修改;所以这个词用在 git 里有点不大合适。 _checkout(签出)_ > ~~~ > 用对象仓库(object database)里的一个树对象(tree object)更新当前整个工作树(worktree),或者一个二进制对象(blob object)更新工作树的一部分;如果工作树指向了一个新的分支,那么就会更新索引(index)和HEAD。 > > ~~~ _cherry-picking_ > In SCM jargon, "cherry pick" means to choose a subset of > > ~~~ > changes out of a series of changes (typically commits) and record them > as a new series of changes on top of a different codebase. In GIT, this is > performed by the "git cherry-pick" command to extract the change introduced > by an existing commit and to record it based on the tip > of the current branch as a new commit. > > ~~~ _cherry-picking_ > 在SCM的行话里,“cherry pick“ 意味着从一系列的修改中选出一部分修改(通常是提交),应用到当前代码中。() _clean(干净)_ > 如果一个工作树(working tree)中所有的修改都已提交到了当前分支里(current head),那么就说它是干净的(clean),反之它就是脏的(dirty)。 _commit_ > As a verb: The action of storing a new snapshot of the project's > > ~~~ > state in the git history, by creating a new commit representing the current > state of the index and advancing HEAD > to point at the new commit. > > ~~~ _commit(提交)_ > 作为名词:指向git历史的某一点的指针;整个项目的历史就由一组相互关联的提交组成的。提交(commit)在其它版本控制系统中也做"revision"或"version"。同时做为提交对象(commit object)的缩写。 > > 作为动词:创建一新的提交(commit)来表示当前索引(index)的状态的行为,把 HEAD 指向新创建的提交,这一系列把项目在某一时间上的快照(snapshot)保存在git历史中的操作。 _提交对象_ > 一个关于特定版本信息(particular revision)的对象。包括父对象名,提交者,作者,日期和存储了此版本内容的树对象名(tree object)。 _core git_ > Git的基本数据结构和工具,它只对外提供简单的代码管理工具。 _DAG_ > 有向无环图。众多提交对象(commit objects)组成了一个有向无环图;因为它们都有直接父对象(direct parent),且没有一条提交线路(chain)的起点和终点都是同一个对象。 _dangling object(悬空对象)_ > 一个甚至从其它不可达对象也不可达的对象(unreachable object);仓库里的一个悬空对象没有任何引用(reference)或是对象(object)引用它。 _detached HEAD(分离的HEAD)_ > 通常情况下HEAD里是存放当前分支的名字。然而 git 有时也允许你签出任意的一个提交(commit),而不一定是某分支的最近的提交(the tip of any particular branch);在这种情况下,HEAD就是处于分离的状态(detached)。 译者注:这时`.git/HEAD`中存储的就是签出的提交的SHA串值。 _dircache_ > 请参见索引(index)。 _directory(目录)_ > 执行"ls"命令所显示的结果 :-) _dirty(脏)_ > 一个工作树里有没有提交到当前分支里修改,那么我就说它是脏的(dirty)。 _ent_ > 某些人给树名(tree-ish)起的另外一个别名,这里`http://en.wikipedia.org/wiki/Ent_(Middle-earth)`有更详细的解释。最好不要使用这个名词,以免让大家糊涂。 _evil merge(坏的合并)_ > 如果一次合并引入一些不存在于任何父对象(parent)中的修改,那么就称它是一个坏的合并(evil merge)。 _fast forward_ > A fast-forward is a special type of merge where you have a > > ~~~ > revision and you are "merging" another > branch's changes that happen to be a descendant of what > you have. In such these cases, you do not make a new merge > commit but instead just update to his > revision. This will happen frequently on a > tracking branch of a remote > repository. > > ~~~ _快速向前_ > “fast-forward”是一种特殊的合并,()。 在这种情况下,并没有创建一个合并提交(merge commit),只是更新了版本信息。 当本地分支是远端仓库(remote repository)的跟踪分支时,这种情况经常出现。 _fetch(抓取)_ > 抓取一个分支意味着:得到远端仓库(remote repository)分支的head ref,找出本地对象数据库所缺少的对象,并把它们下载下来。你可以参考一下 [git fetch](http://www.kernel.org/pub/software/scm/git/docs/git-fetch.html)。 _file system(文件系统)_ > Linus Torvalds 最初设计 git 时,是把它设计成一个在用户空间(user space)运行的文件系统;也就是一个用来保存文件和目录的 infrastructure,这样就保证了git的速度和效率。 _git archive_ > 对玩架构的人来说,这就是仓库的同义词。 _grafts_ > Grafts enables two otherwise different lines of development to be joined > > ~~~ > together by recording fake ancestry information for commits. This way > you can make git pretend the set of parents a commit has > is different from what was recorded when the commit was > created. Configured via the `.git/info/grafts` file. > > ~~~ _hash(哈希)_ > 在git里,这就是对象名(object name)的同义词。 _head_ > 指向一个分支最新提交的命名引用(named reference)。除非使用了打包引用(packed refs),heads 一般存储在`$GIT_DIR/refs/heads/`。 参见: [git pack-refs](http://www.kernel.org/pub/software/scm/git/docs/git-pack-refs.html) _HEAD_ > 当前分支。详细的讲是:你的工作树(working tree)通是从HEAD所指向的tree所派生的来的。 HEAD 必须是指向一个你仓库里的head,除非你使用分离的HEAD(detached HEAD)。 _head ref_ > head的同义词。 _hook_ > During the normal execution of several git commands, call-outs are made > > ~~~ > to optional scripts that allow a developer to add functionality or > checking. Typically, the hooks allow for a command to be pre-verified > and potentially aborted, and allow for a post-notification after the > operation is done. The hook scripts are found in the > `$GIT_DIR/hooks/` directory, and are enabled by simply > removing the `.sample` suffix from the filename. In earlier versions > of git you had to make them executable. > > ~~~ _钩子_ > 在一些git命令的执行过程中, () 允许开发人员调用特别的脚本来添加功能或检查。 > > ~~~ > () > > ~~~ ~~~ Typically,钩子允许对一个命令做pre-verified并且可以中止此命令的运行;同时也可在这个命令执行完后做后继的通知工作。这些钩子脚本放在`$GIT_DIR/hooks/`目录下,你只要把这它们文件名的`.sample`后缀删掉就可以了。不过在git的早期版本,你需要为这些钩子脚本加上可执行属性。 ~~~ _index_ > A collection of files with stat information, whose contents are stored > > ~~~ > as objects. The index is a stored version of your > working tree. Truth be told, it can also contain a second, and even > a third version of a working tree, which are used > when merging. > > ~~~ _索引_ > 描述项目状态信息的文件,。索引里保存的是你的工作树的版本记录。() _index entry_ > The information regarding a particular file, stored in the > > ~~~ > index. An index entry can be unmerged, if a > merge was started, but not yet finished (i.e. if > the index contains multiple versions of that file). > > ~~~ _索引条目_ _主分支 (master)_ > 默认的开发分支。当你创建了一个git仓库,一个叫"master"的分支就被创建并且成为当前活动分支(active branch)。在多数情况下,这个分支里就包含有本地的开发内容。 _merge_ > As a verb: To bring the contents of another > > ~~~ > branch (possibly from an external > repository) into the current branch. In the > case where the merged-in branch is from a different repository, > this is done by first fetching the remote branch > and then merging the result into the current branch. This > combination of fetch and merge operations is called a > pull. Merging is performed by an automatic process > that identifies changes made since the branches diverged, and > then applies all those changes together. In cases where changes > conflict, manual intervention may be required to complete the > merge. > > ~~~ _merge(合并)_ > 作为动词:把另外一个分支(也许来自另外一个仓库)的内容合并进当前的分支。() > > 作为名词:除非合并的结果是 fast forward;那么一次成功的合并会创建一个新的提交(commit)来表示这次合并,并且把合并了的分支做为此提交(commit)的父对象。这个提交(commit)也可以表述为“合并提交”(merge commit),或者就是"合并"(merge 名词)。 _object(对象)_ > Git的存储单位,它以对象内容的SHA1值做为唯一对象名;因此对象内容是不能被修改的。 _object database(对象仓库)_ > 用来存储一组对象(objects),每个对象通过对象名来区别。对象(objects)通常保存在 `$GIT_DIR/objects/`。 _object identifier(对象标识符)_ > 对象名(object name)的同义词。 _object name(对象名)_ > 一个对象的唯一标识符(unique identifier)。它是使用SHA1算法(Secure Hash Algorithm 1)给对象内容进行哈希(hash)计算,产生的一个40个字节长的16进制编码的串。 _object type(对象类型)_ > Git有4种对象类型:提交(commit),树(tree),标签(tag)和二进制块(blob)。 _octopus(章鱼)_ > 一次多于两个分支的合并(merge)。也用来表示聪明的肉食动物。 _origin_ > 默认的上游仓库(upstream repository)。每个项目至少有一个它追踪(track)的上游(upstream)仓库,通常情况 origin 就是用来表示它。你可以用 ”`git branch -r`“ 命令查看上游仓库(upstream repository)里所有的分支,再用 origin/name-of-upstream-branch 的名字来抓取(fetch)远程追踪分支里的内容。 _pack(包)_ > 一个文件,里面有一些压缩了的对象。(用以节约空间或是提高传输效率)。 _pack index(包索引)_ > 包(pack)里的一些标识符和其它相关信息,用于帮助git快速的访问包(pack)里面的对象。 _parent_ > A commit object contains a (possibly empty) list > > ~~~ > of the logical predecessor(s) in the line of development, i.e. its > parents. > > ~~~ _父对象_ > 一个提交对象(commit object),()。 _pickaxe_ > The term pickaxe refers to an option to the diffcore > > ~~~ > routines that help select changes that add or delete a given text > string. With the `--pickaxe-all` option, it can be used to view the full > changeset that introduced or removed, say, a > particular line of text. See git diff. > > ~~~ _plumbing_ > core git的别名(cute name)。 _porcelain_ > Cute name for programs and program suites depending on > > ~~~ > core git, presenting a high level access to > core git. Porcelains expose more of a SCM > interface than the plumbing. > > ~~~ _pull(拉)_ > 拉(pull)一个分支意味着,把它抓取(fetch)下来并合并(merge)进当前的分支。可以参考 [git pull](http://www.kernel.org/pub/software/scm/git/docs/git-pull.html). _push_ > Pushing a branch means to get the branch's > > ~~~ > head ref from a remote repository, > find out if it is a direct ancestor to the branch's local > head ref, and in that case, putting all > objects, which are reachable from the local > head ref, and which are missing from the remote > repository, into the remote > object database, and updating the remote > head ref. If the remote head is not an > ancestor to the local head, the push fails. > > ~~~ _推_ > () _reachable_ > All of the ancestors of a given commit are said to be > > ~~~ > "reachable" from that commit. More > generally, one object is reachable from > another if we can reach the one from the other by a chain > that follows tags to whatever they tag, > commits to their parents or trees, and > trees to the trees or blobs > that they contain. > > ~~~ > > _可达的_ _rebase_ > 重新应用(reapply)当前点(branch)和另一个点(base)间的修改;并且根据rebase的结果重置当前分支的 head。 译者注:这个功能可以修改历史提交。 _ref(引用)_ > 一个40字节长的SHA1串或是表示某个对象的名字。它们可能存储在 `$GIT_DIR/refs/`。 _reflog_ > reflog用以表示本地的ref的历史记录。从另外一角度也可以说,它能行告诉你这个仓库最近的第3个版本(revision)是什么,还可以告诉你昨天晚上9点14分时你是在这个仓库的哪个分支下工作。可以参见:[git reflog](http://www.kernel.org/pub/software/scm/git/docs/git-reflog.html)。 _refspec_ > "refspec"用于描述在抓取和推的过程中,远程ref和本地ref之间的映射关系。它用冒号连接::,前面也可以加一个加号:“+“。 例如:`git fetch $URL refs/heads/master:refs/heads/origin` 意味着:从$URL抓取主分支的 head 并把它保存到本地的origin分支的head中。`git push $URL refs/heads/master:refs/heads/to-upstream` 意味着:把我本地主分支 head 推到$URL上的 to-upstream分支里。具体可以参见: [git push](http://www.kernel.org/pub/software/scm/git/docs/git-push.html)。 _repository_ > A collection of refs together with an > > ~~~ > object database containing all objects > which are reachable from the refs, possibly > accompanied by meta data from one or more porcelains. A > repository can share an object database with other repositories > via alternates mechanism. > > ~~~ _resolve_ > 在自动合并失败后,手工修复合并冲突的行为。 _revision(版本)_ > 对象仓库(object database)保存的文件和目录在某一特定时间点的状态;它会被一个提交对象(commit object)所引用。 _rewind_ > 丢弃某一部分开发成果。例如:把head 指向早期的版本。 _SCM_ > 源代码管理工作。 _SHA1_ > 对象名(object name)的同义词。 _shallow repository_ > A shallow repository has an incomplete > > ~~~ > history some of whose commits have parents cauterized away (in other > words, git is told to pretend that these commits do not have the > parents, even though they are recorded in the commit > object). This is sometimes useful when you are interested only in the > recent history of a project even though the real history recorded in the > upstream is much larger. A shallow repository > is created by giving the `--depth` option to git clone, and > its history can be later deepened with git fetch. > > ~~~ _symref_ > Symbolic reference: instead of containing the SHA1 > > ~~~ > id itself, it is of the format 'ref: refs/some/thing' and when > referenced, it recursively dereferences to this reference. > 'HEAD' is a prime example of a symref. Symbolic > references are manipulated with the git symbolic-ref > command. > > ~~~ _tag(标签)_ > 一个ref指向一个标签或提交对象。与 head 相反,标签并不会在一次提交操作后改变。标签(不是标签对象)存储在`$GIT_DIR/refs/tags/`。 一个标签通常是用来标识提交家族链(commit ancerstry chain)里的某一点。 _tag object(标签对象)_ > 一个含有指向其它对象的引用(ref)的对象,对象里包括注释消息。如果它里面可以含有一个PGP签名,那么就称为一个“签名标签对象”(signed tag object)。 _topic branch_ > A regular git branch that is used by a developer to > > ~~~ > identify a conceptual line of development. Since branches are very easy > and inexpensive, it is often desirable to have several small branches > that each contain very well defined concepts or small incremental yet > related changes. > > ~~~ _tracking branch_ > A regular git branch that is used to follow changes from > > ~~~ > another repository. A tracking > branch should not contain direct modifications or have local commits > made to it. A tracking branch can usually be > identified as the right-hand-side ref in a Pull: > > ~~~ ~~~ refspec. ~~~ _追踪分支_ > 一个用以追踪(follow)另外一个仓库的修改的git分支。() _tree(树)_ > 可以是一个工作树(working tree),也可以是一个树对象(tree object)。 _tree object(树对象)_ > 包含有一串(list)文件名和模式(mode),并且指向与之相关的二进制对象(blob object)和树对象(tree object)。一个树(tree)等价于一个目录。 _tree-ish(树名)_ > 一个指向的提交对象(commit object),树对象(tree object)或是标签对象(tag object)的引用(ref)。 _unmerged index(未合并索引)_ > 一个索引中包含有未合并的索引条目(index entries)。 _unreachable object(不可达对象)_ > 从任何一个分支、标签或是其它引用(reference)做为起点都无法到达的一个对象。 _working tree(工作树)_ > 签出(checkout)用于编辑的文件目录树。 工作树一般等价于 HEAD 加本地没有提交的修改。
';