diff options
| author | Mike McQuaid | 2012-03-18 15:33:21 +1300 |
|---|---|---|
| committer | Mike McQuaid | 2012-03-18 15:34:41 +1300 |
| commit | e33937a1e35e75dffae043f22e975bfd51dea409 (patch) | |
| tree | 0c04edf7d597577808d5dc72a68718e047052168 /Library/Contributions/cmds/brew-pull.rb | |
| parent | d47cf55f68fb1d381cfbdc9de905dc33c7ce5a83 (diff) | |
| download | brew-e33937a1e35e75dffae043f22e975bfd51dea409.tar.bz2 | |
Rename external commands directory from examples.
Fixes Homebrew/homebrew#10829.
Diffstat (limited to 'Library/Contributions/cmds/brew-pull.rb')
| -rwxr-xr-x | Library/Contributions/cmds/brew-pull.rb | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/Library/Contributions/cmds/brew-pull.rb b/Library/Contributions/cmds/brew-pull.rb new file mode 100755 index 000000000..30d04120b --- /dev/null +++ b/Library/Contributions/cmds/brew-pull.rb @@ -0,0 +1,78 @@ +# 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 + +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 + + # GitHub provides commits'/pull-requests' raw patches using this URL. + url = urlmatch[0] + '.patch' + 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 + + # Store current revision + revision = `git log -n1 --format=%H`.strip() + + 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 + + safe_system 'git', *patch_args + + issue = arg.to_i > 0 ? arg.to_i : urlmatch[2] + if issue + ohai "Patch closes issue ##{issue}" + message = `git log HEAD^.. --format=%B` + + # 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 + end + + 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 + end + end + end +end |
