Wrox Programmer Forums
Go Back   Wrox Programmer Forums > XML > XSLT
|
XSLT General questions and answers about XSLT. For issues strictly specific to the book XSLT 1.1 Programmers Reference, please post to that forum instead.
Welcome to the p2p.wrox.com Forums.

You are currently viewing the XSLT section of the Wrox Programmer to Programmer discussions. This is a community of software programmers and website developers including Wrox book authors and readers. New member registration was closed in 2019. New posts were shut off and the site was archived into this static format as of October 1, 2020. If you require technical support for a Wrox book please contact http://hub.wiley.com
 
Old August 12th, 2009, 06:03 AM
Registered User
 
Join Date: Aug 2009
Posts: 1
Thanks: 0
Thanked 0 Times in 0 Posts
Default Graph Traversal (Keep track of visited path)

Hello Everybody,

I am trying to navigate through a graph by going through every path between elements.
I face the problem of not being able to accumulate the visited paths(links between elements). The graph contain cycles, to avoid infinite loops, i need to keep track of the visited path.

Any help is appreciated,

Waiting your responses :)


Simplified version of the source file:

<element id="abc-001" name="A">
<links>
<link id="link-001" start="abc-001" end="abc-002"/> <!--out link-->
</links>
</element>
<element id="abc-002" name="B">
<links>
<link id="link-001" start="abc-001" end="abc-002"/><!--in link-->
<link id="link-002" start="abc-002" end="abc-003"/><!--out link-->
</links>
</element>
<element id="abc-003" name="C">
<links>
<link id="link-002" start="abc-002" end="abc-003"/><!--in link-->
<link id="link-003" start="abc-003" end="abc-004"/><!--out link-->
<link id="link-004" start="abc-003" end="abc-005"/><!--out link-->
<link id="link-005" start="abc-003" end="abc-006"/><!--out link-->
</links>
</element>
<element id="abc-004" name="D">
<links>
<link id="link-003" start="abc-003" end="abc-004"/><!--in link-->
<link id="link-006" start="abc-004" end="abc-007"/><!--out link-->
</links>
</element>
<element id="abc-005" name="E">
<links>
<link id="link-004" start="abc-003" end="abc-005"/><!--in link-->
<link id="link-010" start="abc-005" end="abc-010"/><!--out link-->
<link id="link-011" start="abc-005" end="abc-011"/><!--out link-->
<link id="link-012" start="abc-005" end="abc-012"/><!--out link-->
<link id="link-013" start="abc-005" end="abc-013"/><!--out link-->
<link id="link-014" start="abc-005" end="abc-014"/><!--out link-->
</links>
</element>
<element id="abc-006" name="F">
<links>
<link id="link-005" start="abc-003" end="abc-006"/><!--in link-->
<link id="link-008" start="abc-006" end="abc-008"/><!--out link-->
<link id="link-009" start="abc-006" end="abc-009"/><!--out link-->
<link id="link-015" start="abc-006" end="abc-010"/><!--out link-->
<link id="link-016" start="abc-006" end="abc-011"/><!--out link-->
</links>
</element>
<element id="abc-007" name="G">
<links>
<link id="link-006" start="abc-004" end="abc-007"/><!--in link-->
</links>
</element>




The desired output :
Starting with A :
link-001 →
link-001 link-002 →
link-001 link-002 link-003 link-004 link-005 →
link-001 link-002 link-003 link-004 link-005 link-006 →
link-001 link-002 link-003 link-004 link-005 link-006 link-007→
link-001 link-002 link-003 link-004 link-005 link-006 link-007 link-010 link-011 link-012 link-013 link-014 →
link-001 link-002 link-003 link-004 link-005 link-006 link-007 link-010 link-011 link-012 link-013 link-014 link-008 link-009 link-015 link-016


Current XSLT Stylesheet:

<xsl:template name="followLink">
<xsl:param name="sortedLinks" as="node()+"/>
<xsl:param name="oldLinks" as="xs:string" select="''"/>

<xsl:variable name="visitedLinks" select="doc:visitedLinks($sortedLinks, $oldLinks)"/>
<xsl:for-each select="$sortedLinks">
<!--elementNode contains the current element-->
<xsl:variable name="elementNode" select="key('elemKey',./@end)"/>
<xsl:choose>
<xsl:when test="count( $elementNode/links/link[(@start = ../../@id) and (@start != @end) ] ) > 0">
<xsl:choose>
<!--number of outlinks and not self referenced = 1 -->
<xsl:when test="count( $elementNode/links/link[(@start = ../../@xmi:idref) and (@start != @end) ] ) = 1">
<xsl:call-template name="followLink">
<xsl:with-param name="sortedLinks" select="$elementNode/links/link[@start = ../../@id]"/>
<xsl:with-param name="oldLinks" select="$visitedLinks"/>
</xsl:call-template>
</xsl:when>
<!-- number of outlinks and not self referenced > 1 -->
<xsl:otherwise>
<!--Sort links according to some criteria-->
<xsl:call-template name="followLink">
<xsl:with-param name="sortedLinks" select="$sortedLinks"/>
<xsl:with-param name="oldLinks" select="$visitedLinks"/>
</xsl:call-template>
</xsl:otherwise>
</xsl:choose>
</xsl:when>
<xsl:otherwise/>
</xsl:choose>
</xsl:for-each>
</xsl:template>

<xsl:function name="doc:visitedLinks" as="xs:string*">
<xsl:param name="sortedLinks" as="node()+"/>
<xsl:param name="oldLinks" as="xs:string+"/>

<xsl:variable name="visitedLinks" as="xs:string+">
<xsl:for-each select="$sortedLinks">
<xsl:sequence select="concat($delimiter, ./@id, $delimiter)"/>
</xsl:for-each>
</xsl:variable>
<xsl:sequence select="string-join(($oldLinks, $visitedLinks), ' ')"/>
</xsl:function>

The current output is like this:
If i output the visited links at each iteration i get this:
link-001 →
link-001 link-002 →
link-001 link-002 link-003 link-004 link-005 →
link-001 link-002 link-003 link-004 link-005 link-006 →
link-001 link-002 link-003 link-004 link-005 link-006 link-007→
link-001 link-002 link-003 link-004 link-005 link-010 link-011 link-012 link-013 link-014 →
link-001 link-002 link-003 link-004 link-005 link-008 link-009 link-015 link-016

How can i write the doc:visitedLinks functions so it can return the result of each iteration?

Many thanks in advance,

Mike

Last edited by Mr.Fine; August 12th, 2009 at 10:05 AM..





Similar Threads
Thread Thread Starter Forum Replies Last Post
a:visited link clearing vferratusco CSS Cascading Style Sheets 8 June 16th, 2010 11:20 AM
Visited link Issue mat41 CSS Cascading Style Sheets 10 May 14th, 2008 07:42 PM
Inorder traversal how to dsekar_nat XSLT 3 March 27th, 2006 09:16 AM
Have robots visited my site angrycat Apache Tomcat 2 February 22nd, 2005 09:50 PM
track how many times the site is visited cindy Classic ASP Basics 4 October 6th, 2003 12:06 AM





Powered by vBulletin®
Copyright ©2000 - 2020, Jelsoft Enterprises Ltd.
Copyright (c) 2020 John Wiley & Sons, Inc.