git-blame
Show what revision and author last modified each line
TLDR
Blame a file
SYNOPSIS
git blame [options] [rev] [--] file
DESCRIPTION
git blame shows what revision and author last modified each line of a file. It annotates each line with commit information, helping identify when and why changes were made.
The command is essential for code archaeology, understanding code history, and finding who to ask about specific code. Options like -M and -C detect moved and copied code across files to show original authorship rather than the person who relocated it.
Line ranges can be specified with -L to focus on specific sections, and -w ignores whitespace changes to find meaningful modifications. The output is invaluable for debugging, code review, and understanding the evolution of specific code sections.
PARAMETERS
FILE
File to annotate.-L START,END
Annotate specific line range.-e, --show-email
Show author email.-w
Ignore whitespace changes.-M
Detect moved lines within file.-C
Detect lines copied from other files.--since DATE
Show only commits since date.--help
Display help information.
CAVEATS
Large files can be slow. Blame follows renames by default. History rewriting changes blame output.
HISTORY
git blame is a core Git command inspired by similar functionality in CVS and SVN, essential for understanding code evolution.
SEE ALSO
git-log(1), git-bisect(1), git-show(1)
