2 // System.Xml.Schema.XmlSchemaAnyAttribute.cs
\r
5 // Dwivedi, Ajay kumar Adwiv@Yahoo.com
\r
6 // Atsushi Enomoto ginga@kit.hi-ho.ne.jp
\r
9 using System.Collections;
\r
10 using System.Collections.Specialized;
\r
12 using System.ComponentModel;
\r
13 using System.Xml.Serialization;
\r
14 using Mono.Xml.Schema;
\r
16 namespace System.Xml.Schema
\r
19 /// Summary description for XmlSchemaAnyAttribute.
\r
21 public class XmlSchemaAnyAttribute : XmlSchemaAnnotated
\r
23 private string nameSpace;
\r
24 private XmlSchemaContentProcessing processing;
\r
25 const string xmlname = "anyAttribute";
\r
26 private XsdWildcard wildcard;
\r
28 public XmlSchemaAnyAttribute()
\r
30 wildcard = new XsdWildcard (this);
\r
33 [System.Xml.Serialization.XmlAttribute("namespace")]
\r
34 public string Namespace
\r
36 get{ return nameSpace; }
\r
37 set{ nameSpace = value; }
\r
40 [DefaultValue(XmlSchemaContentProcessing.None)]
\r
41 [System.Xml.Serialization.XmlAttribute("processContents")]
\r
42 public XmlSchemaContentProcessing ProcessContents
\r
44 get{ return processing; }
\r
45 set{ processing = value; }
\r
49 internal bool HasValueAny {
\r
50 get { return wildcard.HasValueAny; }
\r
53 internal bool HasValueLocal {
\r
54 get { return wildcard.HasValueLocal; }
\r
57 internal bool HasValueOther {
\r
58 get { return wildcard.HasValueOther; }
\r
61 internal bool HasValueTargetNamespace {
\r
62 get { return wildcard.HasValueTargetNamespace; }
\r
65 internal StringCollection ResolvedNamespaces {
\r
66 get { return wildcard.ResolvedNamespaces; }
\r
69 internal XmlSchemaContentProcessing ResolvedProcessContents
\r
71 get{ return wildcard.ResolvedProcessing; }
\r
74 internal string TargetNamespace
\r
76 get { return wildcard.TargetNamespace; }
\r
80 /// 1. id must be of type ID
\r
81 /// 2. namespace can have one of the following values:
\r
82 /// a) ##any or ##other
\r
83 /// b) list of anyURI and ##targetNamespace and ##local
\r
85 internal override int Compile(ValidationEventHandler h, XmlSchema schema)
\r
87 // If this is already compiled this time, simply skip.
\r
88 if (this.IsComplied (schema.CompilationId))
\r
93 wildcard.TargetNamespace = schema.TargetNamespace;
\r
94 if (wildcard.TargetNamespace == null)
\r
95 wildcard.TargetNamespace = "";
\r
97 XmlSchemaUtil.CompileID(Id,this, schema.IDCollection,h);
\r
99 wildcard.Compile (Namespace, h, schema);
\r
101 if (processing == XmlSchemaContentProcessing.None)
\r
102 wildcard.ResolvedProcessing = XmlSchemaContentProcessing.Strict;
\r
104 wildcard.ResolvedProcessing = processing;
\r
106 this.CompilationId = schema.CompilationId;
\r
110 internal override int Validate(ValidationEventHandler h, XmlSchema schema)
\r
115 // 3.10.6 Wildcard Subset
\r
116 internal void ValidateWildcardSubset (XmlSchemaAnyAttribute other,
\r
117 ValidationEventHandler h, XmlSchema schema)
\r
119 wildcard.ValidateWildcardSubset (other.wildcard, h, schema);
\r
123 internal bool ValidateWildcardAllowsNamespaceName (string ns, XmlSchema schema)
\r
125 return wildcard.ValidateWildcardAllowsNamespaceName (ns, null, schema, false);
\r
130 // namespace = ((##any | ##other) | List of (anyURI | (##targetNamespace | ##local)) ) : ##any
\r
131 // processContents = (lax | skip | strict) : strict
\r
132 // {any attributes with non-schema namespace . . .}>
\r
133 // Content: (annotation?)
\r
135 internal static XmlSchemaAnyAttribute Read(XmlSchemaReader reader, ValidationEventHandler h)
\r
137 XmlSchemaAnyAttribute any = new XmlSchemaAnyAttribute();
\r
138 reader.MoveToElement();
\r
140 if(reader.NamespaceURI != XmlSchema.Namespace || reader.LocalName != xmlname)
\r
142 error(h,"Should not happen :1: XmlSchemaAnyAttribute.Read, name="+reader.Name,null);
\r
143 reader.SkipToEnd();
\r
147 any.LineNumber = reader.LineNumber;
\r
148 any.LinePosition = reader.LinePosition;
\r
149 any.SourceUri = reader.BaseURI;
\r
151 while(reader.MoveToNextAttribute())
\r
153 if(reader.Name == "id")
\r
155 any.Id = reader.Value;
\r
157 else if(reader.Name == "namespace")
\r
159 any.nameSpace = reader.Value;
\r
161 else if(reader.Name == "processContents")
\r
164 any.processing = XmlSchemaUtil.ReadProcessingAttribute(reader,out innerex);
\r
165 if(innerex != null)
\r
166 error(h, reader.Value + " is not a valid value for processContents",innerex);
\r
168 else if((reader.NamespaceURI == "" && reader.Name != "xmlns") || reader.NamespaceURI == XmlSchema.Namespace)
\r
170 error(h,reader.Name + " is not a valid attribute for anyAttribute",null);
\r
174 XmlSchemaUtil.ReadUnhandledAttribute(reader,any);
\r
178 reader.MoveToElement();
\r
179 if(reader.IsEmptyElement)
\r
182 // Content: (annotation?)
\r
184 while(reader.ReadNextElement())
\r
186 if(reader.NodeType == XmlNodeType.EndElement)
\r
188 if(reader.LocalName != xmlname)
\r
189 error(h,"Should not happen :2: XmlSchemaAnyAttribute.Read, name="+reader.Name,null);
\r
192 if(level <= 1 && reader.LocalName == "annotation")
\r
194 level = 2; //Only one annotation
\r
195 XmlSchemaAnnotation annotation = XmlSchemaAnnotation.Read(reader,h);
\r
196 if(annotation != null)
\r
197 any.Annotation = annotation;
\r
200 reader.RaiseInvalidElementError();
\r