aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Contributions/cmds/brew-pull.rb
diff options
context:
space:
mode:
authorMike McQuaid2012-03-18 15:33:21 +1300
committerMike McQuaid2012-03-18 15:34:41 +1300
commite33937a1e35e75dffae043f22e975bfd51dea409 (patch)
tree0c04edf7d597577808d5dc72a68718e047052168 /Library/Contributions/cmds/brew-pull.rb
parentd47cf55f68fb1d381cfbdc9de905dc33c7ce5a83 (diff)
downloadbrew-e33937a1e35e75dffae043f22e975bfd51dea409.tar.bz2
Rename external commands directory from examples.
Fixes Homebrew/homebrew#10829.
Diffstat (limited to 'Library/Contributions/cmds/brew-pull.rb')
-rwxr-xr-xLibrary/Contributions/cmds/brew-pull.rb78
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