diff options
Diffstat (limited to 'tool/downloader.rb')
-rw-r--r-- | tool/downloader.rb | 27 |
1 files changed, 25 insertions, 2 deletions
diff --git a/tool/downloader.rb b/tool/downloader.rb index ba6ddc15c5..4edbc430c1 100644 --- a/tool/downloader.rb +++ b/tool/downloader.rb @@ -1,6 +1,29 @@ require 'open-uri' class Downloader + def self.gnu(name) + "http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=#{name};hb=HEAD" + end + + def self.rubygems(name) + "https://rubygems.org/downloads/#{name}" + end + + def self.uri_to_download(url, name) + from, url = url + case from + when :gnu + url = gnu(url || name) + when :rubygems, :gems + url = rubygems(url || name) + when Symbol + raise ArgumentError, "unkonwn site - #{from}" + else + url = from + end + URI(url) + end + def self.mode_for(data) data.start_with?("#!") ? 0755 : 0644 end @@ -34,7 +57,7 @@ class Downloader # 'enc/unicode/data/UnicodeData.txt' def self.download(url, name, dir = nil, ims = true) file = dir ? File.join(dir, name) : name - url = URI(url) + url = uri_to_download(url, name) begin data = url.read(http_options(file, ims)) rescue OpenURI::HTTPError => http_error @@ -53,7 +76,7 @@ class Downloader end true rescue => e - raise "failed to download #{name}\n#{e.message}: #{url}" + raise e.class, "failed to download #{name}\n#{e.message}: #{url}", e.backtrace end def self.download_if_modified_since(url, name, dir = nil) |