From 3355ffe029fdecbe78a75f7f459bd93eae835a42 Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Wed, 3 Mar 2010 21:15:46 +0000 Subject: Fixes git annotate (#3832). git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3531 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- lib/redmine/scm/adapters/git_adapter.rb | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) (limited to 'lib/redmine') diff --git a/lib/redmine/scm/adapters/git_adapter.rb b/lib/redmine/scm/adapters/git_adapter.rb index ae619e032..d15bce1af 100644 --- a/lib/redmine/scm/adapters/git_adapter.rb +++ b/lib/redmine/scm/adapters/git_adapter.rb @@ -235,14 +235,15 @@ module Redmine # git annotates binary files return nil if content.is_binary_data? identifier = '' - author = '' + # git shows commit author on the first occurrence only + authors_by_commit = {} content.split("\n").each do |line| if line =~ /^([0-9a-f]{39,40})\s.*/ identifier = $1 elsif line =~ /^author (.+)/ - author = $1.strip + authors_by_commit[identifier] = $1.strip elsif line =~ /^\t(.*)/ - blame.add_line($1, Revision.new(:identifier => identifier, :author => author)) + blame.add_line($1, Revision.new(:identifier => identifier, :author => authors_by_commit[identifier])) identifier = '' author = '' end -- cgit v1.2.3