| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- // Author: Dwivedi, Ajay kumar
- // [email protected]
- using System;
- using System.Xml;
- using System.Xml.Serialization;
- namespace System.Xml.Schema
- {
- /// <summary>
- /// Summary description for XmlSchemaIdentityConstraint.
- /// </summary>
- public class XmlSchemaIdentityConstraint : XmlSchemaAnnotated
- {
- private XmlSchemaObjectCollection fields;
- private string name;
- private XmlQualifiedName qName;
- private XmlSchemaXPath selector;
- public XmlSchemaIdentityConstraint()
- {
- fields = new XmlSchemaObjectCollection();
- qName = XmlQualifiedName.Empty;
- }
-
- [System.Xml.Serialization.XmlAttribute("name")]
- public string Name
- {
- get{ return name; }
- set{ name = value; }
- }
- [XmlElement("selector",typeof(XmlSchemaXPath),Namespace=XmlSchema.Namespace)]
- public XmlSchemaXPath Selector
- {
- get{ return selector; }
- set{ selector = value; }
- }
- [XmlElement("field",typeof(XmlSchemaXPath),Namespace=XmlSchema.Namespace)]
- public XmlSchemaObjectCollection Fields
- {
- get{ return fields; }
- }
-
- [XmlIgnore]
- public XmlQualifiedName QualifiedName
- {
- get{ return qName; }
- }
- /// <remarks>
- /// 1. name must be present
- /// 2. selector and field must be present
- /// </remarks>
- [MonoTODO]
- internal int Compile(ValidationEventHandler h, XmlSchema schema)
- {
- // If this is already compiled this time, simply skip.
- if (this.IsComplied (schema.CompilationId))
- return 0;
- if(Name == null)
- error(h,"Required attribute name must be present");
- else if(!XmlSchemaUtil.CheckNCName(this.name))
- error(h,"attribute name must be NCName");
- else
- this.qName = new XmlQualifiedName(Name,schema.TargetNamespace);
- if(Selector == null)
- error(h,"selector must be present");
- else
- {
- errorCount += Selector.Compile(h,schema);
- }
- if(Fields.Count == 0)
- error(h,"atleast one field value must be present");
- else
- {
- foreach(XmlSchemaObject obj in Fields)
- {
- if(obj is XmlSchemaXPath)
- {
- XmlSchemaXPath field = (XmlSchemaXPath)obj;
- errorCount += field.Compile(h,schema);
- }
- else
- error(h,"Object of type "+obj.GetType()+" is invalid in the Fields Collection");
- }
- }
- XmlSchemaUtil.CompileID(Id,this,schema.IDCollection,h);
- this.CompilationId = schema.CompilationId;
- return errorCount;
- }
- }
- }
|