Port Homebrew::DevCmd::BumpRevision
This commit is contained in:
parent
d873881c47
commit
1097496a06
@ -1,76 +1,75 @@
|
||||
# typed: true
|
||||
# typed: strict
|
||||
# frozen_string_literal: true
|
||||
|
||||
require "abstract_command"
|
||||
require "formula"
|
||||
require "cli/parser"
|
||||
|
||||
module Homebrew
|
||||
module_function
|
||||
module DevCmd
|
||||
class BumpRevision < AbstractCommand
|
||||
cmd_args do
|
||||
description <<~EOS
|
||||
Create a commit to increment the revision of <formula>. If no revision is
|
||||
present, "revision 1" will be added.
|
||||
EOS
|
||||
switch "-n", "--dry-run",
|
||||
description: "Print what would be done rather than doing it."
|
||||
switch "--remove-bottle-block",
|
||||
description: "Remove the bottle block in addition to bumping the revision."
|
||||
switch "--write-only",
|
||||
description: "Make the expected file modifications without taking any Git actions."
|
||||
flag "--message=",
|
||||
description: "Append <message> to the default commit message."
|
||||
|
||||
sig { returns(CLI::Parser) }
|
||||
def bump_revision_args
|
||||
Homebrew::CLI::Parser.new do
|
||||
description <<~EOS
|
||||
Create a commit to increment the revision of <formula>. If no revision is
|
||||
present, "revision 1" will be added.
|
||||
EOS
|
||||
switch "-n", "--dry-run",
|
||||
description: "Print what would be done rather than doing it."
|
||||
switch "--remove-bottle-block",
|
||||
description: "Remove the bottle block in addition to bumping the revision."
|
||||
switch "--write-only",
|
||||
description: "Make the expected file modifications without taking any Git actions."
|
||||
flag "--message=",
|
||||
description: "Append <message> to the default commit message."
|
||||
conflicts "--dry-run", "--write-only"
|
||||
|
||||
conflicts "--dry-run", "--write-only"
|
||||
|
||||
named_args :formula, min: 1, without_api: true
|
||||
end
|
||||
end
|
||||
|
||||
def bump_revision
|
||||
args = bump_revision_args.parse
|
||||
|
||||
# As this command is simplifying user-run commands then let's just use a
|
||||
# user path, too.
|
||||
ENV["PATH"] = PATH.new(ORIGINAL_PATHS).to_s
|
||||
|
||||
args.named.to_formulae.each do |formula|
|
||||
current_revision = formula.revision
|
||||
new_revision = current_revision + 1
|
||||
|
||||
if args.dry_run?
|
||||
unless args.quiet?
|
||||
old_text = "revision #{current_revision}"
|
||||
new_text = "revision #{new_revision}"
|
||||
if current_revision.zero?
|
||||
ohai "add #{new_text.inspect}"
|
||||
else
|
||||
ohai "replace #{old_text.inspect} with #{new_text.inspect}"
|
||||
end
|
||||
end
|
||||
else
|
||||
Homebrew.install_bundler_gems!(groups: ["ast"])
|
||||
require "utils/ast"
|
||||
|
||||
formula_ast = Utils::AST::FormulaAST.new(formula.path.read)
|
||||
if current_revision.zero?
|
||||
formula_ast.add_stanza(:revision, new_revision)
|
||||
else
|
||||
formula_ast.replace_stanza(:revision, new_revision)
|
||||
end
|
||||
formula_ast.remove_stanza(:bottle) if args.remove_bottle_block?
|
||||
formula.path.atomic_write(formula_ast.process)
|
||||
named_args :formula, min: 1, without_api: true
|
||||
end
|
||||
|
||||
message = "#{formula.name}: revision bump #{args.message}"
|
||||
if args.dry_run?
|
||||
ohai "git commit --no-edit --verbose --message=#{message} -- #{formula.path}"
|
||||
elsif !args.write_only?
|
||||
formula.path.parent.cd do
|
||||
safe_system "git", "commit", "--no-edit", "--verbose",
|
||||
"--message=#{message}", "--", formula.path
|
||||
sig { override.void }
|
||||
def run
|
||||
# As this command is simplifying user-run commands then let's just use a
|
||||
# user path, too.
|
||||
ENV["PATH"] = PATH.new(ORIGINAL_PATHS).to_s
|
||||
|
||||
args.named.to_formulae.each do |formula|
|
||||
current_revision = formula.revision
|
||||
new_revision = current_revision + 1
|
||||
|
||||
if args.dry_run?
|
||||
unless args.quiet?
|
||||
old_text = "revision #{current_revision}"
|
||||
new_text = "revision #{new_revision}"
|
||||
if current_revision.zero?
|
||||
ohai "add #{new_text.inspect}"
|
||||
else
|
||||
ohai "replace #{old_text.inspect} with #{new_text.inspect}"
|
||||
end
|
||||
end
|
||||
else
|
||||
Homebrew.install_bundler_gems!(groups: ["ast"])
|
||||
require "utils/ast"
|
||||
|
||||
formula_ast = Utils::AST::FormulaAST.new(formula.path.read)
|
||||
if current_revision.zero?
|
||||
formula_ast.add_stanza(:revision, new_revision)
|
||||
else
|
||||
formula_ast.replace_stanza(:revision, new_revision)
|
||||
end
|
||||
formula_ast.remove_stanza(:bottle) if args.remove_bottle_block?
|
||||
formula.path.atomic_write(formula_ast.process)
|
||||
end
|
||||
|
||||
message = "#{formula.name}: revision bump #{args.message}"
|
||||
if args.dry_run?
|
||||
ohai "git commit --no-edit --verbose --message=#{message} -- #{formula.path}"
|
||||
elsif !args.write_only?
|
||||
formula.path.parent.cd do
|
||||
safe_system "git", "commit", "--no-edit", "--verbose",
|
||||
"--message=#{message}", "--", formula.path
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@ -1,7 +1,8 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require "cmd/shared_examples/args_parse"
|
||||
require "dev-cmd/bump-revision"
|
||||
|
||||
RSpec.describe "brew bump-revision" do
|
||||
it_behaves_like "parseable arguments"
|
||||
RSpec.describe Homebrew::DevCmd::BumpRevision do
|
||||
it_behaves_like "parseable arguments", argv: ["foo"]
|
||||
end
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user