Examining a repository | Git status

Examining a repository | Git status

Git status


gitstatus

Definition

The git status command shows the state of the working directory and the staging area. It allows you to see staged changes and the files that aren’t being tracked by Git. The Status output does not display any information about the committed project history. For this purpose, use the git log command. The git status simply displays what has been going on with git add and git commit commands.

Usage

The git status lists which files are staged, unstaged, and untracked.
git status

Common options

-s or --shortOutputs in the short-format.
-b or --branchDisplays the branch and tracking information in the short-format.
--porcelainOutputs in an easy-to-parse format for scripts. It remains stable across Git versions and does not take into consideration the user configuration.
--longOutputs in the long-format (default).
-u[<mode>] --untracked-files[=<mode>]Displays the untracked files.
The mode parameter is optional is used to manage the untracked files.
The possible options are:
no - displays no untracked files.
normal - displays untracked files and directories.
all - Also displays individual files in untracked directories.
--ignore-submodules[=<when>]Ignores changes to submodules when looking for changes. <when> can be "none", "untracked", "dirty" and "all".
--ignoredDisplays ignored files.
-zTerminates entries with NUL. If no format is given the --porcelain output format is used.
--column[=<options>] --no-columnDisplays untracked files in columns. If no option is used with the --column and --no-column without options are equivalent to always and never.

Ignoring Files

Untracked files can be of two types: ones that have not been added and committed to the project and the ones that are binaries like .pyc, .obj, .exe, etc. If binaries are included in git status output, you cannot see the actual state of your repository. Thus, Git puts paths in the .gitignore file to ignore these files. The ones that you do not want to ignore, will be included on a separate line. The * symbol is used as a wildcard:
*.obj

Explanation

It is very important to check the state of the repository before committing any change. The following example shows the repository status before and after staging and committing:
# Edit w3docs.txt

git status
# w3docs.txt is listed under "Changes not staged for commit"

git add w3docs.txt
git status
# w3docs.txt is listed under "Changes to be committed"

git commit
git status
# nothing to commit (working directory clean)
The first status shows the unstaged file. In the second status, git add action will be followed. The third stats output shows that there is nothing to commit.
Soeng Souy

Soeng Souy

Website that learns and reads, PHP, Framework Laravel, How to and download Admin template sample source code free.

Post a Comment

CAN FEEDBACK
close