Module: Gem::Util
- Defined in:
- lib/rubygems/util.rb
Overview
This module contains various utility methods as module methods.
Class Method Summary collapse
-
.correct_for_windows_path(path) ⇒ Object
Corrects
path
(usually returned by ‘URI.parse().path` on Windows), that comes with a leading slash. -
.glob_files_in_dir(glob, base_path) ⇒ Object
Globs for files matching
pattern
inside ofdirectory
, returning absolute paths to the matching files. -
.gunzip(data) ⇒ Object
Zlib::GzipReader wrapper that unzips
data
. -
.gzip(data) ⇒ Object
Zlib::GzipWriter wrapper that zips
data
. -
.inflate(data) ⇒ Object
A Zlib::Inflate#inflate wrapper.
-
.popen(*command) ⇒ Object
This calls IO.popen and reads the result.
-
.silent_system(*command) ⇒ Object
Invokes system, but silences all output.
-
.traverse_parents(directory, &block) ⇒ Object
Enumerates the parents of
directory
.
Class Method Details
.correct_for_windows_path(path) ⇒ Object
Corrects path
(usually returned by ‘URI.parse().path` on Windows), that comes with a leading slash.
99 100 101 102 103 104 105 |
# File 'lib/rubygems/util.rb', line 99 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 |
.glob_files_in_dir(glob, base_path) ⇒ Object
Globs for files matching pattern
inside of directory
, returning absolute paths to the matching files.
87 88 89 90 91 92 93 |
# File 'lib/rubygems/util.rb', line 87 def self.glob_files_in_dir(glob, base_path) if RUBY_VERSION >= "2.5" Dir.glob(glob, base: base_path).map! {|f| File.(f, base_path) } else Dir.glob(File.(glob, base_path)) end end |
.gunzip(data) ⇒ Object
Zlib::GzipReader wrapper that unzips data
.
12 13 14 15 16 17 18 19 20 |
# File 'lib/rubygems/util.rb', line 12 def self.gunzip(data) require 'zlib' require 'stringio' data = StringIO.new(data, 'r') unzipped = Zlib::GzipReader.new(data).read unzipped.force_encoding Encoding::BINARY unzipped end |
.gzip(data) ⇒ Object
Zlib::GzipWriter wrapper that zips data
.
25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'lib/rubygems/util.rb', line 25 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 |
.inflate(data) ⇒ Object
A Zlib::Inflate#inflate wrapper
41 42 43 44 |
# File 'lib/rubygems/util.rb', line 41 def self.inflate(data) require 'zlib' Zlib::Inflate.inflate data end |
.popen(*command) ⇒ Object
This calls IO.popen and reads the result
49 50 51 |
# File 'lib/rubygems/util.rb', line 49 def self.popen(*command) IO.popen command, &:read end |
.silent_system(*command) ⇒ Object
Invokes system, but silences all output.
56 57 58 59 60 61 62 63 64 65 |
# File 'lib/rubygems/util.rb', line 56 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 |
.traverse_parents(directory, &block) ⇒ Object
Enumerates the parents of directory
.
70 71 72 73 74 75 76 77 78 79 80 81 |
# File 'lib/rubygems/util.rb', line 70 def self.traverse_parents(directory, &block) return enum_for __method__, directory unless block_given? here = File. directory loop do Dir.chdir here, &block rescue Errno::EACCES new_here = File.('..', here) return if new_here == here # toplevel here = new_here end end |