/usr/share/rubygems/rubygems
# frozen_string_literal: true require_relative 'deprecate' ## # This module contains various utility methods as module methods. module Gem::Util ## # Zlib::GzipReader wrapper that unzips +data+. def self.gunzip(data) require 'zlib' require 'stringio' data = StringIO.new(data, 'r') gzip_reader = begin Zlib::GzipReader.new(data) rescue Zlib::GzipFile::Error => e raise e.class, e.inspect, e.backtrace end unzipped = gzip_reader.read unzipped.force_encoding Encoding::BINARY unzipped end ## # Zlib::GzipWriter wrapper that zips +data+. def self.gzip(data) require 'zlib' require 'stringio' zipped = StringIO.new(String.new, 'w') zipped.set_encoding Encoding::BINARY Zlib::GzipWriter.wrap zipped do |io| io.write data end zipped.string end ## # A Zlib::Inflate#inflate wrapper def self.inflate(data) require 'zlib' Zlib::Inflate.inflate data end ## # This calls IO.popen and reads the result def self.popen(*command) IO.popen command, &:read end ## # Invokes system, but silences all output. def self.silent_system(*command) opt = {:out => IO::NULL, :err => [:child, :out]} if Hash === command.last opt.update(command.last) cmds = command[0...-1] else cmds = command.dup end system(*(cmds << opt)) end class << self extend Gem::Deprecate rubygems_deprecate :silent_system end ## # Enumerates the parents of +directory+. def self.traverse_parents(directory, &block) return enum_for __method__, directory unless block_given? here = File.expand_path directory loop do Dir.chdir here, &block rescue Errno::EACCES new_here = File.expand_path('..', here) return if new_here == here # toplevel here = new_here end end ## # Globs for files matching +pattern+ inside of +directory+, # returning absolute paths to the matching files. def self.glob_files_in_dir(glob, base_path) if RUBY_VERSION >= "2.5" Dir.glob(glob, base: base_path).map! {|f| File.expand_path(f, base_path) } else Dir.glob(File.expand_path(glob, base_path)) end end ## # Corrects +path+ (usually returned by `URI.parse().path` on Windows), that # comes with a leading slash. def self.correct_for_windows_path(path) if path[0].chr == '/' && path[1].chr =~ /[a-z]/i && path[2].chr == ':' path[1..-1] else path end end end
.
Edit
..
Edit
available_set.rb
Edit
basic_specification.rb
Edit
bundler_version_finder.rb
Edit
command.rb
Edit
command_manager.rb
Edit
commands
Edit
compatibility.rb
Edit
config_file.rb
Edit
core_ext
Edit
defaults
Edit
defaults.rb
Edit
dependency.rb
Edit
dependency_installer.rb
Edit
dependency_list.rb
Edit
deprecate.rb
Edit
doctor.rb
Edit
errors.rb
Edit
exceptions.rb
Edit
ext
Edit
ext.rb
Edit
gem_runner.rb
Edit
gemcutter_utilities.rb
Edit
indexer.rb
Edit
install_default_message.rb
Edit
install_message.rb
Edit
install_update_options.rb
Edit
installer.rb
Edit
installer_uninstaller_utils.rb
Edit
local_remote_options.rb
Edit
mock_gem_ui.rb
Edit
name_tuple.rb
Edit
openssl.rb
Edit
optparse
Edit
optparse.rb
Edit
package
Edit
package.rb
Edit
package_task.rb
Edit
path_support.rb
Edit
platform.rb
Edit
psych_additions.rb
Edit
psych_tree.rb
Edit
query_utils.rb
Edit
rdoc.rb
Edit
remote_fetcher.rb
Edit
request
Edit
request.rb
Edit
request_set
Edit
request_set.rb
Edit
requirement.rb
Edit
resolver
Edit
resolver.rb
Edit
s3_uri_signer.rb
Edit
safe_yaml.rb
Edit
security
Edit
security.rb
Edit
security_option.rb
Edit
server.rb
Edit
source
Edit
source.rb
Edit
source_list.rb
Edit
spec_fetcher.rb
Edit
specification.rb
Edit
specification_policy.rb
Edit
ssl_certs
Edit
stub_specification.rb
Edit
text.rb
Edit
tsort
Edit
tsort.rb
Edit
uninstaller.rb
Edit
uri.rb
Edit
uri_formatter.rb
Edit
user_interaction.rb
Edit
util
Edit
util.rb
Edit
validator.rb
Edit
version.rb
Edit
version_option.rb
Edit