Class: Gem::Commands::GenerateIndexCommand
- Inherits:
-
Gem::Command
- Object
- Gem::Command
- Gem::Commands::GenerateIndexCommand
- Defined in:
- lib/rubygems/commands/generate_index_command.rb
Overview
Generates a index files for use as a gem server.
See ‘gem help generate_index`
Instance Attribute Summary
Attributes inherited from Gem::Command
#command, #defaults, #options, #program_name, #summary
Instance Method Summary collapse
-
#defaults_str ⇒ Object
:nodoc:.
-
#description ⇒ Object
:nodoc:.
- #execute ⇒ Object
-
#initialize ⇒ GenerateIndexCommand
constructor
A new instance of GenerateIndexCommand.
Methods inherited from Gem::Command
add_common_option, #add_extra_args, #add_option, add_specific_extra_args, #arguments, #begins?, build_args, build_args=, #check_deprecated_options, common_options, #deprecate_option, extra_args, extra_args=, #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, #usage, #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 ⇒ GenerateIndexCommand
Returns a new instance of GenerateIndexCommand.
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 |
# File 'lib/rubygems/commands/generate_index_command.rb', line 12 def initialize super 'generate_index', 'Generates the index files for a gem server directory', :directory => '.', :build_modern => true add_option '-d', '--directory=DIRNAME', 'repository base dir containing gems subdir' do |dir, | [:directory] = File. dir end add_option '--[no-]modern', 'Generate indexes for RubyGems', '(always true)' do |value, | [:build_modern] = value end deprecate_option('--modern', version: '4.0', extra_msg: 'Modern indexes (specs, latest_specs, and prerelease_specs) are always generated, so this option is not needed.') deprecate_option('--no-modern', version: '4.0', extra_msg: 'The `--no-modern` option is currently ignored. Modern indexes (specs, latest_specs, and prerelease_specs) are always generated.') add_option '--update', 'Update modern indexes with gems added', 'since the last update' do |value, | [:update] = value end end |
Instance Method Details
#defaults_str ⇒ Object
:nodoc:
38 39 40 |
# File 'lib/rubygems/commands/generate_index_command.rb', line 38 def defaults_str # :nodoc: "--directory . --modern" end |
#description ⇒ Object
:nodoc:
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 |
# File 'lib/rubygems/commands/generate_index_command.rb', line 42 def description # :nodoc: <<-EOF The generate_index command creates a set of indexes for serving gems statically. The command expects a 'gems' directory under the path given to the --directory option. The given directory will be the directory you serve as the gem repository. For `gem generate_index --directory /path/to/repo`, expose /path/to/repo via your HTTP server configuration (not /path/to/repo/gems). When done, it will generate a set of files like this: gems/*.gem # .gem files you want to # index specs.<version>.gz # specs index latest_specs.<version>.gz # latest specs index prerelease_specs.<version>.gz # prerelease specs index quick/Marshal.<version>/<gemname>.gemspec.rz # Marshal quick index file The .rz extension files are compressed with the inflate algorithm. The Marshal version number comes from ruby's Marshal::MAJOR_VERSION and Marshal::MINOR_VERSION constants. It is used to ensure compatibility. EOF end |
#execute ⇒ Object
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 |
# File 'lib/rubygems/commands/generate_index_command.rb', line 68 def execute # This is always true because it's the only way now. [:build_modern] = true if not File.exist?([:directory]) or not File.directory?([:directory]) alert_error "unknown directory name #{[:directory]}." terminate_interaction 1 else indexer = Gem::Indexer.new .delete(:directory), if [:update] indexer.update_index else indexer.generate_index end end end |