class REXML::Validation::Choice

公共类方法

new(context) 点击切换源代码
# File rexml-3.4.0/lib/rexml/validation/relaxng.rb, line 359
def initialize context
  super
  @choices = []
end

公共实例方法

<<( event ) 点击切换源代码
# File rexml-3.4.0/lib/rexml/validation/relaxng.rb, line 370
def <<( event )
  add_event_to_arry( @choices, event )
end
expected() 点击切换源代码
# File rexml-3.4.0/lib/rexml/validation/relaxng.rb, line 404
def expected
  return [@events[@current]] if @events.size > 0
  return @choices.collect do |x|
    if x[0].kind_of? State
      x[0].expected
    else
      x[0]
    end
  end.flatten
end
inspect() 点击切换源代码
# File rexml-3.4.0/lib/rexml/validation/relaxng.rb, line 415
def inspect
  "< #{to_s} #{@choices.collect{|e| e.collect{|f|f.to_s}.join(', ')}.join(' or ')} >"
end
matches?( event ) 点击切换源代码
# File rexml-3.4.0/lib/rexml/validation/relaxng.rb, line 399
def matches?( event )
  return @events[@current].matches?( event ) if @events.size > 0
  !@choices.find{|evt| evt[0].matches?(event)}.nil?
end
next( event ) 点击切换源代码
# File rexml-3.4.0/lib/rexml/validation/relaxng.rb, line 374
def next( event )
  # Make the choice if we haven't
  if @events.size == 0
    c = 0 ; max = @choices.size
    while c < max
      if @choices[c][0].class == Ref
        expand_ref_in( @choices[c], 0 )
        @choices += @choices[c]
        @choices.delete( @choices[c] )
        max -= 1
      else
        c += 1
      end
    end
    @events = @choices.find { |evt| evt[0].matches? event }
    # Remove the references
    # Find the events
  end
  unless @events
    @events = []
    return nil
  end
  super
end
reset() 点击切换源代码
# File rexml-3.4.0/lib/rexml/validation/relaxng.rb, line 364
def reset
  super
  @events = []
  @choices.each { |c| c.each { |s| s.reset if s.kind_of? State } }
end

保护实例方法

add_event_to_arry( arry, evt ) 点击切换源代码
# File rexml-3.4.0/lib/rexml/validation/relaxng.rb, line 420
def add_event_to_arry( arry, evt )
  if evt.kind_of? State or evt.class == Ref
    arry << [evt]
  elsif evt[0] == :text
   if arry[-1] and
      arry[-1][-1].kind_of?( Event ) and
      arry[-1][-1].event_type == :text and @value

      arry[-1][-1].event_arg = evt[1]
      @value = false
   end
  else
    arry << [] if evt[0] == :start_element
    arry[-1] << generate_event( evt )
  end
end