I recently learned about git blame and what it does. I want to know how git finds when each line was changed in a file, even across file renames. In other words, I want to know how the blame algorithm works.
How does git create a file blame?
378 Views Asked by Rak Laptudirm At
1
There are 1 best solutions below
Related Questions in GIT
- Push mysql database script to server using git
- Git show's file path
- Git > diffs filtered, show only certain changed classes/files
- Pushing to git repository hosted by Visual studio online without entering user name and password
- How do I create my own Git branch to work on?
- Git init --bare giving error fatal: Out of memory? mmap failed: No such device
- Sub-directory into independent repository and later merge back into main repository
- How to find the Git Revision Hash in a synced SVN repo using SubGit?
- eclipse errors when try to change to master git branch
- How to have Heroku build my development branch on a staging server?
- Is "Merged in" a commit message created by bitbucket, or git?
- Git: Multiple projects under one directory
- Permission denied hg-git
- Is it possible to clone a private git repo without adding ssh keys
- Track file in master repository which is ignored in submodule
Related Questions in BLAME
- How can I view prior commits with git blame?
- Determine when a line was modified in a file
- How to see all matching ranges with git blame?
- Is there a blame/annotate for 'MKS Source Integrity'?
- Where is git-blame in SourceTree
- How do you find who merged a git commit into a branch?
- What is the equivalence of Git-blame in bazaar?
- How does git create a file blame?
- Tortoise SVN blame displays non-sense
- How to git blame to see what code from a single committer before X date has survived?
- Using git to find first introduction of token on a specific line of a file
- Subversion - Commiting a Re-formatted File
- Git blame for all revesions of a file
- JGit BlameCommand keeps returning null
- Git: Get username vs number of lines for a particular file type in HEAD
Related Questions in GIT-BLAME
- Blame information not displayed in few SonarQube projects
- Is there any way to do a git blame on the assets file in Xcode?
- Convince git blame that one branch is more relevant to history than another
- Meaning of double dot (..) when using it with git-blame command
- how to fix Losing git blame feature after commit? (EOL conflict)
- Git log for a specific line in a file between the commit id and a prior date?
- VS Code: Find occurrences of text only in changes made by me
- How to enable git blame on every file in project in intelliJ
- Where is git-blame in SourceTree
- How does git create a file blame?
- Git: How to restore a file history blame track after changed its EOL?
- How to continue blaming in git
- How to find all the "active" git commits in a tree?
- How can I show annotations in PhpStorm/WebStorm search preview
- Getting all lines by author per file in git
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
First of all, the
blamefeature exists in almost all others SCM too, including CVS. So the algorithm used will vary according to the tool you're using.Basically, however, the simplest way to achieve this is starting from the most recent state of your file, then browsing history backwards (toward the past) and applying the negative of each changeset.
Every affected row is marked as belonging to last commit, all other rows to previous one. Aside of this, you'll count the number of these latter rows. Then you restart this process with commit n-1 and n-2. If the rows don't explicitly belong to "n-1", they are ignored because this means they've been altered by some more recent commit (actually, the reverse changeset will still be applied, but commit number won't be updated). Otherwise, you apply the same computations, updating the commit number each row belongs to.
You then just have to iterate on this all the way down 'til initial commit if needed but if you reached a state where the "number of rows" quoted above reaches zero, you know you can stop here because it means that all the rows have been altered since the original state of the file and there's no more need to go any further.