summaryrefslogtreecommitdiff
path: root/tool
diff options
context:
space:
mode:
authorHiroshi SHIBATA <hsbt@ruby-lang.org>2022-03-10 13:32:31 +0900
committernagachika <nagachika@ruby-lang.org>2022-05-18 10:02:42 +0900
commitb61f3a9199adb771d785c948ceb8dac61e0fc77f (patch)
treeb3af73217793114a853c681127a7bbd425e2aa9e /tool
parentc5432beecce5339ce3f5c20b990710d7f62de854 (diff)
backport the latest version of sync_default_gems
Diffstat (limited to 'tool')
-rwxr-xr-xtool/sync_default_gems.rb23
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('|'))