summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-01-03 10:54:29 +0000
committerToshi MARUYAMA <marutosijp2@yahoo.co.jp>2011-01-03 10:54:29 +0000
commitd97297e45d8584067641d3f4008f8cf85558033e (patch)
tree7a7d2f60c341c050af4411a313561b516c278b32 /lib
parentf06500dcce1d6f36f289cf20ba2092574d27e58b (diff)
downloadredmine-d97297e45d8584067641d3f4008f8cf85558033e.tar.gz
redmine-d97297e45d8584067641d3f4008f8cf85558033e.zip
Merged r4624 from trunk.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/branches/1.1-stable@4627 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'lib')
-rw-r--r--lib/redmine/scm/adapters/git_adapter.rb16
1 files changed, 8 insertions, 8 deletions
diff --git a/lib/redmine/scm/adapters/git_adapter.rb b/lib/redmine/scm/adapters/git_adapter.rb
index cd8fd95d4..302ded580 100644
--- a/lib/redmine/scm/adapters/git_adapter.rb
+++ b/lib/redmine/scm/adapters/git_adapter.rb
@@ -89,12 +89,13 @@ module Redmine
cmd = "#{GIT_BIN} --git-dir #{target('')} log --no-color --date=iso --pretty=fuller --no-merges -n 1 "
cmd << " #{shell_quote rev} " if rev
cmd << "-- #{shell_quote path} " unless path.empty?
- shellout(cmd) do |io|
- begin
- id = io.gets.split[1]
- author = io.gets.match('Author:\s+(.*)$')[1]
- 2.times { io.gets }
- time = Time.parse(io.gets.match('CommitDate:\s+(.*)$')[1]).localtime
+ lines = []
+ shellout(cmd) { |io| lines = io.readlines }
+ return nil if $? && $?.exitstatus != 0
+ begin
+ id = lines[0].split[1]
+ author = lines[1].match('Author:\s+(.*)$')[1]
+ time = Time.parse(lines[4].match('CommitDate:\s+(.*)$')[1]).localtime
Revision.new({
:identifier => id,
@@ -104,10 +105,9 @@ module Redmine
:message => nil,
:paths => nil
})
- rescue NoMethodError => e
+ rescue NoMethodError => e
logger.error("The revision '#{path}' has a wrong format")
return nil
- end
end
end