blob: e808c318c4596263744f977f4dbb61a57aed0bd0 (
plain)
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
|
# WSDL4R - XMLSchema simpleType definition for WSDL.
# Copyright (C) 2004, 2005 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
def check_lexical_format(value)
if @restriction
check_restriction(value)
else
raise ArgumentError.new("incomplete simpleType")
end
end
def base
if @restriction
@restriction.base
else
raise ArgumentError.new("incomplete simpleType")
end
end
def initialize(name = nil)
super()
@name = name
@restriction = nil
end
def targetnamespace
parent.targetnamespace
end
def parse_element(element)
case element
when RestrictionName
@restriction = SimpleRestriction.new
@restriction
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
|