1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
|
# WSDL4R - XMLSchema simpleType definition for WSDL.
# Copyright (C) 2000-2007 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 SimpleType < Info
attr_accessor :name
attr_reader :restriction
attr_reader :list
attr_reader :union
def check_lexical_format(value)
if @restriction
check_restriction(value)
elsif @list
# TODO: check
elsif @union
# TODO: check
else
raise ArgumentError.new("incomplete simpleType")
end
end
def base
if @restriction
@restriction.base
else
nil
end
end
def initialize(name = nil)
super()
@name = name
@restriction = nil
@list = nil
@union = nil
end
def targetnamespace
parent.targetnamespace
end
def parse_element(element)
case element
when RestrictionName
@restriction = SimpleRestriction.new
@restriction
when ListName
@list = List.new
@list
when UnionName
@union = Union.new
@union
end
end
def parse_attr(attr, value)
case attr
when NameAttrName
@name = XSD::QName.new(targetnamespace, value.source)
end
end
private
def check_restriction(value)
unless @restriction.valid?(value)
raise XSD::ValueSpaceError.new("#{@name}: cannot accept '#{value}'")
end
end
end
end
end
|