- It allows users to work productively without network connection, and
- it makes most operations much faster, since most operations are local.
- index (also called staging area or cache) -- a mutable file that caches information about the working directory, and
- object database -- an immutable, append-only storage that stores files and meta-data for our project.
- blob (binary large object) -- each file that we add to the repository is turned into a blob object.
- tree -- each directory is turned into a tree object.
- commit -- a commit is a snapshot of the working directory at a point in time.
- tag -- a container that contains reference to another object.
The index (staging area) serves as a bridge between the working directory and the object database. Information stored in the index will go into the object database at our next commit. The following figure shows the normal work flow among them.
Working Index Object
directory database
<--------checkout-----------|
|-----add---->
|---commit--->
Each file in our working directory can be in one of two states: tracked or untracked. Tracked files are those that are in the last snapshot or in the index (staging area); they can be further classified as unmodified, modified, or staged. A staged file is one that has been modified/created and added to the index. Untracked files are everything else. The lifecycle of files in working directory is illustrated in the following figure:
untracked unmodified modified staged
|----------------------add------------------------->
<---------------------reset------------------------|
|-----edit------>
|------add----->
<----------commit-------------|
The command git ls-files lists tracked files, whereas git ls-file -o (option o) lists untracked files.