Class: OptionParser::List

Inherits:
Object show all
Defined in:
opal/stdlib/optparse.rb

Overview

Simple option list providing mapping from short and/or long option string to OptionParser::Switch and mapping from acceptable argument to matching pattern and converter pair. Also provides summary feature.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeList

Just initializes all instance variables.



775
776
777
778
779
780
# File 'opal/stdlib/optparse.rb', line 775

def initialize
  @atype = {}
  @short = OptionMap.new
  @long = OptionMap.new
  @list = []
end

Instance Attribute Details

#atypeObject (readonly)

Map from acceptable argument types to pattern and converter pairs.



761
762
763
# File 'opal/stdlib/optparse.rb', line 761

def atype
  @atype
end

#listObject (readonly)

List of all switches and summary string.



770
771
772
# File 'opal/stdlib/optparse.rb', line 770

def list
  @list
end

#longObject (readonly)

Map from long style option switches to actual switch objects.



767
768
769
# File 'opal/stdlib/optparse.rb', line 767

def long
  @long
end

#shortObject (readonly)

Map from short style option switches to actual switch objects.



764
765
766
# File 'opal/stdlib/optparse.rb', line 764

def short
  @short
end

Instance Method Details

#accept(t, pat = /.*/m, &block) ⇒ Object

See OptionParser.accept.



785
786
787
788
789
790
791
792
793
794
795
796
# File 'opal/stdlib/optparse.rb', line 785

def accept(t, pat = /.*/m, &block)
  if pat
    pat.respond_to?(:match) ||
      raise(TypeError, "has no `match'", ParseError.filter_backtrace(caller(2)))
  else
    pat = t if t.respond_to?(:match)
  end
  unless block
    block = pat.method(:convert).to_proc if pat.respond_to?(:convert)
  end
  @atype[t] = [pat, block]
end

#add_banner(to) ⇒ Object

:nodoc:



909
910
911
912
913
914
915
916
# File 'opal/stdlib/optparse.rb', line 909

def add_banner(to) # :nodoc:
  list.each do |opt|
    if opt.respond_to?(:add_banner)
      opt.add_banner(to)
    end
  end
  to
end

#append(*args) ⇒ Object

Appends +switch+ at the tail of the list, and associates short, long and negated long options. Arguments are:

+switch+:: OptionParser::Switch instance to be inserted. +short_opts+:: List of short style options. +long_opts+:: List of long style options. +nolong_opts+:: List of long style options with "no-" prefix.

append(switch, short_opts, long_opts, nolong_opts)



849
850
851
852
# File 'opal/stdlib/optparse.rb', line 849

def append(*args)
  update(*args)
  @list.push(args[0])
end

#complete(id, opt, icase = false, *pat, &block) ⇒ Object

Searches list +id+ for +opt+ and the optional patterns for completion +pat+. If +icase+ is true, the search is case insensitive. The result is returned or yielded if a block is given. If it isn't found, nil is returned.



871
872
873
# File 'opal/stdlib/optparse.rb', line 871

def complete(id, opt, icase = false, *pat, &block)
  __send__(id).complete(opt, icase, *pat, &block)
end

#compsys(*args, &block) ⇒ Object

:nodoc:



918
919
920
921
922
923
924
# File 'opal/stdlib/optparse.rb', line 918

def compsys(*args, &block) # :nodoc:
  list.each do |opt|
    if opt.respond_to?(:compsys)
      opt.compsys(*args, &block)
    end
  end
end

#each_option(&block) ⇒ Object

Iterates over each option, passing the option to the +block+.



882
883
884
# File 'opal/stdlib/optparse.rb', line 882

def each_option(&block)
  list.each(&block)
end

#get_candidates(id) {|__send__(id).keys| ... } ⇒ Object

Yields:

  • (__send__(id).keys)


875
876
877
# File 'opal/stdlib/optparse.rb', line 875

def get_candidates(id)
  yield __send__(id).keys
end

#prepend(*args) ⇒ Object

Inserts +switch+ at the head of the list, and associates short, long and negated long options. Arguments are:

+switch+:: OptionParser::Switch instance to be inserted. +short_opts+:: List of short style options. +long_opts+:: List of long style options. +nolong_opts+:: List of long style options with "no-" prefix.

prepend(switch, short_opts, long_opts, nolong_opts)



833
834
835
836
# File 'opal/stdlib/optparse.rb', line 833

def prepend(*args)
  update(*args)
  @list.unshift(args[0])
end

#reject(t) ⇒ Object

See OptionParser.reject.



801
802
803
# File 'opal/stdlib/optparse.rb', line 801

def reject(t)
  @atype.delete(t)
end

#search(id, key) ⇒ Object

Searches +key+ in +id+ list. The result is returned or yielded if a block is given. If it isn't found, nil is returned.



858
859
860
861
862
863
# File 'opal/stdlib/optparse.rb', line 858

def search(id, key)
  if list = __send__(id)
    val = list.fetch(key) { return nil }
    block_given? ? yield(val) : val
  end
end

#summarize(*args, &block) ⇒ Object

Creates the summary table, passing each line to the +block+ (without newline). The arguments +args+ are passed along to the summarize method which is called on every option.



891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
# File 'opal/stdlib/optparse.rb', line 891

def summarize(*args, &block)
  sum = []
  list.reverse_each do |opt|
    if opt.respond_to?(:summarize) # perhaps OptionParser::Switch
      s = []
      opt.summarize(*args) { |l| s << l }
      sum.concat(s.reverse)
    elsif !opt || opt.empty?
      sum << ''
    elsif opt.respond_to?(:each_line)
      sum.concat([*opt.each_line].reverse)
    else
      sum.concat([*opt.each].reverse)
    end
  end
  sum.reverse_each(&block)
end