internal string XmlTypeNamespace
{
- get { return xmlTypeNamespace; }
+ get { return xmlTypeNamespace ?? string.Empty; }
set { xmlTypeNamespace = value; }
}
+ internal bool HasXmlTypeNamespace
+ {
+ get { return xmlTypeNamespace != null; }
+ }
+
internal ArrayList DerivedTypes
{
get { return _derivedTypes; }
internal XmlTypeMapping GetRealElementMap (string name, string ens)
{
- if (xmlType == name && xmlTypeNamespace == ens) return this;
+ if (xmlType == name && XmlTypeNamespace == ens) return this;
foreach (XmlTypeMapping map in _derivedTypes)
- if (map.xmlType == name && map.xmlTypeNamespace == ens) return map;
+ if (map.xmlType == name && map.XmlTypeNamespace == ens) return map;
return null;
}
internal class XmlSerializableMapping : XmlTypeMapping
{
XmlSchema _schema;
-#if NET_2_0
+#if NET_2_0 && !MOONLIGHT
XmlSchemaComplexType _schemaType;
XmlQualifiedName _schemaTypeName;
#endif
- internal XmlSerializableMapping(string elementName, string ns, TypeData typeData, string xmlType, string xmlTypeNamespace)
+ internal XmlSerializableMapping(XmlRootAttribute root, string elementName, string ns, TypeData typeData, string xmlType, string xmlTypeNamespace)
: base(elementName, ns, typeData, xmlType, xmlTypeNamespace)
{
-#if NET_2_0
+#if NET_2_0 && !MOONLIGHT
XmlSchemaProviderAttribute schemaProvider = (XmlSchemaProviderAttribute) Attribute.GetCustomAttribute (typeData.Type, typeof (XmlSchemaProviderAttribute));
if (schemaProvider != null) {
String.Format ("Method {0}.{1}() specified by XmlSchemaProviderAttribute has invalid signature: return type must be compatible with System.Xml.XmlQualifiedName.", typeData.Type.Name, method));
// defaultNamespace at XmlReflectionImporter takes precedence for Namespace, but not for XsdTypeNamespace.
- UpdateRoot (new XmlQualifiedName (_schemaTypeName.Name, Namespace ?? _schemaTypeName.Namespace));
+ UpdateRoot (new XmlQualifiedName (root != null ? root.ElementName : _schemaTypeName.Name, root != null ? root.Namespace : Namespace ?? _schemaTypeName.Namespace));
XmlTypeNamespace = _schemaTypeName.Namespace;
XmlType = _schemaTypeName.Name;
return;
}
#endif
+#if NET_2_0 && !MOONLIGHT
IXmlSerializable serializable = (IXmlSerializable)Activator.CreateInstance (typeData.Type, true);
+ try {
+ _schema = serializable.GetSchema();
+ } catch (Exception) {
+ // LAMESPEC: .NET has a bad exception catch and swallows it silently.
+ }
+#else
+ IXmlSerializable serializable = (IXmlSerializable)Activator.CreateInstance (typeData.Type);
_schema = serializable.GetSchema();
+#endif
+#if !MOONLIGHT
if (_schema != null)
{
if (_schema.Id == null || _schema.Id.Length == 0)
throw new InvalidOperationException("Schema Id is missing. The schema returned from " + typeData.Type.FullName + ".GetSchema() must have an Id.");
}
+#endif
}
internal XmlSchema Schema
get { return _schema; }
}
-#if NET_2_0
+#if NET_2_0 && !MOONLIGHT
internal XmlSchemaType SchemaType {
get { return _schemaType; }
}
XmlTypeMapMember _returnMember;
bool _ignoreMemberNamespace;
bool _canBeSimpleType = true;
+ bool? _isOrderDependentMap;
public void AddMember (XmlTypeMapMember member)
{
- member.GlobalIndex = _allMembers.Count;
+ // If GlobalIndex has not been set, set it now
+ if (member.GlobalIndex == -1)
+ member.GlobalIndex = _allMembers.Count;
+
_allMembers.Add (member);
if (!(member.DefaultValue is System.DBNull) && member.DefaultValue != null) {
{
XmlTypeMapMemberAttribute atm = (XmlTypeMapMemberAttribute)member;
if (_attributeMembers == null) _attributeMembers = new Hashtable();
- string key = BuildKey (atm.AttributeName, atm.Namespace);
+ string key = BuildKey (atm.AttributeName, atm.Namespace, -1);
if (_attributeMembers.ContainsKey (key))
throw new InvalidOperationException ("The XML attribute named '" + atm.AttributeName + "' from namespace '" + atm.Namespace + "' is already present in the current scope. Use XML attributes to specify another XML name or namespace for the attribute.");
member.Index = _attributeMembers.Count;
ICollection elemsInfo = ((XmlTypeMapMemberElement)member).ElementInfo;
foreach (XmlTypeMapElementInfo elem in elemsInfo)
{
- string key = BuildKey (elem.ElementName, elem.Namespace);
+ string key = BuildKey (elem.ElementName, elem.Namespace, elem.ExplicitOrder);
if (_elements.ContainsKey (key))
throw new InvalidOperationException ("The XML element named '" + elem.ElementName + "' from namespace '" + elem.Namespace + "' is already present in the current scope. Use XML attributes to specify another XML name or namespace for the element.");
_elements.Add (key, elem);
public XmlTypeMapMemberAttribute GetAttribute (string name, string ns)
{
if (_attributeMembers == null) return null;
- return (XmlTypeMapMemberAttribute)_attributeMembers [BuildKey(name,ns)];
+ return (XmlTypeMapMemberAttribute)_attributeMembers [BuildKey (name,ns, -1)];
}
- public XmlTypeMapElementInfo GetElement (string name, string ns)
+ public XmlTypeMapElementInfo GetElement (string name, string ns, int order)
{
if (_elements == null) return null;
- return (XmlTypeMapElementInfo)_elements [BuildKey(name,ns)];
+ return (XmlTypeMapElementInfo)_elements [BuildKey (name,ns, order)];
}
public XmlTypeMapElementInfo GetElement (int index)
_elementsByIndex [mem.Index] = (XmlTypeMapElementInfo) mem.ElementInfo [0];
}
}
-
+ if (index >= _elementMembers.Count)
+ return null;
return _elementsByIndex [index];
}
- private string BuildKey (string name, string ns)
+ private string BuildKey (string name, string ns, int explicitOrder)
{
if (_ignoreMemberNamespace) return name;
- else return name + " / " + ns;
+ else return name + " / " + ns + (explicitOrder < 0 ? "" : "/" + explicitOrder);
}
public ICollection AllElementInfos
set { _ignoreMemberNamespace = value; }
}
+ public bool IsOrderDependentMap {
+ get {
+ if (_isOrderDependentMap == null) {
+ _isOrderDependentMap = false;
+ foreach (XmlTypeMapElementInfo ei in _elements.Values)
+ if (ei.ExplicitOrder >= 0) {
+ _isOrderDependentMap = true;
+ break;
+ }
+ }
+ return (bool) _isOrderDependentMap;
+ }
+ }
+
public XmlTypeMapMember FindMember (string name)
{
for (int n=0; n<_allMembers.Count; n++)