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/examples/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/examples/brew-pull.rb')
| -rwxr-xr-x | Library/Contributions/examples/brew-pull.rb | 78 |
1 files changed, 0 insertions, 78 deletions
diff --git a/Library/Contributions/examples/brew-pull.rb b/Library/Contributions/examples/brew-pull.rb deleted file mode 100755 index 30d04120b..000000000 --- a/Library/Contributions/examples/brew-pull.rb +++ /dev/null @@ -1,78 +0,0 @@ -# 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 |
