2017-02-25 17:37:57 -05:00
|
|
|
#: * `bump-formula-pr` [`--devel`] [`--dry-run` [`--write`]] [`--audit`|`--strict`] [`--mirror=`<URL>] [`--version=`<version>] [`--message=`<message>] (`--url=`<URL> `--sha256=`<sha-256>|`--tag=`<tag> `--revision=`<revision>) <formula>:
|
|
|
|
#: Creates a pull request to update the formula with a new URL or a new tag.
|
2016-08-08 03:42:40 -04:00
|
|
|
#:
|
2017-02-25 17:37:57 -05:00
|
|
|
#: If a <URL> is specified, the <sha-256> checksum of the new download must
|
2016-09-27 03:29:47 -07:00
|
|
|
#: also be specified. A best effort to determine the <sha-256> and <formula>
|
|
|
|
#: name will be made if either or both values are not supplied by the user.
|
2016-08-08 03:42:40 -04:00
|
|
|
#:
|
|
|
|
#: If a <tag> is specified, the git commit <revision> corresponding to that
|
|
|
|
#: tag must also be specified.
|
|
|
|
#:
|
|
|
|
#: If `--devel` is passed, bump the development rather than stable version.
|
|
|
|
#: The development spec must already exist.
|
|
|
|
#:
|
|
|
|
#: If `--dry-run` is passed, print what would be done rather than doing it.
|
|
|
|
#:
|
2016-09-27 03:29:47 -07:00
|
|
|
#: If `--write` is passed along with `--dry-run`, perform a not-so-dry run
|
|
|
|
#: making the expected file modifications but not taking any git actions.
|
|
|
|
#:
|
2016-06-17 10:10:47 -07:00
|
|
|
#: If `--audit` is passed, run `brew audit` before opening the PR.
|
|
|
|
#:
|
|
|
|
#: If `--strict` is passed, run `brew audit --strict` before opening the PR.
|
|
|
|
#:
|
2017-02-25 17:37:57 -05:00
|
|
|
#: If `--mirror=`<URL> is passed, use the value as a mirror URL.
|
2016-09-27 03:29:47 -07:00
|
|
|
#:
|
|
|
|
#: If `--version=`<version> is passed, use the value to override the value
|
2017-02-25 17:37:57 -05:00
|
|
|
#: parsed from the URL or tag. Note that `--version=0` can be used to delete
|
2016-09-27 03:29:47 -07:00
|
|
|
#: an existing `version` override from a formula if it has become redundant.
|
|
|
|
#:
|
2016-11-15 11:37:49 -05:00
|
|
|
#: If `--message=`<message> is passed, append <message> to the default PR
|
|
|
|
#: message.
|
|
|
|
#:
|
2017-10-30 09:14:53 +00:00
|
|
|
#: If `--no-browse` is passed, don't pass the `--browse` argument to `hub`
|
|
|
|
#: which opens the pull request URL in a browser. Instead, output it to the
|
|
|
|
#: command line.
|
|
|
|
#:
|
2018-02-01 16:06:17 -05:00
|
|
|
#: If `--quiet` is passed, don't output replacement messages or warn about
|
|
|
|
#: duplicate pull requests.
|
|
|
|
#:
|
2016-08-08 03:42:40 -04:00
|
|
|
#: Note that this command cannot be used to transition a formula from a
|
2017-02-25 17:37:57 -05:00
|
|
|
#: URL-and-sha256 style specification into a tag-and-revision style
|
2016-08-08 03:42:40 -04:00
|
|
|
#: specification, nor vice versa. It must use whichever style specification
|
|
|
|
#: the preexisting formula already uses.
|
2016-03-17 05:58:14 +00:00
|
|
|
|
|
|
|
require "formula"
|
2018-03-25 23:49:54 +05:30
|
|
|
require "cli_parser"
|
2016-03-17 05:58:14 +00:00
|
|
|
|
|
|
|
module Homebrew
|
2016-09-26 01:44:51 +02:00
|
|
|
module_function
|
|
|
|
|
2018-03-25 23:49:54 +05:30
|
|
|
def bump_formula_pr
|
|
|
|
@args = Homebrew::CLI::Parser.parse do
|
|
|
|
switch "--devel"
|
|
|
|
switch "-n", "--dry-run"
|
|
|
|
switch "--write"
|
|
|
|
switch "--audit"
|
|
|
|
switch "--strict"
|
|
|
|
switch "--no-browse"
|
|
|
|
switch :quiet
|
|
|
|
switch :force
|
|
|
|
switch :debug
|
|
|
|
flag "--url", required: true
|
|
|
|
flag "--sha256", required: true
|
|
|
|
flag "--mirror", required: true
|
|
|
|
flag "--tag", required: true
|
|
|
|
flag "--revision", required: true
|
|
|
|
flag "--version", required: true
|
|
|
|
flag "--message", required: true
|
2017-02-12 09:22:26 -08:00
|
|
|
end
|
|
|
|
|
2017-10-28 21:46:11 +01:00
|
|
|
# As this command is simplifying user run commands then let's just use a
|
|
|
|
# user path, too.
|
|
|
|
ENV["PATH"] = ENV["HOMEBREW_PATH"]
|
|
|
|
|
2017-11-07 07:48:00 +00:00
|
|
|
# Use the user's browser, too.
|
|
|
|
ENV["BROWSER"] = ENV["HOMEBREW_BROWSER"]
|
|
|
|
|
2017-11-05 20:30:52 +00:00
|
|
|
# Setup GitHub environment variables
|
|
|
|
%w[GITHUB_USER GITHUB_PASSWORD GITHUB_TOKEN].each do |env|
|
|
|
|
homebrew_env = ENV["HOMEBREW_#{env}"]
|
|
|
|
next unless homebrew_env
|
|
|
|
next if homebrew_env.empty?
|
|
|
|
ENV[env] = homebrew_env
|
|
|
|
end
|
|
|
|
|
2018-03-04 00:12:59 +05:30
|
|
|
gh_api_errors = [GitHub::AuthenticationFailedError, GitHub::HTTPNotFoundError,
|
|
|
|
GitHub::RateLimitExceededError, GitHub::Error, JSON::ParserError].freeze
|
|
|
|
|
2016-03-17 05:58:14 +00:00
|
|
|
formula = ARGV.formulae.first
|
2017-02-12 09:22:26 -08:00
|
|
|
|
|
|
|
if formula
|
|
|
|
check_for_duplicate_pull_requests(formula)
|
|
|
|
checked_for_duplicates = true
|
|
|
|
end
|
|
|
|
|
2018-03-25 23:49:54 +05:30
|
|
|
new_url = @args.url
|
2016-09-04 11:20:03 -07:00
|
|
|
if new_url && !formula
|
2018-01-24 06:37:27 -08:00
|
|
|
# Split the new URL on / and find any formulae that have the same URL
|
|
|
|
# except for the last component, but don't try to match any more than the
|
|
|
|
# first five components since sometimes the last component isn't the only
|
|
|
|
# one to change.
|
|
|
|
new_url_split = new_url.split("/")
|
|
|
|
maximum_url_components_to_match = 5
|
|
|
|
components_to_match = [new_url_split.count - 1, maximum_url_components_to_match].min
|
|
|
|
base_url = new_url_split.first(components_to_match).join("/")
|
2016-09-04 11:20:03 -07:00
|
|
|
base_url = /#{Regexp.escape(base_url)}/
|
2018-03-25 23:49:54 +05:30
|
|
|
is_devel = @args.devel?
|
2016-09-04 11:20:03 -07:00
|
|
|
guesses = []
|
|
|
|
Formula.each do |f|
|
|
|
|
if is_devel && f.devel && f.devel.url && f.devel.url.match(base_url)
|
|
|
|
guesses << f
|
2017-09-24 19:24:46 +01:00
|
|
|
elsif f.stable&.url && f.stable.url.match(base_url)
|
2016-09-04 11:20:03 -07:00
|
|
|
guesses << f
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if guesses.count == 1
|
|
|
|
formula = guesses.shift
|
|
|
|
elsif guesses.count > 1
|
|
|
|
odie "Couldn't guess formula for sure: could be one of these:\n#{guesses}"
|
|
|
|
end
|
|
|
|
end
|
2016-03-17 05:58:14 +00:00
|
|
|
odie "No formula found!" unless formula
|
|
|
|
|
2017-02-12 09:22:26 -08:00
|
|
|
check_for_duplicate_pull_requests(formula) unless checked_for_duplicates
|
|
|
|
|
2018-03-25 23:49:54 +05:30
|
|
|
requested_spec, formula_spec = if @args.devel?
|
2016-03-17 05:58:14 +00:00
|
|
|
devel_message = " (devel)"
|
|
|
|
[:devel, formula.devel]
|
|
|
|
else
|
|
|
|
[:stable, formula.stable]
|
|
|
|
end
|
2016-03-28 00:29:48 +02:00
|
|
|
odie "#{formula}: no #{requested_spec} specification found!" unless formula_spec
|
2016-03-17 05:58:14 +00:00
|
|
|
|
|
|
|
hash_type, old_hash = if (checksum = formula_spec.checksum)
|
2018-03-25 23:49:54 +05:30
|
|
|
[checksum.hash_type, checksum.hexdigest]
|
2016-03-17 05:58:14 +00:00
|
|
|
end
|
|
|
|
|
2018-03-25 23:49:54 +05:30
|
|
|
new_hash = @args[hash_type]
|
|
|
|
new_tag = @args.tag
|
|
|
|
new_revision = @args.revision
|
|
|
|
new_mirror = @args.mirror
|
|
|
|
forced_version = @args.version
|
2016-03-17 05:58:14 +00:00
|
|
|
new_url_hash = if new_url && new_hash
|
|
|
|
true
|
|
|
|
elsif new_tag && new_revision
|
|
|
|
false
|
|
|
|
elsif !hash_type
|
2017-12-11 09:02:41 +00:00
|
|
|
odie "#{formula}: no --tag=/--revision= arguments specified!"
|
2017-01-09 12:16:55 +00:00
|
|
|
elsif !new_url
|
2017-12-11 09:02:41 +00:00
|
|
|
odie "#{formula}: no --url= argument specified!"
|
2016-03-17 05:58:14 +00:00
|
|
|
else
|
2018-01-24 06:54:14 -08:00
|
|
|
new_mirror = case new_url
|
|
|
|
when requested_spec != :devel && %r{.*ftp.gnu.org/gnu.*}
|
2018-01-24 06:49:31 -08:00
|
|
|
new_url.sub "ftp.gnu.org/gnu", "ftpmirror.gnu.org"
|
2018-01-24 06:54:14 -08:00
|
|
|
when %r{.*mirrors.ocf.berkeley.edu/debian.*}
|
|
|
|
new_url.sub "mirrors.ocf.berkeley.edu/debian", "mirrorservice.org/sites/ftp.debian.org/debian"
|
2016-09-04 11:21:08 -07:00
|
|
|
end
|
2018-01-24 06:49:31 -08:00
|
|
|
resource = Resource.new { @url = new_url }
|
2018-01-24 06:55:55 -08:00
|
|
|
resource.download_strategy = DownloadStrategyDetector.detect_from_url(new_url)
|
2018-01-24 03:51:23 -08:00
|
|
|
resource.owner = Resource.new(formula.name)
|
|
|
|
resource.version = forced_version if forced_version
|
|
|
|
odie "No --version= argument specified!" unless resource.version
|
|
|
|
resource_path = resource.fetch
|
2018-01-24 04:22:11 -08:00
|
|
|
tar_file_extensions = %w[.tar .tb2 .tbz .tbz2 .tgz .tlz .txz .tZ]
|
|
|
|
if tar_file_extensions.any? { |extension| new_url.include? extension }
|
|
|
|
gnu_tar_gtar_path = HOMEBREW_PREFIX/"opt/gnu-tar/bin/gtar"
|
|
|
|
gnu_tar_gtar = gnu_tar_gtar_path if gnu_tar_gtar_path.executable?
|
|
|
|
tar = which("gtar") || gnu_tar_gtar || which("tar")
|
|
|
|
if Utils.popen_read(tar, "-tf", resource_path) =~ %r{/.*\.}
|
|
|
|
new_hash = resource_path.sha256
|
|
|
|
else
|
|
|
|
odie "#{resource_path} is not a valid tar file!"
|
|
|
|
end
|
|
|
|
else
|
2018-01-24 03:51:23 -08:00
|
|
|
new_hash = resource_path.sha256
|
2016-09-04 11:28:38 -07:00
|
|
|
end
|
2016-03-17 05:58:14 +00:00
|
|
|
end
|
|
|
|
|
2018-03-25 23:49:54 +05:30
|
|
|
if @args.dry_run?
|
2016-03-17 05:58:14 +00:00
|
|
|
ohai "brew update"
|
|
|
|
else
|
|
|
|
safe_system "brew", "update"
|
|
|
|
end
|
|
|
|
|
2016-06-16 14:25:53 -07:00
|
|
|
old_formula_version = formula_version(formula, requested_spec)
|
|
|
|
|
2016-06-17 08:17:56 -07:00
|
|
|
replacement_pairs = []
|
2016-09-11 17:41:51 +01:00
|
|
|
if requested_spec == :stable && formula.revision.nonzero?
|
2016-06-17 08:17:56 -07:00
|
|
|
replacement_pairs << [/^ revision \d+\n(\n( head "))?/m, "\\2"]
|
|
|
|
end
|
|
|
|
|
2016-12-22 00:54:08 -05:00
|
|
|
replacement_pairs += formula_spec.mirrors.map do |mirror|
|
2018-01-24 07:00:41 -08:00
|
|
|
[/ +mirror \"#{Regexp.escape(mirror)}\"\n/m, ""]
|
2016-12-22 00:54:08 -05:00
|
|
|
end
|
2016-09-04 11:28:02 -07:00
|
|
|
|
2016-06-17 08:17:56 -07:00
|
|
|
replacement_pairs += if new_url_hash
|
2016-06-16 14:25:53 -07:00
|
|
|
[
|
2018-01-24 07:00:41 -08:00
|
|
|
[/#{Regexp.escape(formula_spec.url)}/, new_url],
|
2016-06-16 14:25:53 -07:00
|
|
|
[old_hash, new_hash],
|
|
|
|
]
|
|
|
|
else
|
|
|
|
[
|
|
|
|
[formula_spec.specs[:tag], new_tag],
|
|
|
|
[formula_spec.specs[:revision], new_revision],
|
|
|
|
]
|
2016-03-17 05:58:14 +00:00
|
|
|
end
|
|
|
|
|
2018-03-25 23:49:54 +05:30
|
|
|
backup_file = File.read(formula.path) unless @args.dry_run?
|
2016-06-17 10:10:47 -07:00
|
|
|
|
2016-09-04 11:28:02 -07:00
|
|
|
if new_mirror
|
2018-01-24 07:00:41 -08:00
|
|
|
replacement_pairs << [/^( +)(url \"#{Regexp.escape(new_url)}\"\n)/m, "\\1\\2\\1mirror \"#{new_mirror}\"\n"]
|
2016-09-04 11:28:02 -07:00
|
|
|
end
|
|
|
|
|
2016-07-06 05:00:45 -07:00
|
|
|
if forced_version && forced_version != "0"
|
2016-09-27 02:50:46 -07:00
|
|
|
if requested_spec == :stable
|
|
|
|
if File.read(formula.path).include?("version \"#{old_formula_version}\"")
|
|
|
|
replacement_pairs << [old_formula_version.to_s, forced_version]
|
2016-09-27 03:30:40 -07:00
|
|
|
elsif new_mirror
|
|
|
|
replacement_pairs << [/^( +)(mirror \"#{new_mirror}\"\n)/m, "\\1\\2\\1version \"#{forced_version}\"\n"]
|
2016-09-04 11:21:08 -07:00
|
|
|
else
|
2016-09-27 03:30:40 -07:00
|
|
|
replacement_pairs << [/^( +)(url \"#{new_url}\"\n)/m, "\\1\\2\\1version \"#{forced_version}\"\n"]
|
2016-09-04 11:21:08 -07:00
|
|
|
end
|
2016-09-27 02:50:46 -07:00
|
|
|
elsif requested_spec == :devel
|
|
|
|
replacement_pairs << [/( devel do.+?version \")#{old_formula_version}(\"\n.+?end\n)/m, "\\1#{forced_version}\\2"]
|
2016-09-04 11:21:08 -07:00
|
|
|
end
|
2016-07-06 05:00:45 -07:00
|
|
|
elsif forced_version && forced_version == "0"
|
2016-09-27 02:50:46 -07:00
|
|
|
if requested_spec == :stable
|
2018-01-24 07:01:20 -08:00
|
|
|
replacement_pairs << [/^ version \"[\w\.\-\+]+\"\n/m, ""]
|
2016-09-27 02:50:46 -07:00
|
|
|
elsif requested_spec == :devel
|
|
|
|
replacement_pairs << [/( devel do.+?)^ +version \"[^\n]+\"\n(.+?end\n)/m, "\\1\\2"]
|
|
|
|
end
|
2016-07-06 05:00:45 -07:00
|
|
|
end
|
2016-06-16 14:25:53 -07:00
|
|
|
new_contents = inreplace_pairs(formula.path, replacement_pairs)
|
|
|
|
|
|
|
|
new_formula_version = formula_version(formula, requested_spec, new_contents)
|
|
|
|
|
|
|
|
if new_formula_version < old_formula_version
|
2018-03-25 23:49:54 +05:30
|
|
|
formula.path.atomic_write(backup_file) unless @args.dry_run?
|
2017-10-15 02:28:32 +02:00
|
|
|
odie <<~EOS
|
2016-06-16 14:25:53 -07:00
|
|
|
You probably need to bump this formula manually since changing the
|
|
|
|
version from #{old_formula_version} to #{new_formula_version} would be a downgrade.
|
|
|
|
EOS
|
|
|
|
elsif new_formula_version == old_formula_version
|
2018-03-25 23:49:54 +05:30
|
|
|
formula.path.atomic_write(backup_file) unless @args.dry_run?
|
2017-10-15 02:28:32 +02:00
|
|
|
odie <<~EOS
|
2016-06-16 14:25:53 -07:00
|
|
|
You probably need to bump this formula manually since the new version
|
|
|
|
and old version are both #{new_formula_version}.
|
|
|
|
EOS
|
|
|
|
end
|
2016-03-17 05:58:14 +00:00
|
|
|
|
2018-03-25 23:49:54 +05:30
|
|
|
if @args.dry_run?
|
|
|
|
if @args.strict?
|
2016-06-17 10:10:47 -07:00
|
|
|
ohai "brew audit --strict #{formula.path.basename}"
|
2018-03-25 23:49:54 +05:30
|
|
|
elsif @args.audit?
|
2016-06-17 10:10:47 -07:00
|
|
|
ohai "brew audit #{formula.path.basename}"
|
|
|
|
end
|
|
|
|
else
|
|
|
|
failed_audit = false
|
2018-03-25 23:49:54 +05:30
|
|
|
if @args.strict?
|
2016-06-17 10:10:47 -07:00
|
|
|
system HOMEBREW_BREW_FILE, "audit", "--strict", formula.path
|
2017-06-10 20:12:55 +03:00
|
|
|
failed_audit = !$CHILD_STATUS.success?
|
2018-03-25 23:49:54 +05:30
|
|
|
elsif @args.audit?
|
2016-06-17 10:10:47 -07:00
|
|
|
system HOMEBREW_BREW_FILE, "audit", formula.path
|
2017-06-10 20:12:55 +03:00
|
|
|
failed_audit = !$CHILD_STATUS.success?
|
2016-06-17 10:10:47 -07:00
|
|
|
end
|
|
|
|
if failed_audit
|
|
|
|
formula.path.atomic_write(backup_file)
|
|
|
|
odie "brew audit failed!"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-03-17 05:58:14 +00:00
|
|
|
formula.path.parent.cd do
|
|
|
|
branch = "#{formula.name}-#{new_formula_version}"
|
2017-06-29 13:28:55 +02:00
|
|
|
git_dir = Utils.popen_read("git rev-parse --git-dir").chomp
|
2017-06-27 23:45:57 +02:00
|
|
|
shallow = !git_dir.empty? && File.exist?("#{git_dir}/shallow")
|
|
|
|
|
2018-03-25 23:49:54 +05:30
|
|
|
if @args.dry_run?
|
2018-03-04 00:12:59 +05:30
|
|
|
ohai "fork repository with GitHub API"
|
2017-06-27 23:45:57 +02:00
|
|
|
ohai "git fetch --unshallow origin" if shallow
|
2016-08-19 10:32:54 -04:00
|
|
|
ohai "git checkout --no-track -b #{branch} origin/master"
|
2016-03-17 05:58:14 +00:00
|
|
|
ohai "git commit --no-edit --verbose --message='#{formula.name} #{new_formula_version}#{devel_message}' -- #{formula.path}"
|
2016-08-19 10:32:54 -04:00
|
|
|
ohai "git push --set-upstream $HUB_REMOTE #{branch}:#{branch}"
|
2018-03-04 00:12:59 +05:30
|
|
|
ohai "create pull request with GitHub API"
|
2016-08-19 15:59:55 -04:00
|
|
|
ohai "git checkout -"
|
2016-03-17 05:58:14 +00:00
|
|
|
else
|
2017-11-21 08:16:12 -08:00
|
|
|
|
2018-03-04 00:12:59 +05:30
|
|
|
begin
|
|
|
|
response = GitHub.create_fork(formula.tap.full_name)
|
2018-04-08 15:37:16 -07:00
|
|
|
# GitHub API responds immediately but fork takes a few seconds to be ready.
|
|
|
|
sleep 3
|
2018-03-04 00:12:59 +05:30
|
|
|
rescue *gh_api_errors => e
|
2018-03-25 23:49:54 +05:30
|
|
|
formula.path.atomic_write(backup_file) unless @args.dry_run?
|
2018-03-04 00:12:59 +05:30
|
|
|
odie "Unable to fork: #{e.message}!"
|
2017-11-21 08:16:12 -08:00
|
|
|
end
|
|
|
|
|
2018-03-04 00:12:59 +05:30
|
|
|
remote_url = response.fetch("clone_url")
|
|
|
|
username = response.fetch("owner").fetch("login")
|
2017-11-21 08:16:12 -08:00
|
|
|
|
2017-06-27 23:45:57 +02:00
|
|
|
safe_system "git", "fetch", "--unshallow", "origin" if shallow
|
2016-08-19 10:32:54 -04:00
|
|
|
safe_system "git", "checkout", "--no-track", "-b", branch, "origin/master"
|
2016-03-17 05:58:14 +00:00
|
|
|
safe_system "git", "commit", "--no-edit", "--verbose",
|
|
|
|
"--message=#{formula.name} #{new_formula_version}#{devel_message}",
|
|
|
|
"--", formula.path
|
2018-03-04 00:12:59 +05:30
|
|
|
safe_system "git", "push", "--set-upstream", remote_url, "#{branch}:#{branch}"
|
|
|
|
safe_system "git", "checkout", "--quiet", "-"
|
2017-10-15 02:28:32 +02:00
|
|
|
pr_message = <<~EOS
|
2016-11-15 11:37:49 -05:00
|
|
|
Created with `brew bump-formula-pr`.
|
|
|
|
EOS
|
2018-03-25 23:49:54 +05:30
|
|
|
user_message = @args.message
|
2016-11-15 11:37:49 -05:00
|
|
|
if user_message
|
2017-10-31 14:16:09 -04:00
|
|
|
pr_message += "\n" + <<~EOS
|
2016-11-15 11:37:49 -05:00
|
|
|
---
|
2017-10-31 14:16:09 -04:00
|
|
|
|
2016-11-15 11:37:49 -05:00
|
|
|
#{user_message}
|
|
|
|
EOS
|
|
|
|
end
|
2018-03-04 00:12:59 +05:30
|
|
|
pr_title = "#{formula.name} #{new_formula_version}#{devel_message}"
|
|
|
|
|
|
|
|
begin
|
|
|
|
url = GitHub.create_pull_request(formula.tap.full_name, pr_title,
|
|
|
|
"#{username}:#{branch}", "master", pr_message)["html_url"]
|
2018-03-25 23:49:54 +05:30
|
|
|
if @args.no_browse?
|
2018-03-04 00:12:59 +05:30
|
|
|
puts url
|
|
|
|
else
|
|
|
|
exec_browser url
|
|
|
|
end
|
|
|
|
rescue *gh_api_errors => e
|
|
|
|
odie "Unable to open pull request: #{e.message}!"
|
|
|
|
end
|
2016-03-17 05:58:14 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-03-25 23:49:54 +05:30
|
|
|
|
|
|
|
def inreplace_pairs(path, replacement_pairs)
|
|
|
|
if @args.dry_run?
|
|
|
|
contents = path.open("r") { |f| Formulary.ensure_utf8_encoding(f).read }
|
|
|
|
contents.extend(StringInreplaceExtension)
|
|
|
|
replacement_pairs.each do |old, new|
|
|
|
|
unless Homebrew.args.quiet?
|
|
|
|
ohai "replace #{old.inspect} with #{new.inspect}"
|
|
|
|
end
|
|
|
|
contents.gsub!(old, new)
|
|
|
|
end
|
|
|
|
unless contents.errors.empty?
|
|
|
|
raise Utils::InreplaceError, path => contents.errors
|
|
|
|
end
|
|
|
|
path.atomic_write(contents) if @args.write?
|
|
|
|
contents
|
|
|
|
else
|
|
|
|
Utils::Inreplace.inreplace(path) do |s|
|
|
|
|
replacement_pairs.each do |old, new|
|
|
|
|
unless Homebrew.args.quiet?
|
|
|
|
ohai "replace #{old.inspect} with #{new.inspect}"
|
|
|
|
end
|
|
|
|
s.gsub!(old, new)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
path.open("r") { |f| Formulary.ensure_utf8_encoding(f).read }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def formula_version(formula, spec, contents = nil)
|
|
|
|
name = formula.name
|
|
|
|
path = formula.path
|
|
|
|
if contents
|
|
|
|
Formulary.from_contents(name, path, contents, spec).version
|
|
|
|
else
|
|
|
|
Formulary::FormulaLoader.new(name, path).get_formula(spec).version
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def fetch_pull_requests(formula)
|
|
|
|
GitHub.issues_for_formula(formula.name, tap: formula.tap).select do |pr|
|
|
|
|
pr["html_url"].include?("/pull/") &&
|
|
|
|
/(^|\s)#{Regexp.quote(formula.name)}(:|\s|$)/i =~ pr["title"]
|
|
|
|
end
|
|
|
|
rescue GitHub::RateLimitExceededError => e
|
|
|
|
opoo e.message
|
|
|
|
[]
|
|
|
|
end
|
|
|
|
|
|
|
|
def check_for_duplicate_pull_requests(formula)
|
|
|
|
pull_requests = fetch_pull_requests(formula)
|
|
|
|
return unless pull_requests
|
|
|
|
return if pull_requests.empty?
|
|
|
|
duplicates_message = <<~EOS
|
|
|
|
These open pull requests may be duplicates:
|
|
|
|
#{pull_requests.map { |pr| "#{pr["title"]} #{pr["html_url"]}" }.join("\n")}
|
|
|
|
EOS
|
|
|
|
error_message = "Duplicate PRs should not be opened. Use --force to override this error."
|
|
|
|
if Homebrew.args.force? && !Homebrew.args.quiet?
|
|
|
|
opoo duplicates_message
|
|
|
|
elsif !Homebrew.args.force? && Homebrew.args.quiet?
|
|
|
|
odie error_message
|
|
|
|
elsif !Homebrew.args.force?
|
|
|
|
odie <<~EOS
|
|
|
|
#{duplicates_message.chomp}
|
|
|
|
#{error_message}
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
2016-03-17 05:58:14 +00:00
|
|
|
end
|