forked from elastic/logstash
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgems.rake
47 lines (41 loc) · 1.73 KB
/
gems.rake
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
require "rubygems/specification"
require "rubygems/commands/install_command"
require "logstash/JRUBY-PR1448" if RUBY_PLATFORM == "java" && Gem.win_platform?
ENV["GEM_HOME"] = ENV["GEM_PATH"] = "build/bootstrap/"
Gem.use_paths(ENV["GEM_HOME"])
namespace "gem" do
task "require", :name, :requirement, :target do |task, args|
name, requirement, target = args[:name], args[:requirement], args[:target]
begin
gem name, requirement
rescue Gem::LoadError => e
puts "Installing #{name} #{requirement} because the build process needs it."
Rake::Task["gem:install"].invoke(name, requirement, target)
end
task.reenable # Allow this task to be run again
end
task "install", [:name, :requirement, :target] => ["build/bootstrap"] do |task, args|
name, requirement, target = args[:name], args[:requirement], args[:target]
puts "[bootstrap] Fetching and installing gem: #{name} (#{requirement})"
installer = Gem::Commands::InstallCommand.new
installer.options[:generate_rdoc] = false
installer.options[:generate_ri] = false
installer.options[:version] = requirement
installer.options[:args] = [name]
installer.options[:install_dir] = target
# ruby 2.0.0 / rubygems 2.x; disable documentation generation
installer.options[:document] = []
begin
installer.execute
rescue Gem::LoadError => e
# For some weird reason the rescue from the 'require' task is being brought down here
# We don't know why placing this solves it, but it does.
rescue Gem::SystemExitException => e
if e.exit_code != 0
puts "Installation of #{name} failed"
raise
end
end
task.reenable # Allow this task to be run again
end # task "install"
end # namespace "gem"