NAME
docs/project/git_terminology.pod - Git Terminology
DESCRIPTION
This document describes terms that are used in docs/project/git_workflow.pod and contains generally useful things to know about Git.
INTRODUCTION
Before learning any terminology, there are a few very basic things that should be understood about Git, which will provide a foundation for understanding anything else.
A Git repository is a Directed Acyclic Graph (DAG), where each node in the graph is a commit, with zero or more parents. A root commit of a repository has zero parents, others have at least one parent. A repository may have any number of root commits, but many have only one. If a commit has more than one parent, that means it was the result of a merge.
Each commit is uniquely identified by a SHA1 sum. You may refer to any commit by the first few characters of a SHA1 sum, as long as it is unique. If it is not unique, git
will complain loudly. Usually 6-7 characters of a SHA1 is sufficient, but this number increases as the number of commits in a repo grows.
There are three distinct "places" in a Git repository, which are referred to as the index, the working copy, and the staging area. The index is the actual DAG, where all the history of the repo is stored. This lives in the .git directory of a repository. The "working copy" are the actual files on the filesystem. The staging area is where things that will be included in the next commit live, which happens to be inside the .git directory as well. When you type git add foo
, you are adding the file/directory foo to the staging area. When you type git log
you are asking the index to show you a log of all commits. When you run a non-git command in a repo, such as rm foo
, you are modifying the working copy.
The most important thing to learn when understanding a git
command is whether it operates on the index, working copy, staging area or a combination of the three. Also note that certain git
commands can operate on different areas when given different command-line options.
HELPING YOURSELF
Git comes with extensive documentation. To get the short help summary for a git command, do git cmd -h
. To see the manual for a git command, type git help cmd
, where "cmd" is the name of the command you want to look up.
TERMS
branch
Noun. A symbolic name referring to a commit SHA1. The master branch is just a branch called master, it is not special in any way except that it is the default.
Verb. To create a divergent history of commits from a given commit, branch or tag.
clone
Verb. The term used for copying a remote repo locally, which contains the entire history of the git repo being cloned.
commit-ish, committish
Noun. A general term for a way to describe a set of commits.
rebase
Verb. Update the local index with changes from a remote, then replay local changes, in order, on top of them. This prevents "useless merge commits", such as:
Merge branch 'master' of github.com:parrot/parrot
The git pull --rebase
command can be used to update your master branch from the remote called 'origin'. There is also a git rebase
command that can be used to rebase branches onto each other.
remote
Noun. A remote is basically a URL with metadata that describes where changes are pushed/pulled from. A git repo may have any number of remotes. The default remote is where the repo was originally cloned from and it has the name "origin".
repo
Noun. Short for repository.
SHA1
Noun. Secure Hash Algorithm 1. Also called a SHA1 sum or SHA1 hash. Every git commit is uniquely identified by a SHA1. This is roughly similar to a Subversion Revision, but it is not an integer and does not increase linearly, because git commits can have any number of parents.
tag
Noun. A symbolic name for a SHA1. A tag is like a variable, which points to a specific SHA1. Tags can change, but usually they don't. A tag is akin to a domain name, which points to an IP address. Run git help tag
for more information.
Verb. The process of giving a sha1 a symbolic name, such as giving commit 9560334cf the symbolic name "RELEASE_42_0_1".
topic branch
Noun. Any branch that is not the master branch.
SEE ALSO
docs/project/git_workflow.pod