Class: Aws::Xml::Parser Private
- Inherits:
- 
      Object
      
        - Object
- Aws::Xml::Parser
 
- Includes:
- Seahorse::Model::Shapes
- Defined in:
- lib/aws-sdk-core/xml/parser.rb,
 lib/aws-sdk-core/xml/parser/frame.rb,
 lib/aws-sdk-core/xml/parser/stack.rb,
 lib/aws-sdk-core/xml/parser/engines/ox.rb,
 lib/aws-sdk-core/xml/parser/engines/oga.rb,
 lib/aws-sdk-core/xml/parser/engines/rexml.rb,
 lib/aws-sdk-core/xml/parser/parsing_error.rb,
 lib/aws-sdk-core/xml/parser/engines/libxml.rb,
 lib/aws-sdk-core/xml/parser/engines/nokogiri.rb
Overview
This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.
A SAX-style XML parser that uses a shape context to handle types.
Defined Under Namespace
Classes: BlobFrame, BooleanFrame, FlatListFrame, FloatFrame, Frame, IntegerFrame, LibxmlEngine, ListFrame, MapEntryFrame, MapFrame, NokogiriEngine, NullFrame, OgaEngine, OxEngine, ParsingError, RexmlEngine, Stack, StringFrame, StructureFrame, TimestampFrame
Constant Summary collapse
- FRAME_CLASSES =
          This constant is part of a private API. You should avoid using this constant if possible, as it may be removed or be changed in the future. 
- { NilClass => NullFrame, BlobShape => BlobFrame, BooleanShape => BooleanFrame, FloatShape => FloatFrame, IntegerShape => IntegerFrame, ListShape => ListFrame, MapShape => MapFrame, StringShape => StringFrame, StructureShape => StructureFrame, TimestampShape => TimestampFrame, } 
Class Method Summary collapse
- 
  
    
      .engine  ⇒ Class 
    
    
  
  
  
  
  
  
  
  private
  
    Returns the default parsing engine. 
- .engine=(engine) ⇒ Object private
- .set_default_engine ⇒ Object private
Instance Method Summary collapse
- 
  
    
      #initialize(rules, options = {})  ⇒ Parser 
    
    
  
  
  
    constructor
  
  
  
  
  
  private
  
    A new instance of Parser. 
- 
  
    
      #parse(xml, target = nil, &unhandled_callback)  ⇒ Structure 
    
    
  
  
  
  
  
  
  
  private
  
    Parses the XML document, returning a parsed structure. 
Constructor Details
#initialize(rules, options = {}) ⇒ Parser
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns a new instance of Parser.
| 18 19 20 21 | # File 'lib/aws-sdk-core/xml/parser.rb', line 18 def initialize(rules, = {}) @rules = rules @engine = [:engine] || self.class.engine end | 
Class Method Details
.engine ⇒ Class
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns the default parsing engine. One of:
| 72 73 74 75 | # File 'lib/aws-sdk-core/xml/parser.rb', line 72 def engine set_default_engine unless @engine @engine end | 
.engine=(engine) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
| 59 60 61 | # File 'lib/aws-sdk-core/xml/parser.rb', line 59 def engine= engine @engine = Class === engine ? engine : load_engine(engine) end | 
.set_default_engine ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
| 77 78 79 80 81 | # File 'lib/aws-sdk-core/xml/parser.rb', line 77 def set_default_engine [:ox, :oga, :libxml, :nokogiri, :rexml].each do |name| @engine ||= try_load_engine(name) end end | 
Instance Method Details
#parse(xml, target = nil, &unhandled_callback) ⇒ Structure
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Parses the XML document, returning a parsed structure.
If you pass a block, this will yield for XML elements that are not modeled in the rules given to the constructor.
parser.parse(xml) do |path, value|
  puts "uhandled: #{path.join('/')} - #{value}"
end
The purpose of the unhandled callback block is to allow callers to access values such as the EC2 request ID that are part of the XML body but not part of the operation result.
| 41 42 43 44 45 46 | # File 'lib/aws-sdk-core/xml/parser.rb', line 41 def parse(xml, target = nil, &unhandled_callback) xml = '<xml/>' if xml.nil? or xml.empty? stack = Stack.new(@rules, target, &unhandled_callback) @engine.new(stack).parse(xml.to_s) stack.result end |