implement bump file
This commit is contained in:
parent
737774a164
commit
b908b07e0a
|
@ -3,7 +3,11 @@ require 'optparse'
|
||||||
|
|
||||||
SPEC_TYPE = 'gemspec'
|
SPEC_TYPE = 'gemspec'
|
||||||
|
|
||||||
@options = {:dry_run => false, :major => false, :minor => false, :patch => true}
|
:major
|
||||||
|
:minor
|
||||||
|
:patch
|
||||||
|
|
||||||
|
@options = {:dry_run => false, :bump_number => :patch}
|
||||||
|
|
||||||
OptionParser.new { |opts|
|
OptionParser.new { |opts|
|
||||||
opts.banner = 'Usage: bump.rb [options]'
|
opts.banner = 'Usage: bump.rb [options]'
|
||||||
|
@ -12,13 +16,13 @@ OptionParser.new { |opts|
|
||||||
@options[:dry_run] = v
|
@options[:dry_run] = v
|
||||||
end
|
end
|
||||||
opts.on('-a', '--major', 'Bump major version') do |v|
|
opts.on('-a', '--major', 'Bump major version') do |v|
|
||||||
@options[:major] = v
|
@options[:bump_number] = :major
|
||||||
end
|
end
|
||||||
opts.on('-m', '--minor', 'Bump minor version') do |v|
|
opts.on('-m', '--minor', 'Bump minor version') do |v|
|
||||||
@options[:minor] = v
|
@options[:bump_number] = :minor
|
||||||
end
|
end
|
||||||
opts.on('-p', '--patch', 'Bump patch version') do |v|
|
opts.on('-p', '--patch', 'Bump patch version') do |v|
|
||||||
@options[:patch] = v
|
@options[:bump_number] = :patch
|
||||||
end
|
end
|
||||||
}.parse!
|
}.parse!
|
||||||
|
|
||||||
|
@ -39,14 +43,6 @@ def check_repo_is_clean_or_dry_run
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def execute_line(line)
|
|
||||||
output = `#{line}`
|
|
||||||
if $?.exitstatus != 0
|
|
||||||
puts "Output:\n#{output}\nExit status = #{$?.exitstatus} ->Terminate script."
|
|
||||||
end
|
|
||||||
|
|
||||||
output
|
|
||||||
end
|
|
||||||
|
|
||||||
def find_spec_file
|
def find_spec_file
|
||||||
list_of_scpecs = execute_line("find . -name '*.#{SPEC_TYPE}'")
|
list_of_scpecs = execute_line("find . -name '*.#{SPEC_TYPE}'")
|
||||||
|
@ -62,7 +58,7 @@ def find_spec_file
|
||||||
spec_file = arr[0]
|
spec_file = arr[0]
|
||||||
else
|
else
|
||||||
puts 'Which spec should be used?'
|
puts 'Which spec should be used?'
|
||||||
arr.each_with_index {|file, index| puts "#{index+1}. #{file}"}
|
arr.each_with_index { |file, index| puts "#{index+1}. #{file}" }
|
||||||
input_index = Integer(gets.chomp)
|
input_index = Integer(gets.chomp)
|
||||||
spec_file = arr[input_index-1]
|
spec_file = arr[input_index-1]
|
||||||
end
|
end
|
||||||
|
@ -77,8 +73,9 @@ def find_spec_file
|
||||||
end
|
end
|
||||||
|
|
||||||
def find_version_in_podspec(podspec)
|
def find_version_in_podspec(podspec)
|
||||||
readme = File.read(#{podspec})
|
readme = File.read(podspec)
|
||||||
|
|
||||||
|
#try to find version in format 1.22.333
|
||||||
re = /(\d+)\.(\d+)\.(\d+)/m
|
re = /(\d+)\.(\d+)\.(\d+)/m
|
||||||
|
|
||||||
match_result = re.match(readme)
|
match_result = re.match(readme)
|
||||||
|
@ -89,78 +86,88 @@ def find_version_in_podspec(podspec)
|
||||||
end
|
end
|
||||||
|
|
||||||
puts "Found version #{match_result[0]}"
|
puts "Found version #{match_result[0]}"
|
||||||
p match_result[0], match_result.captures
|
return match_result[0], match_result.captures
|
||||||
exit
|
|
||||||
# return match_result[0], match_result.captures
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def bump_version(result_array)
|
def bump_version(versions_array)
|
||||||
bumped_result = result_array.dup
|
bumped_result = versions_array.dup
|
||||||
bumped_result.map! { |x| x.to_i }
|
bumped_result.map! { |x| x.to_i }
|
||||||
|
|
||||||
if @options[:major]
|
case @options[:bump_number]
|
||||||
|
when :major
|
||||||
bumped_result[0] += 1
|
bumped_result[0] += 1
|
||||||
bumped_result[1] = 0
|
bumped_result[1] = 0
|
||||||
bumped_result[2] = 0
|
bumped_result[2] = 0
|
||||||
else
|
when :minor
|
||||||
if @options[:minor]
|
|
||||||
bumped_result[1] += 1
|
bumped_result[1] += 1
|
||||||
bumped_result[2] = 0
|
bumped_result[2] = 0
|
||||||
else
|
when :patch
|
||||||
if @options[:patch]
|
|
||||||
bumped_result[2] += 1
|
bumped_result[2] += 1
|
||||||
|
else
|
||||||
|
raise('unknown bump_number')
|
||||||
end
|
end
|
||||||
end
|
|
||||||
end
|
|
||||||
bumped_version = bumped_result.join('.')
|
bumped_version = bumped_result.join('.')
|
||||||
puts "Bump version: #{result_array.join('.')} -> #{bumped_version}"
|
puts "Bump version: #{versions_array.join('.')} -> #{bumped_version}"
|
||||||
bumped_version
|
bumped_version
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def execute_line(line)
|
||||||
|
output = `#{line}`
|
||||||
|
check_exit_status
|
||||||
|
|
||||||
|
output
|
||||||
|
end
|
||||||
|
|
||||||
def execute_line_if_not_dry_run(line)
|
def execute_line_if_not_dry_run(line)
|
||||||
if @options[:dry_run]
|
if @options[:dry_run]
|
||||||
puts "Dry run:\n#{line}"
|
puts "Dry run: #{line}"
|
||||||
|
nil
|
||||||
else
|
else
|
||||||
puts line
|
puts line
|
||||||
value = %x[#{line}]
|
value = %x[#{line}]
|
||||||
puts value
|
puts value
|
||||||
if $?.exitstatus != 0
|
check_exit_status
|
||||||
puts "Error (exit status = #{$?} -> exit"
|
value
|
||||||
exit
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def check_exit_status
|
||||||
|
if $?.exitstatus != 0
|
||||||
|
puts "Output:\n#{output}\nExit status = #{$?.exitstatus} ->Terminate script."
|
||||||
|
exit
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def run_bumping_script
|
def run_bumping_script
|
||||||
|
|
||||||
check_repo_is_clean_or_dry_run
|
check_repo_is_clean_or_dry_run
|
||||||
result, result_array = find_version_in_podspec(find_spec_file)
|
spec_file = find_spec_file
|
||||||
bumped_version = bump_version(result_array)
|
result, versions_array = find_version_in_podspec(spec_file)
|
||||||
|
bumped_version = bump_version(versions_array)
|
||||||
|
|
||||||
unless @options[:dry_run]
|
unless @options[:dry_run]
|
||||||
|
|
||||||
puts 'Are you sure? Click Y to continue:'
|
puts 'Are you sure? Click Y to continue:'
|
||||||
str = gets.chomp
|
str = gets.chomp
|
||||||
if str != 'Y'
|
if str != 'Y'
|
||||||
puts '-> exit'
|
puts '-> exit'
|
||||||
exit
|
exit
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
execute_line_if_not_dry_run("sed -i \"\" \"s/#{result}/#{bumped_version}/\" README.md")
|
execute_line_if_not_dry_run("sed -i \"\" \"s/#{result}/#{bumped_version}/\" README.md")
|
||||||
execute_line_if_not_dry_run("sed -i \"\" \"s/#{result}/#{bumped_version}/\" ActionSheetPicker-3.0.podspec")
|
execute_line_if_not_dry_run("sed -i \"\" \"s/#{result}/#{bumped_version}/\" #{spec_file}")
|
||||||
execute_line_if_not_dry_run("git commit --all -m \"Update #{$SPEC_TYPE} to version #{bumped_version}\"")
|
execute_line_if_not_dry_run("git commit --all -m \"Update #{$SPEC_TYPE} to version #{bumped_version}\"")
|
||||||
execute_line_if_not_dry_run("git tag #{bumped_version}")
|
execute_line_if_not_dry_run("git tag #{bumped_version}")
|
||||||
execute_line_if_not_dry_run('git push')
|
# execute_line_if_not_dry_run('git push')
|
||||||
execute_line_if_not_dry_run('git push --tags')
|
# execute_line_if_not_dry_run('git push --tags')
|
||||||
execute_line_if_not_dry_run('pod trunk push ./ActionSheetPicker-3.0.podspec')
|
# execute_line_if_not_dry_run("pod trunk push #{spec_file}")
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if __FILE__ == $0
|
if __FILE__ == $0
|
||||||
|
|
||||||
result, result_array = find_version_in_podspec(find_spec_file)
|
run_bumping_script
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue
Block a user