Hi,
I have an XML structure like the following:
<Root>
<Base>
<Greeting>Base Hello!</Greeting>
<SpecialMessage>Base Special Message</SpecialMessage>
<Products>
<Product id="001">
<Greeting>Base 001 Hello!</Greeting>
</Product>
</Products>
</Base>
<Buy>
<Greeting>Buy Hello!</Greeting>
<SpecialMessage>Buy Special Message</SpecialMessage>
<Products>
<Product id="001">
<Greeting>Buy 001 Hello!</Greeting>
</Product>
</Products>
</Buy>
<Rent>
<Greeting>Rent Hello</Greeting>
</Rent>
</Root>
The Base, Buy and Rent nodes will always exist, but the nodes within them may or may not. At runtime, I'll determine if this is a Buy or Rent scenario. I also may or may not have a product id.
For example, if it's a buy scenario and the product id is "001", I'll get the "Buy 001 Hello" Message. However, if the Product section in the Buy section were to be missing for whatever reason, I'll return "Base 001 Hello".
A second example would be if I wanted to get the SpecialMessage for a Rent scenario. Since no SpecialMessage node is in the Rent section, I'll return "Base Special Message"
I assemble a list of XPaths like this, using Greeting as an example in a Buy scenario for product 001):
- /Root/Buy/Products/Product[id=001]/Greeting
- /Root/Base/Products/Product[id=001]/Greeting
- /Root/Buy/Greeting
- /Root/Base/Greeting
At the moment, I start at the top of the list, run the XPath, return the result if it's found, other wise move on to the next XPath and so on:
string result;
result = RunXPath(xpaths["Level1"], document);
if (!String.IsNullOrEmpty(result))
return result;
result = RunXPath(xpaths["Level2"], document);
if (!String.IsNullOrEmpty(result))
return result;
result = RunXPath(xpaths["Level3"], document);
if (!String.IsNullOrEmpty(result))
return result;
result = RunXPath(xpaths["Level4"], document);
if (!String.IsNullOrEmpty(result))
return result;
return String.Empty;
While it works, it seems awkward and a little rough to read. Are there better approaches, in terms of readability?