Class: Gem::Commands::SpecificationCommand
| Relationships & Source Files | |
| Super Chains via Extension / Inclusion / Inheritance | |
| Class Chain: 
          self,
          ::Gem::Command
         | |
| Instance Chain: | |
| Inherits: | Gem::Command 
 | 
| Defined in: | lib/rubygems/commands/specification_command.rb | 
Constant Summary
::Gem::Command - Inherited
Class Attribute Summary
::Gem::Command - Inherited
| .build_args | Arguments used when building gems. | 
| .build_args=, .extra_args, .extra_args= | |
Class Method Summary
- .new ⇒ SpecificationCommand constructor
::Gem::Command - Inherited
| .add_common_option, | |
| .add_specific_extra_args | Add a list of extra arguments for the given command. | 
| .common_options, | |
| .new | Initializes a generic gem command named  | 
| .specific_extra_args | Return an array of extra arguments for the command. | 
| .specific_extra_args_hash | Accessor for the specific extra args hash (self initializing). | 
Instance Attribute Summary
::Gem::LocalRemoteOptions - Included
| #both? | Is fetching of local and remote information enabled? | 
| #local? | Is local fetching enabled? | 
| #remote? | Is remote fetching enabled? | 
::Gem::Command - Inherited
| #command | The name of the command. | 
| #defaults | The default options for the command. | 
| #options | The options for the command. | 
| #program_name | The name of the command for command-line invocation. | 
| #summary | A short description of the command. | 
::Gem::DefaultUserInteraction - Included
Instance Method Summary
- #execute
- #arguments Internal use only
- #defaults_str Internal use only
- #description Internal use only
- #usage Internal use only
::Gem::VersionOption - Included
| #add_platform_option | Add the –platform option to the option parser. | 
| #add_prerelease_option | Add the –prerelease option to the option parser. | 
| #add_version_option | Add the –version option to the option parser. | 
::Gem::LocalRemoteOptions - Included
| #accept_uri_http | Allows OptionParser to handle HTTP URIs. | 
| #add_bulk_threshold_option | Add the –bulk-threshold option. | 
| #add_clear_sources_option | Add the –clear-sources option. | 
| #add_local_remote_options | Add local/remote options to the command line parser. | 
| #add_proxy_option | Add the –http-proxy option. | 
| #add_source_option | Add the –source option. | 
| #add_update_sources_option | Add the –update-sources option. | 
::Gem::Command - Inherited
| #add_extra_args | Adds extra args from ~/.gemrc. | 
| #add_option | Add a command-line option and handler to the command. | 
| #arguments | Override to provide details of the arguments a command takes. | 
| #begins? | True if  | 
| #defaults_str | Override to display the default values of the command options. | 
| #description | Override to display a longer description of what this command does. | 
| #execute | Override to provide command handling. | 
| #get_all_gem_names | Get all gem names from the command line. | 
| #get_all_gem_names_and_versions | Get all [gem, version] from the command line. | 
| #get_one_gem_name | Get a single gem name from the command line. | 
| #get_one_optional_argument | Get a single optional argument from the command line. | 
| #handle_options | Handle the given list of arguments by parsing them and recording the results. | 
| #handles? | True if the command handles the given argument list. | 
| #invoke | Invoke the command with the given list of arguments. | 
| #invoke_with_build_args | Invoke the command with the given list of normal arguments and additional build arguments. | 
| #merge_options | Merge a set of command options with the set of default options (without modifying the default option hash). | 
| #remove_option | Remove previously defined command-line argument  | 
| #show_help | Display the help message for the command. | 
| #show_lookup_failure | Display to the user that a gem couldn't be found and reasons why. | 
| #usage | Override to display the usage for an individual gem command. | 
| #when_invoked | Call the given block when invoked. | 
| #add_parser_run_info | Adds a section with  | 
| #configure_options, | |
| #create_option_parser | Creates an option parser and fills it in with the help info for the command. | 
| #parser | Create on demand parser. | 
| #wrap | Wraps  | 
| #add_parser_description, #add_parser_options, #add_parser_summary | |
::Gem::UserInteraction - Included
| #alert | Displays an alert  | 
| #alert_error | Displays an error  | 
| #alert_warning | Displays a warning  | 
| #ask | Asks a  | 
| #ask_for_password | Asks for a password with a  | 
| #ask_yes_no | Asks a yes or no  | 
| #choose_from_list | Asks the user to answer  | 
| #say | Displays the given  | 
| #terminate_interaction | Terminates the RubyGems process with the given  | 
| #verbose | Calls  | 
::Gem::DefaultUserInteraction - Included
::Gem::Text - Included
| #clean_text | Remove any non-printable characters and make the text suitable for printing. | 
| #format_text | Wraps  | 
| #levenshtein_distance | This code is based directly on the ::Gem::Text gem implementation Returns a value representing the “cost” of transforming str1 into str2. | 
| #truncate_text, #min3 | |
Constructor Details
    .new  ⇒ SpecificationCommand 
  
# File 'lib/rubygems/commands/specification_command.rb', line 12
def initialize Gem.load_yaml super 'specification', 'Display gem specification (in yaml)', :domain => :local, :version => Gem::Requirement.default, :format => :yaml add_version_option('examine') add_platform_option add_prerelease_option add_option('--all', 'Output specifications for all versions of', 'the gem') do |value, | [:all] = true end add_option('--ruby', 'Output ruby format') do |value, | [:format] = :ruby end add_option('--yaml', 'Output YAML format') do |value, | [:format] = :yaml end add_option('--marshal', 'Output Marshal format') do |value, | [:format] = :marshal end end
Instance Method Details
#arguments
# File 'lib/rubygems/commands/specification_command.rb', line 43
def arguments # :nodoc: <<-ARGS GEMFILE name of gem to show the gemspec for FIELD name of gemspec field to show ARGS end
#defaults_str
# File 'lib/rubygems/commands/specification_command.rb', line 50
def defaults_str # :nodoc: "--local --version '#{Gem::Requirement.default}' --yaml" end
#description
# File 'lib/rubygems/commands/specification_command.rb', line 54
def description # :nodoc: <<-EOF The specification command allows you to extract the specification from a gem for examination. The specification can be output in YAML, ruby or Marshal formats. Specific fields in the specification can be extracted in YAML format: $ gem spec rake summary --- Ruby based make-like utility. #... EOF end
#execute
# File 'lib/rubygems/commands/specification_command.rb', line 74
def execute specs = [] gem = [:args].shift unless gem then raise Gem::CommandLineError, "Please specify a gem name or file on the command line" end case v = [:version] when String req = Gem::Requirement.create v when Gem::Requirement req = v else raise Gem::CommandLineError, "Unsupported version type: '#{v}'" end if !req.none? and [:all] alert_error "Specify --all or -v, not both" terminate_interaction 1 end if [:all] dep = Gem::Dependency.new gem else dep = Gem::Dependency.new gem, req end field = get_one_optional_argument raise Gem::CommandLineError, "--ruby and FIELD are mutually exclusive" if field and [:format] == :ruby if local? then if File.exist? gem then specs << Gem::Package.new(gem).spec rescue nil end if specs.empty? then specs.push(*dep.matching_specs) end end if remote? then dep.prerelease = [:prerelease] found, _ = Gem::SpecFetcher.fetcher.spec_for_dependency dep specs.push(*found.map { |spec,| spec }) end if specs.empty? then alert_error "No gem matching '#{dep}' found" terminate_interaction 1 end unless [:all] then specs = [specs.max_by { |s| s.version }] end specs.each do |s| s = s.send field if field say case [:format] when :ruby then s.to_ruby when :marshal then Marshal.dump s else s.to_yaml end say "\n" end end
#usage
# File 'lib/rubygems/commands/specification_command.rb', line 70
def usage # :nodoc: "#{program_name} [GEMFILE] [FIELD]" end