scm: mercurial: rewrite MercurialAdapter#diff by using helper extension (#4455, #7518).

fix incompatibility of diff with Mercurial < 1.1.

Contributed by Yuya Nishihara.

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4854 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Toshi MARUYAMA 2011-02-16 11:17:58 +00:00 committed by Eric Davis
parent 6840897f38
commit cb26f0adf9
1 changed files with 9 additions and 17 deletions

View File

@ -159,27 +159,19 @@ module Redmine
end end
def diff(path, identifier_from, identifier_to=nil) def diff(path, identifier_from, identifier_to=nil)
path ||= '' hg_args = %w|rhdiff|
diff_args = ''
diff = []
if identifier_to if identifier_to
diff_args = "-r #{hgrev(identifier_to, true)} -r #{hgrev(identifier_from, true)}" hg_args << '-r' << hgrev(identifier_to) << '-r' << hgrev(identifier_from)
else else
if self.class.client_version_above?([1, 2]) hg_args << '-c' << hgrev(identifier_from)
diff_args = "-c #{hgrev(identifier_from, true)}"
else
return []
end
end end
cmd = "#{self.class.sq_bin} -R #{target('')} --config diff.git=false diff --nodates #{diff_args}" hg_args << CGI.escape(hgtarget(path)) unless path.blank?
cmd << " -I #{target(path)}" unless path.empty?
shellout(cmd) do |io| hg *hg_args do |io|
io.each_line do |line| io.collect
diff << line
end
end end
return nil if $? && $?.exitstatus != 0 rescue HgCommandAborted
diff nil # means not found
end end
def cat(path, identifier=nil) def cat(path, identifier=nil)