mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
66 lines
1.2 KiB
Ruby
66 lines
1.2 KiB
Ruby
|
# WSDL4R - XMLSchema simpleContent definition for WSDL.
|
||
|
# Copyright (C) 2004 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
|
||
|
|
||
|
# This program is copyrighted free software by NAKAMURA, Hiroshi. You can
|
||
|
# redistribute it and/or modify it under the same terms of Ruby's license;
|
||
|
# either the dual license version in 2003, or any later version.
|
||
|
|
||
|
|
||
|
require 'wsdl/info'
|
||
|
require 'xsd/namedelements'
|
||
|
|
||
|
|
||
|
module WSDL
|
||
|
module XMLSchema
|
||
|
|
||
|
|
||
|
class SimpleContent < Info
|
||
|
attr_accessor :base
|
||
|
attr_reader :derivetype
|
||
|
attr_reader :content
|
||
|
attr_reader :attributes
|
||
|
|
||
|
def initialize
|
||
|
super
|
||
|
@base = nil
|
||
|
@derivetype = nil
|
||
|
@content = nil
|
||
|
@attributes = XSD::NamedElements.new
|
||
|
end
|
||
|
|
||
|
def targetnamespace
|
||
|
parent.targetnamespace
|
||
|
end
|
||
|
|
||
|
def parse_element(element)
|
||
|
case element
|
||
|
when RestrictionName, ExtensionName
|
||
|
@derivetype = element.name
|
||
|
self
|
||
|
when AttributeName
|
||
|
if @derivetype.nil?
|
||
|
raise Parser::ElementConstraintError.new("base attr not found.")
|
||
|
end
|
||
|
o = Attribute.new
|
||
|
@attributes << o
|
||
|
o
|
||
|
end
|
||
|
end
|
||
|
|
||
|
def parse_attr(attr, value)
|
||
|
if @derivetype.nil?
|
||
|
return nil
|
||
|
end
|
||
|
case attr
|
||
|
when BaseAttrName
|
||
|
@base = value
|
||
|
else
|
||
|
nil
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
|
||
|
end
|
||
|
end
|