diff options
author | Hiroshi SHIBATA <hsbt@ruby-lang.org> | 2022-03-10 13:32:31 +0900 |
---|---|---|
committer | nagachika <nagachika@ruby-lang.org> | 2022-05-18 10:02:42 +0900 |
commit | b61f3a9199adb771d785c948ceb8dac61e0fc77f (patch) | |
tree | b3af73217793114a853c681127a7bbd425e2aa9e /tool | |
parent | c5432beecce5339ce3f5c20b990710d7f62de854 (diff) |
backport the latest version of sync_default_gems
Diffstat (limited to 'tool')
-rwxr-xr-x | tool/sync_default_gems.rb | 23 |
1 files changed, 18 insertions, 5 deletions
diff --git a/tool/sync_default_gems.rb b/tool/sync_default_gems.rb index ca5283d2c3..564877a26b 100755 --- a/tool/sync_default_gems.rb +++ b/tool/sync_default_gems.rb @@ -530,7 +530,7 @@ def sync_lib(repo, upstream = nil) cp_r("#{upstream}/#{repo}.gemspec", "#{gemspec}") end -def update_default_gems(gem) +def update_default_gems(gem, release: false) author, repository = REPOSITORIES[gem.to_sym].split('/') @@ -552,9 +552,15 @@ def update_default_gems(gem) end `git checkout ruby-core` `git rebase ruby-core/master` - `git checkout master` - `git fetch origin master` - `git rebase origin/master` + `git fetch origin --tags` + + if release + last_release = `git tag`.chomp.split.delete_if{|v| v =~ /pre|beta/ }.last + `git checkout #{last_release}` + else + `git checkout master` + `git rebase origin/master` + end end end @@ -566,7 +572,14 @@ when "up" REPOSITORIES.keys.each{|gem| update_default_gems(gem.to_s)} end when "all" - REPOSITORIES.keys.each{|gem| sync_default_gems(gem.to_s)} + if ARGV[1] == "release" + REPOSITORIES.keys.each do |gem| + update_default_gems(gem.to_s, release: true) + sync_default_gems(gem.to_s) + end + else + REPOSITORIES.keys.each{|gem| sync_default_gems(gem.to_s)} + end when "list" ARGV.shift pattern = Regexp.new(ARGV.join('|')) |