aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMike McQuaid2012-03-08 00:43:15 -0800
committerMike McQuaid2012-03-29 18:30:38 +1100
commit8c338a6bb1827b8631cab5d5ecb6587b6c3cd905 (patch)
tree011cbf2af1598c5cb16721c0dca5ad6acfb430e2
parent4ddbb335d0096a94ea3c11e4ff1ee63a8a71bc11 (diff)
downloadbrew-8c338a6bb1827b8631cab5d5ecb6587b6c3cd905.tar.bz2
Cleanup brew-pull code.
-rwxr-xr-xLibrary/Contributions/cmds/brew-pull.rb108
1 files changed, 53 insertions, 55 deletions
diff --git a/Library/Contributions/cmds/brew-pull.rb b/Library/Contributions/cmds/brew-pull.rb
index 30d04120b..f7e2516d5 100755
--- a/Library/Contributions/cmds/brew-pull.rb
+++ b/Library/Contributions/cmds/brew-pull.rb
@@ -1,77 +1,75 @@
# Gets a patch from a GitHub commit or pull request and applies it to Homebrew.
# Optionally, installs it too.
-require 'utils.rb'
-
-if ARGV.include? '--install'
- ARGV.delete '--install'
- install = true
-end
+require 'utils'
if ARGV.empty?
onoe 'This command requires at least one argument containing a URL or pull request number'
end
-HOMEBREW_REPOSITORY.cd do
- ARGV.named.each do|arg|
- if arg.to_i > 0
- url = 'https://github.com/mxcl/homebrew/pull/' + arg + '.patch'
- else
- # This regex should work, if it's too precise, feel free to fix it.
- urlmatch = arg.match 'https:\/\/github.com\/\w+\/homebrew\/(pull\/(\d+)|commit\/\w{4,40})'
- if !urlmatch
- ohai 'Ignoring URL:', "Not a GitHub pull request or commit: #{arg}"
- next
- end
+Dir.chdir HOMEBREW_REPOSITORY
- # GitHub provides commits'/pull-requests' raw patches using this URL.
- url = urlmatch[0] + '.patch'
+ARGV.named.each do|arg|
+ if arg.to_i > 0
+ url = 'https://github.com/mxcl/homebrew/pull/' + arg
+ else
+ # This regex should work, if it's too precise, feel free to fix it.
+ url_match = arg.match 'https:\/\/github.com\/\w+\/homebrew\/(pull\/(\d+)|commit\/\w{4,40})'
+ unless url_match
+ ohai 'Ignoring URL:', "Not a GitHub pull request or commit: #{arg}"
+ next
end
- # The cache directory seems like a good place to put patches.
- HOMEBREW_CACHE.mkpath
- patchpath = (HOMEBREW_CACHE+File.basename(url))
- curl url, '-o', patchpath
+ url = url_match[0]
+ end
+
+ # GitHub provides commits'/pull-requests' raw patches using this URL.
+ url += '.patch'
- # Store current revision
- revision = `git log -n1 --format=%H`.strip()
+ # The cache directory seems like a good place to put patches.
+ HOMEBREW_CACHE.mkpath
+ patchpath = HOMEBREW_CACHE + File.basename(url)
+ curl url, '-o', patchpath
- ohai 'Applying patch'
- patch_args = %w[am --signoff]
- # Normally we don't want whitespace errors, but squashing them can break
- # patches so an option is provided to skip this step.
- patch_args << '--whitespace=fix' unless ARGV.include? '--ignore-whitespace'
- patch_args << patchpath
+ # Store current revision
+ revision = `git rev-parse --short HEAD`.strip
- safe_system 'git', *patch_args
+ ohai 'Applying patch'
+ patch_args = ['am']
+ patch_args << '--signoff' unless ARGV.include? '--clean'
+ # Normally we don't want whitespace errors, but squashing them can break
+ # patches so an option is provided to skip this step.
+ patch_args << '--whitespace=fix' unless ARGV.include? '--ignore-whitespace' or ARGV.include? '--clean'
+ patch_args << patchpath
- issue = arg.to_i > 0 ? arg.to_i : urlmatch[2]
- if issue
- ohai "Patch closes issue ##{issue}"
- message = `git log HEAD^.. --format=%B`
+ safe_system 'git', *patch_args
- # If this is a pull request, append a close message.
- if !message.include? 'Closes #'
- issueline = "Closes ##{issue}."
- signed = 'Signed-off-by:'
- message = message.gsub signed, issueline + "\n\n" + signed
- safe_system 'git', 'commit', '--amend', '-q', '-m', message
- end
+ issue = arg.to_i > 0 ? arg.to_i : url_match[2]
+ if issue and not ARGV.include? '--clean'
+ ohai "Patch closes issue ##{issue}"
+ message = `git log HEAD^.. --format=%B`
+
+ # If this is a pull request, append a close message.
+ unless message.include? 'Closes #'
+ issueline = "Closes ##{issue}."
+ signed = 'Signed-off-by:'
+ message = message.gsub signed, issueline + "\n\n" + signed
+ safe_system 'git', 'commit', '--amend', '-q', '-m', message
end
+ end
- ohai 'Patch changed:'
- safe_system 'git', 'diff', "#{revision}..", '--stat'
+ ohai 'Patch changed:'
+ safe_system 'git', 'diff', "#{revision}..", '--stat'
- if install
- `git diff #{revision}.. --name-status`.each_line do |line|
- status, filename = line.split()
- # Don't try and do anything to removed files.
- if (status == 'A' or status == 'M') and filename.include? '/Formula/'
- formula = File.basename(filename, '.rb')
- ohai "Installing #{formula}"
- # Not sure if this is the best way to install?
- safe_system 'brew', 'install', '--force', '--build-bottle', formula
- end
+ if ARGV.include? '--install'
+ `git diff #{revision}.. --name-status`.each_line do |line|
+ status, filename = line.split
+ # Don't try and do anything to removed files.
+ if (status == 'A' or status == 'M') and filename.include? '/Formula/'
+ formula = File.basename(filename, '.rb')
+ ohai "Installing #{formula}"
+ # Not sure if this is the best way to install?
+ safe_system 'brew', 'install', '--force', '--build-bottle', formula
end
end
end