Wednesday, 21 July 2010

FinalBuilder, XPath, WIX, XML namespaces etc.

A few weeks ago myself and another developer spent a morning scratching our heads trying to work out why we couldn't reference certain elements in Wix installation script using XPath through FinalBuilder. Every combination of element and attribute id's we tried produced an empty result set. The only thing that worked was when we referenced the attribute in question using the inbuilt XPath node() function. By using //node()/node() were were able to address the attributes local to the the first element. In the case of Wix this refers to the project element:

<wix xmlns="http://schemas.microsoft.com/wix/2006/wi">
<product id="{cea1706b-2804-4c85-b4eb-083b0394fccc}" name="LongArm" language="1033" version="2.187.0"></product>

Therefore using //node()/node() we are able to skip straight to the first child element of the first root element. From here we were able to use the attribute name of Id and Version to access the attributes we needed to generate an upgrade msi. I realised soon after that node() worked because it is namespace independent whereas our attempts at more fancy XPath queries required namespace resolution. Examples I found on the internet were all applied to xml files either devoid of namespaces or which used named namespaces. My first attempt at solving this issue was therefore to force a name on the namespace:

<wix xmlns:a="http://schemas.microsoft.com/wix/2006/wi">
<product id="{cea1706b-2804-4c85-b4eb-083b0394fccc}" name="LongArm" language="1033" version="2.187.0"></product>

This let me address the attributes I needed by using //a:Wix/a:Product

The first time I attempted to run this through the Wix compiler however I was greeted with a compilation error from visual studio. Candle.exe balked at the new and exciting namespace identifier.

Frustrated I then went back to FinalBuilder to see if there were any hints or tips on the configuration of the Edit XML File element. It was then I noticed the MSXML Parser tab in the Edit XML dialog screen:
I ticked the namespace prefix option and was amazed to see this work first time.

No comments:

Post a Comment