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
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require "abstract_command"
|
||||||
require "formula"
|
require "formula"
|
||||||
require "cli/parser"
|
require "cli/parser"
|
||||||
|
|
||||||
module Homebrew
|
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) }
|
conflicts "--dry-run", "--write-only"
|
||||||
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"
|
named_args :formula, min: 1, without_api: true
|
||||||
|
|
||||||
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)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
message = "#{formula.name}: revision bump #{args.message}"
|
sig { override.void }
|
||||||
if args.dry_run?
|
def run
|
||||||
ohai "git commit --no-edit --verbose --message=#{message} -- #{formula.path}"
|
# As this command is simplifying user-run commands then let's just use a
|
||||||
elsif !args.write_only?
|
# user path, too.
|
||||||
formula.path.parent.cd do
|
ENV["PATH"] = PATH.new(ORIGINAL_PATHS).to_s
|
||||||
safe_system "git", "commit", "--no-edit", "--verbose",
|
|
||||||
"--message=#{message}", "--", formula.path
|
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
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -1,7 +1,8 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
require "cmd/shared_examples/args_parse"
|
require "cmd/shared_examples/args_parse"
|
||||||
|
require "dev-cmd/bump-revision"
|
||||||
|
|
||||||
RSpec.describe "brew bump-revision" do
|
RSpec.describe Homebrew::DevCmd::BumpRevision do
|
||||||
it_behaves_like "parseable arguments"
|
it_behaves_like "parseable arguments", argv: ["foo"]
|
||||||
end
|
end
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user