SOAP::EncodingStyle::LiteralHandler (Class)

In: soap/encodingstyle/literalHandler.rb
Parent: Handler

Constants

Namespace = SOAP::LiteralNamespace

Public Class methods

[Source]

# File soap/encodingstyle/literalHandler.rb, line 20
  def initialize(charset = nil)
    super(charset)
    @textbuf = ''
  end

Public Instance methods

[Source]

# File soap/encodingstyle/literalHandler.rb, line 155
  def decode_epilogue
  end

[Source]

# File soap/encodingstyle/literalHandler.rb, line 158
  def decode_parent(parent, node)
    case parent.node
    when SOAPUnknown
      newparent = parent.node.as_struct
      node.parent = newparent
      parent.replace_node(newparent)
      decode_parent(parent, node)

    when SOAPStruct
      parent.node.add(node.name, node)

    when SOAPArray
      if node.position
        parent.node[*(decode_arypos(node.position))] = node
        parent.node.sparse = true
      else
        parent.node.add(node)
      end

    when SOAPBasetype
      raise EncodingStyleError.new("SOAP base type must not have a child.")

    else
      # SOAPUnknown does not have parent.

      # raise EncodingStyleError.new("Illegal parent: #{ parent }.")

    end
  end

[Source]

# File soap/encodingstyle/literalHandler.rb, line 152
  def decode_prologue
  end

[Source]

# File soap/encodingstyle/literalHandler.rb, line 123
  def decode_tag(ns, elename, attrs, parent)
    # ToDo: check if @textbuf is empty...

    @textbuf = ''
    o = SOAPUnknown.new(self, elename)
    o.parent = parent
    o
  end

[Source]

# File soap/encodingstyle/literalHandler.rb, line 131
  def decode_tag_end(ns, node)
    o = node.node
    if o.is_a?(SOAPUnknown)
      newnode = if /\A\s*\z/ =~ @textbuf
          o.as_struct
        else
          o.as_string
        end
      node.replace_node(newnode)
      o = node.node
    end

    decode_textbuf(o)
    @textbuf = ''
  end

[Source]

# File soap/encodingstyle/literalHandler.rb, line 147
  def decode_text(ns, text)
    # @textbuf is set at decode_tag_end.

    @textbuf << text
  end

encode interface.

[Source]

# File soap/encodingstyle/literalHandler.rb, line 29
  def encode_data(generator, ns, qualified, data, parent)
    attrs = {}
    name = if qualified and data.elename.namespace
        SOAPGenerator.assign_ns(attrs, ns, data.elename.namespace)
        ns.name(data.elename)
      else
        data.elename.name
      end

    case data
    when SOAPRawString
      generator.encode_tag(name, attrs)
      generator.encode_rawstring(data.to_s)
    when XSD::XSDString
      generator.encode_tag(name, attrs)
      generator.encode_string(@charset ? XSD::Charset.encoding_to_xml(data.to_s, @charset) : data.to_s)
    when XSD::XSDAnySimpleType
      generator.encode_tag(name, attrs)
      generator.encode_string(data.to_s)
    when SOAPStruct
      generator.encode_tag(name, attrs)
      data.each do |key, value|
        value.elename.namespace = data.elename.namespace if !value.elename.namespace
        yield(value, true)
      end
    when SOAPArray
      generator.encode_tag(name, attrs)
      data.traverse do |child, *rank|
        data.position = nil
        yield(child, true)
      end
    when SOAPElement
      generator.encode_tag(name, attrs.update(data.extraattr))
      generator.encode_rawstring(data.text) if data.text
      data.each do |key, value|
        value.elename.namespace = data.elename.namespace if !value.elename.namespace
        #yield(value, data.qualified)

        yield(value, qualified)
      end
    else
      raise EncodingStyleError.new("Unknown object:#{ data } in this encodingStyle.")
    end
  end

[Source]

# File soap/encodingstyle/literalHandler.rb, line 73
  def encode_data_end(generator, ns, qualified, data, parent)
    name = if qualified and data.elename.namespace
        ns.name(data.elename)
      else
        data.elename.name
      end
    generator.encode_tag_end(name)
  end

[Validate]