From: Toshi MARUYAMA Date: Mon, 3 Jan 2011 10:45:00 +0000 (+0000) Subject: repository: git: change io.gets to io.readlines (#5404, #5096). X-Git-Tag: 1.2.0~1139 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=7958facadcc30fcce2f9ba27602944e713ce85f6;p=redmine.git repository: git: change io.gets to io.readlines (#5404, #5096). git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4624 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- 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