Class: Gem::Commands::PristineCommand
- Inherits:
-
Gem::Command
- Object
- Gem::Command
- Gem::Commands::PristineCommand
- Includes:
- VersionOption
- Defined in:
- lib/rubygems/commands/pristine_command.rb
Instance Attribute Summary
Attributes inherited from Gem::Command
#command, #defaults, #options, #program_name, #summary
Instance Method Summary collapse
-
#arguments ⇒ Object
:nodoc:.
-
#defaults_str ⇒ Object
:nodoc:.
-
#description ⇒ Object
:nodoc:.
- #execute ⇒ Object
-
#initialize ⇒ PristineCommand
constructor
A new instance of PristineCommand.
-
#usage ⇒ Object
:nodoc:.
Methods included from VersionOption
#add_platform_option, #add_prerelease_option, #add_version_option, #get_platform_from_requirements
Methods inherited from Gem::Command
add_common_option, #add_extra_args, #add_option, add_specific_extra_args, #begins?, build_args, build_args=, #check_deprecated_options, common_options, #deprecate_option, #deprecated?, extra_args, extra_args=, #extract_gem_name_and_version, #get_all_gem_names, #get_all_gem_names_and_versions, #get_one_gem_name, #get_one_optional_argument, #handle_options, #handles?, #invoke, #invoke_with_build_args, #merge_options, #remove_option, #show_help, #show_lookup_failure, specific_extra_args, specific_extra_args_hash, #when_invoked
Methods included from UserInteraction
#alert, #alert_error, #alert_warning, #ask, #ask_for_password, #ask_yes_no, #choose_from_list, #say, #terminate_interaction, #verbose
Methods included from DefaultUserInteraction
ui, #ui, ui=, #ui=, use_ui, #use_ui
Methods included from Text
#clean_text, #format_text, #levenshtein_distance, #min3, #truncate_text
Constructor Details
#initialize ⇒ PristineCommand
Returns a new instance of PristineCommand.
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 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 |
# File 'lib/rubygems/commands/pristine_command.rb', line 11 def initialize super "pristine", "Restores installed gems to pristine condition from files located in the gem cache", version: Gem::Requirement.default, extensions: true, extensions_set: false, all: false add_option("--all", "Restore all installed gems to pristine", "condition") do |value, | [:all] = value end add_option("--skip=gem_name", "used on --all, skip if name == gem_name") do |value, | [:skip] ||= [] [:skip] << value end add_option("--[no-]extensions", "Restore gems with extensions", "in addition to regular gems") do |value, | [:extensions_set] = true [:extensions] = value end add_option("--only-missing-extensions", "Only restore gems with missing extensions") do |value, | [:only_missing_extensions] = value end add_option("--only-executables", "Only restore executables") do |value, | [:only_executables] = value end add_option("--only-plugins", "Only restore plugins") do |value, | [:only_plugins] = value end add_option("-E", "--[no-]env-shebang", "Rewrite executables with a shebang", "of /usr/bin/env") do |value, | [:env_shebang] = value end add_option("-i", "--install-dir DIR", "Gem repository to get gems restored") do |value, | [:install_dir] = File.(value) end add_option("-n", "--bindir DIR", "Directory where executables are", "located") do |value, | [:bin_dir] = File.(value) end add_version_option("restore to", "pristine condition") end |
Instance Method Details
#arguments ⇒ Object
:nodoc:
73 74 75 |
# File 'lib/rubygems/commands/pristine_command.rb', line 73 def arguments # :nodoc: "GEMNAME gem to restore to pristine condition (unless --all)" end |
#defaults_str ⇒ Object
:nodoc:
77 78 79 |
# File 'lib/rubygems/commands/pristine_command.rb', line 77 def defaults_str # :nodoc: "--extensions" end |
#description ⇒ Object
:nodoc:
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 |
# File 'lib/rubygems/commands/pristine_command.rb', line 81 def description # :nodoc: <<-EOF The pristine command compares an installed gem with the contents of its cached .gem file and restores any files that don't match the cached .gem's copy. If you have made modifications to an installed gem, the pristine command will revert them. All extensions are rebuilt and all bin stubs for the gem are regenerated after checking for modifications. If the cached gem cannot be found it will be downloaded. If --no-extensions is provided pristine will not attempt to restore a gem with an extension. If --extensions is given (but not --all or gem names) only gems with extensions will be restored. EOF end |
#execute ⇒ Object
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 |
# File 'lib/rubygems/commands/pristine_command.rb', line 105 def execute install_dir = [:install_dir] specification_record = install_dir ? Gem::SpecificationRecord.from_path(install_dir) : Gem::Specification.specification_record specs = if [:all] specification_record.map # `--extensions` must be explicitly given to pristine only gems # with extensions. elsif [:extensions_set] && [:extensions] && [:args].empty? specification_record.select do |spec| spec.extensions && !spec.extensions.empty? end elsif [:only_missing_extensions] specification_record.select(&:missing_extensions?) else get_all_gem_names.sort.map do |gem_name| specification_record.find_all_by_name(gem_name, [:version]).reverse end.flatten end specs = specs.select {|spec| spec.platform == RUBY_ENGINE || Gem::Platform.local === spec.platform || spec.platform == Gem::Platform::RUBY } if specs.to_a.empty? raise Gem::Exception, "Failed to find gems #{[:args]} #{[:version]}" end say "Restoring gems to pristine condition..." specs.group_by(&:full_name_with_location).values.each do |grouped_specs| spec = grouped_specs.find {|s| !s.default_gem? } || grouped_specs.first unless only_executables_or_plugins? # Default gemspecs include changes provided by ruby-core installer that # can't currently be pristined (inclusion of compiled extension targets in # the file list). So stick to resetting executables if it's a default gem. [:only_executables] = true if spec.default_gem? end if .key? :skip if [:skip].include? spec.name say "Skipped #{spec.full_name}, it was given through options" next end end unless spec.extensions.empty? || [:extensions] || only_executables_or_plugins? say "Skipped #{spec.full_name_with_location}, it needs to compile an extension" next end gem = spec.cache_file unless File.exist?(gem) || only_executables_or_plugins? require_relative "../remote_fetcher" say "Cached gem for #{spec.full_name_with_location} not found, attempting to fetch..." dep = Gem::Dependency.new spec.name, spec.version found, _ = Gem::SpecFetcher.fetcher.spec_for_dependency dep if found.empty? say "Skipped #{spec.full_name}, it was not found from cache and remote sources" next end spec_candidate, source = found.first Gem::RemoteFetcher.fetcher.download spec_candidate, source.uri.to_s, spec.base_dir end env_shebang = if .include? :env_shebang [:env_shebang] else install_defaults = Gem::ConfigFile::PLATFORM_DEFAULTS["install"] install_defaults.to_s["--env-shebang"] end bin_dir = [:bin_dir] if [:bin_dir] = { wrappers: true, force: true, install_dir: install_dir || spec.base_dir, env_shebang: env_shebang, build_args: spec.build_args, bin_dir: bin_dir, } if [:only_executables] installer = Gem::Installer.for_spec(spec, ) installer.generate_bin elsif [:only_plugins] installer = Gem::Installer.for_spec(spec, ) installer.generate_plugins else installer = Gem::Installer.at(gem, ) installer.install end say "Restored #{spec.full_name_with_location}" end end |
#usage ⇒ Object
:nodoc:
101 102 103 |
# File 'lib/rubygems/commands/pristine_command.rb', line 101 def usage # :nodoc: "#{program_name} [GEMNAME ...]" end |