3

I am trying to make an XML file with a root element:

<urn:Command complete="true" xmlns:urn="namespaceURI">

So I have an element Command a namespace namespaceURI a prefix urn and finally an attribute string with name complete a value true and no namespace.

The code I have made to do this returns:

<urn:Command xmlns:urn="namespaceURI" complete="true">

So the problem is I would like the attribute string to be before the namespace definition in the XML file and I can't find a similar problem on this website.

I have tried writing a StartElement with a prefix and namespace then writing an AttributeString with no namespace, this returns the root element with the defined namespace first followed by the attribute string. I have also tried only defining a start element and then two attribute strings but then I can't find a way to write the prefix to the start element.

This is my original code that returns the root element with a namespace definition first the the attribute definition:

`Dim Writer as System.Xml.XmlWriter;
dim writerSettings  as System.Xml.XmlWriterSettings;
dim basePath as string;
dim source as string;
dim destination as string;

writerSettings = new System.Xml.XmlWriterSettings();
'writerSettings.ConformanceLevel= false;
'writerSettings.Encoding = new System.Text.UTF8Encoding(false);
writerSettings.OmitXmlDeclaration = false;

basePath = System.IO.Path.Combine("\\wnlcuieb502\WEI\Outbound","RolexSet");
source  = System.IO.Path.Combine(basePath,"\\wnlcuieb502\WEI\Outbound","TEST.XML");

Writer = System.Xml.XmlWriter.Create(source,writerSettings);
Writer.WriteStartDocument();

Writer.WriteStartElement("urn","SetPackagingOrder","urn:laetus.com:ws:tts:mes");
Writer.WriteAttributeString("complete",null,"true");
Writer.WriteEndElement();
Writer.WriteEndDocument();
Writer.dispose();


try
    destination = System.IO.Path.Combine(basePath,"TEST.XML");
    while not System.IO.File.Exists(destination)        
        System.IO.File.Move(source,destination);
    endwhile;
catch
    LogError(Me.HierarchicalName + ": Could not move XML file: "+ "TEST.XML" +" from " + source + " to " + destination + ", Error: " + error.Message);
endtry;`
kjhughes
  • 106,133
  • 27
  • 181
  • 240
  • Can you provide code that reproduces the issue? With your code, the complete attribute is output before the namespace declaration ([tried it](https://tio.run/##hZHbSsQwEIbv8xShVy2sfYHihVYvBEWxKwriRUyHEsihZCa7ivTZa9q6hxZXBwLJ5P@/mUwknkmUfR9Q2YZXn0hgCnZ8ytfwQQVjVhjAVkjg1T37YjyG1AKRP3jXeGHGzJQfAkmQknzjVM3vhLIpko/Q1zcufIPZXndwDFGNosugdA2eu0BtIH7OLWznV2lWzHwb4fnWKwJfAVHU4c41veHF6GE9zyQRciCcwEXMb4i89CAI0qnD1aL2ornpMh@dFQlPV04GA5bS/4TXGkZdErxNVjwpnTHC1sN2/x1PjzfJH5wLinN7DwNwmF@aSGdaDQQRYoPWEUU@wAlEqR3Css3SWXQaJv6tsrsx5Gv3UyQ7cnSzCXes6/tv)), which is what you want if I understood correctly. – steve16351 Sep 02 '19 at 11:32
  • @steve16351 I have editted my post to include simplified code i used. The code is in a script builder on a program called System platform by wonderware so is quite simplified to begin with. using this code i still get the output – nick macdonald Sep 02 '19 at 11:56
  • I also found out that the program uses a .Net library so this could be why we have diferences – nick macdonald Sep 02 '19 at 12:40

1 Answers1

5

XML attribute and namespace declaration order should never matter

Attribute order is insignificant per the XML Recommendation:

Note that the order of attribute specifications in a start-tag or empty-element tag is not significant.

Namespace declaration are like attributes (W3C Namespaces in XML Recommendation, section 3 Declaring Namespaces),

[Definition: A namespace (or more precisely, a namespace binding) is declared using a family of reserved attributes. Such an attribute's name must either be xmlns or begin xmlns:. These attributes, like any other XML attributes, may be provided directly or by default. ]

with similarly insignificant ordering.

So, no conformant XML tool or library will care about the order of XML attributes and XML namespace declarations, and neither should you.

This is why XML libraries generally do not provide a way to constrain attribute ordering, and trying to do so is almost always a sign that you're doing something wrong.


...except for rarely needed normalization applications

The XML recommendations will all consider attribute ordering and namespace declaration ordering to be insignificant, but see the section on attribute processing in the XML Normalization Recommendation or the Canonical XML Recommendation if your application has an unavoidable need for attribute ordering. The need to establish lexical equality/inequality for digital signatures (XML Signature Syntax and Processing Version 1.1) is one such exception.

See also (but only if you absolutely must order XML attributes and namespaces declarations):

Peter Mortensen
  • 30,738
  • 21
  • 105
  • 131
kjhughes
  • 106,133
  • 27
  • 181
  • 240
  • "XML attribute and namespace declaration order should never matter" - which is great, until you're trying to diff a problem in an attribute an it shows every single tag as being changed because they're out of order. – Maury Markowitz Sep 27 '22 at 15:28
  • @MauryMarkowitz: At the text level, diff is just doing its (lexical) job, unaware of XML semantics. If you're forced to use such a blunt instrument for diff'ing XML, see the answer's next section, **...except for rarely needed normalization applications**. – kjhughes Sep 27 '22 at 16:16