blob: a10436911f4a3e534e0ab9b9428fc9102366c5f1 [file] [log] [blame]
<HTML><HEAD><META CONTENT="text/html; charset=UTF-8" HTTP-EQUIV="Content-Type"/><TITLE>EMMA Coverage Report</TITLE><STYLE TYPE="text/css"> TABLE,TD,TH {border-style:solid; border-color:black;} TD,TH {background:white;margin:0;line-height:100%;padding-left:0.5em;padding-right:0.5em;} TD {border-width:0 1px 0 0;} TH {border-width:1px 1px 1px 0;} TR TD.h {color:red;} TABLE {border-spacing:0; border-collapse:collapse;border-width:0 0 1px 1px;} P,H1,H2,H3,TH {font-family:verdana,arial,sans-serif;font-size:10pt;} TD {font-family:courier,monospace;font-size:10pt;} TABLE.hdft {border-spacing:0;border-collapse:collapse;border-style:none;} TABLE.hdft TH,TABLE.hdft TD {border-style:none;line-height:normal;} TABLE.hdft TH.tl,TABLE.hdft TD.tl {background:#6699CC;color:white;} TABLE.hdft TD.nv {background:#6633DD;color:white;} .nv A:link {color:white;} .nv A:visited {color:white;} .nv A:active {color:yellow;} TABLE.hdft A:link {color:white;} TABLE.hdft A:visited {color:white;} TABLE.hdft A:active {color:yellow;} .in {color:#356085;} TABLE.s TD {padding-left:0.25em;padding-right:0.25em;} TABLE.s TD.l {padding-left:0.25em;padding-right:0.25em;text-align:right;background:#F0F0F0;} TABLE.s TR.z TD {background:#FF9999;} TABLE.s TR.p TD {background:#FFFF88;} TABLE.s TR.c TD {background:#CCFFCC;} A:link {color:#0000EE;text-decoration:none;} A:visited {color:#0000EE;text-decoration:none;} A:hover {color:#0000EE;text-decoration:underline;} TABLE.cn {border-width:0 0 1px 0;} TABLE.s {border-width:1px 0 1px 1px;} TD.h {color:red;border-width:0 1px 0 0;} TD.f {border-width:0 1px 0 1px;} TD.hf {color:red;border-width:0 1px 0 1px;} TH.f {border-width:1px 1px 1px 1px;} TR.cis TD {background:#F0F0F0;} TR.cis TD {border-width:1px 1px 1px 0;} TR.cis TD.h {color:red;border-width:1px 1px 1px 0;} TR.cis TD.f {border-width:1px 1px 1px 1px;} TR.cis TD.hf {color:red;border-width:1px 1px 1px 1px;} TD.b {border-style:none;background:transparent;line-height:50%;} TD.bt {border-width:1px 0 0 0;background:transparent;line-height:50%;} TR.o TD {background:#F0F0F0;}TABLE.it {border-style:none;}TABLE.it TD,TABLE.it TH {border-style:none;}</STYLE></HEAD><BODY><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="tl"><A HREF="http://www.eclemma.org/">EMMA</A> Coverage Report (generated Fri Feb 20 18:44:54 GMT 2009)</TH></TR><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="a8.html">org.eclipse.wst.xml.core.internal.contentmodel.internal.util</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">CMValidator.java</SPAN>]</H2><TABLE CELLSPACING="0" WIDTH="100%"><TR><TH>name</TH><TH>class, %</TH><TH>method, %</TH><TH>block, %</TH><TH>line, %</TH></TR><TR><TD>CMValidator.java</TD><TD CLASS="h">77%  (10/13)</TD><TD CLASS="h">49%  (34/69)</TD><TD CLASS="h">40%  (822/2039)</TD><TD CLASS="h">39%  (191.1/487)</TD></TR></TABLE><H3>COVERAGE BREAKDOWN BY CLASS AND METHOD</H3><TABLE CLASS="cn" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="f">name</TH><TH>class, %</TH><TH>method, %</TH><TH>block, %</TH><TH>line, %</TH></TR><TR><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#0">CMValidator$MatchModelNode</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/29)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR><TD CLASS="f"><A HREF="#0">CMValidator$MatchModelNode (CMValidator$MatchModelNode, CMNode): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/11)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">printModel (int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#3">CMValidator$MatchModelNodeBuilder</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/6)</TD><TD CLASS="h">0%   (0/162)</TD><TD CLASS="h">0%   (0/34)</TD></TR><TR><TD CLASS="f"><A HREF="#3">CMValidator$MatchModelNodeBuilder (List): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/22)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#5">buildMatchModel (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/97)</TD><TD CLASS="h">0%   (0/19)</TD></TR><TR><TD CLASS="f"><A HREF="#6">getRoot (): CMValidator$MatchModelNode</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#7">isCMGroup (CMNode): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#8">pop (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/21)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#9">push (CMValidator$MatchModelNode): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/9)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#a">CMValidator$PathRecordingResult</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/63)</TD><TD CLASS="h">0%   (0/16)</TD></TR><TR><TD CLASS="f"><A HREF="#a">CMValidator$PathRecordingResult (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/8)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">getArcList (): List</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/26)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR><TD CLASS="f"><A HREF="#d">getMatchModel (): CMValidator$MatchModelNode</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/11)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#e">pop (CMValidator$Arc): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/12)</TD><TD CLASS="h">0%   (0/3)</TD></TR><TR><TD CLASS="f"><A HREF="#f">push (CMValidator$Arc): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/6)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#10">CMValidator$ElementList</A></TD><TD>100% (1/1)</TD><TD CLASS="h">33%  (1/3)</TD><TD CLASS="h">5%   (3/65)</TD><TD CLASS="h">6%   (1/17)</TD></TR><TR><TD CLASS="f"><A HREF="#11">create (List): CMValidator$ElementList</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/35)</TD><TD CLASS="h">0%   (0/12)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#12">toString (): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/27)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR><TD CLASS="f"><A HREF="#10">CMValidator$ElementList (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#14">CMValidator</A></TD><TD>100% (1/1)</TD><TD CLASS="h">44%  (7/16)</TD><TD CLASS="h">27%  (233/870)</TD><TD CLASS="h">30%  (64.7/218)</TD></TR><TR><TD CLASS="f"><A HREF="#15">collectNamedArcs (CMValidator$GraphNode, List, int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/51)</TD><TD CLASS="h">0%   (0/10)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#16">collectNextSiblings (CMValidator$GraphNode, List, List, List, int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/84)</TD><TD CLASS="h">0%   (0/18)</TD></TR><TR><TD CLASS="f"><A HREF="#17">createStringList (String [], int): List</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/20)</TD><TD CLASS="h">0%   (0/4)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#18">getMatchingArcs (CMElementDeclaration, String): List</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/67)</TD><TD CLASS="h">0%   (0/15)</TD></TR><TR><TD CLASS="f"><A HREF="#19">getNextSiblings (CMElementDeclaration, String): CMNode []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/42)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1a">getOriginArray (CMElementDeclaration, List, CMValidator$ElementContentCompara...</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/68)</TD><TD CLASS="h">0%   (0/19)</TD></TR><TR><TD CLASS="f"><A HREF="#1b">printGraph (CMValidator$GraphNode): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/11)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1c">printGraph (CMValidator$GraphNode, Vector, Vector, int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/57)</TD><TD CLASS="h">0%   (0/12)</TD></TR><TR><TD CLASS="f"><A HREF="#1d">validatAllGroupContent (List, CMValidator$ElementContentComparator, CMGroup, ...</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/149)</TD><TD CLASS="h">0%   (0/41)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1e">validate (CMElementDeclaration, List, CMValidator$ElementContentComparator, C...</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">43%  (58/134)</TD><TD CLASS="h">44%  (15.7/36)</TD></TR><TR><TD CLASS="f"><A HREF="#1f">createElementList (int, List, CMValidator$ElementContentComparator, CMValidat...</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>80%  (48/60)</TD><TD CLASS="h">78%  (14/18)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#20">&lt;static initializer&gt;</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (5/5)</TD><TD>100% (2/2)</TD></TR><TR><TD CLASS="f"><A HREF="#14">CMValidator (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (8/8)</TD><TD>100% (2/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#22">createGraph (CMElementDeclaration): CMValidator$GraphNode</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (10/10)</TD><TD>100% (3/3)</TD></TR><TR><TD CLASS="f"><A HREF="#23">lookupOrCreateGraph (CMElementDeclaration): CMValidator$GraphNode</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (22/22)</TD><TD>100% (6/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#24">validateElementList (CMValidator$ElementList, CMValidator$GraphNode, CMValida...</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (82/82)</TD><TD>100% (23/23)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#25">CMValidator$StringElementContentComparator</A></TD><TD>100% (1/1)</TD><TD>83%  (5/6)</TD><TD CLASS="h">37%  (90/241)</TD><TD CLASS="h">32%  (19.9/62)</TD></TR><TR><TD CLASS="f"><A HREF="#26">getURIForContentSpecification (String): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/16)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#27">matches (Object, CMNode): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">26%  (47/180)</TD><TD CLASS="h">27%  (14/51)</TD></TR><TR><TD CLASS="f"><A HREF="#28">isPCData (Object): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>87%  (13/15)</TD><TD>93%  (1.9/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#25">CMValidator$StringElementContentComparator (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#2a">isElement (Object): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (12/12)</TD><TD>100% (1/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2b">isIgnorable (Object): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (15/15)</TD><TD>100% (2/2)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#2c">CMValidator$GraphNode</A></TD><TD>100% (1/1)</TD><TD CLASS="h">67%  (2/3)</TD><TD CLASS="h">59%  (16/27)</TD><TD>86%  (6/7)</TD></TR><TR><TD CLASS="f"><A HREF="#2d">toString (): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/11)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2c">CMValidator$GraphNode (String): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (11/11)</TD><TD>100% (4/4)</TD></TR><TR><TD CLASS="f"><A HREF="#2f">addArc (CMValidator$Arc): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (5/5)</TD><TD>100% (2/2)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#30">CMValidator$Result</A></TD><TD>100% (1/1)</TD><TD CLASS="h">20%  (1/5)</TD><TD CLASS="h">60%  (9/15)</TD><TD CLASS="h">43%  (3/7)</TD></TR><TR><TD CLASS="f"><A HREF="#31">canPush (CMValidator$Arc): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#32">getOriginArray (): CMNode []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/2)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#33">pop (CMValidator$Arc): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#34">push (CMValidator$Arc): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#30">CMValidator$Result (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (9/9)</TD><TD>100% (3/3)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#36">CMValidator$GraphGenerator</A></TD><TD>100% (1/1)</TD><TD>89%  (8/9)</TD><TD CLASS="h">80%  (220/276)</TD><TD>80%  (40.9/51)</TD></TR><TR><TD CLASS="f"><A HREF="#37">visitCMAnyElement (CMAnyElement): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/27)</TD><TD CLASS="h">0%   (0/5)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#38">visitCMGroup (CMGroup): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">79%  (67/85)</TD><TD CLASS="h">72%  (10.9/15)</TD></TR><TR><TD CLASS="f"><A HREF="#39">createArcs (CMValidator$GraphNode, CMValidator$GraphNode, CMContent, boolean)...</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>85%  (64/75)</TD><TD>92%  (11/12)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#36">CMValidator$GraphGenerator (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (18/18)</TD><TD>100% (4/4)</TD></TR><TR><TD CLASS="f"><A HREF="#3b">createArcs (CMValidator$GraphNode, CMValidator$GraphNode, CMContent): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (7/7)</TD><TD>100% (2/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#3c">generateGraph (CMElementDeclaration): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (19/19)</TD><TD>100% (6/6)</TD></TR><TR><TD CLASS="f"><A HREF="#3d">getGraphNodeName (): String</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (14/14)</TD><TD>100% (1/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#3e">getStartGraphNode (): CMValidator$GraphNode</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR><TD CLASS="f"><A HREF="#3f">visitCMElementDeclaration (CMElementDeclaration): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (28/28)</TD><TD>100% (5/5)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#40">CMValidator$GraphGenerator$Context</A></TD><TD>100% (1/1)</TD><TD>100% (2/2)</TD><TD>83%  (15/18)</TD><TD>93%  (4.7/5)</TD></TR><TR><TD CLASS="f"><A HREF="#41">getLastGraphNode (): CMValidator$GraphNode</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">67%  (6/9)</TD><TD CLASS="h">66%  (0.7/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#40">CMValidator$GraphGenerator$Context (CMValidator$GraphNode, CMValidator$GraphN...</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (9/9)</TD><TD>100% (4/4)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#43">CMValidator$ElementPathRecordingResult</A></TD><TD>100% (1/1)</TD><TD CLASS="h">56%  (5/9)</TD><TD>85%  (208/245)</TD><TD CLASS="h">79%  (41/52)</TD></TR><TR><TD CLASS="f"><A HREF="#44">getElementOriginList (): Vector</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#45">getOriginArray (): CMNode []</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#46">setOriginArray (CMNode []): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#47">setPartialValidationCount (int): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="f"><A HREF="#48">canPush (CMValidator$Arc): boolean</A></TD><TD> </TD><TD>100% (1/1)</TD><TD CLASS="h">47%  (20/43)</TD><TD CLASS="h">55%  (6/11)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#43">CMValidator$ElementPathRecordingResult (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (24/24)</TD><TD>100% (6/6)</TD></TR><TR><TD CLASS="f"><A HREF="#4a">getPartialValidationCount (): int</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (3/3)</TD><TD>100% (1/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4b">pop (CMValidator$Arc): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (80/80)</TD><TD>100% (14/14)</TD></TR><TR><TD CLASS="f"><A HREF="#4c">push (CMValidator$Arc): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (81/81)</TD><TD>100% (14/14)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#4d">CMValidator$Arc</A></TD><TD>100% (1/1)</TD><TD>100% (2/2)</TD><TD>100% (22/22)</TD><TD>100% (8/8)</TD></TR><TR><TD CLASS="f"><A HREF="#4d">CMValidator$Arc (int, CMValidator$GraphNode, CMNode): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (7/7)</TD><TD>100% (2/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4f">CMValidator$Arc (int, String, CMValidator$GraphNode, CMNode): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (15/15)</TD><TD>100% (6/6)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#50">CMValidator$ItemCount</A></TD><TD>100% (1/1)</TD><TD>100% (1/1)</TD><TD>100% (6/6)</TD><TD>100% (2/2)</TD></TR><TR><TD CLASS="f"><A HREF="#50">CMValidator$ItemCount (): void</A></TD><TD> </TD><TD>100% (1/1)</TD><TD>100% (6/6)</TD><TD>100% (2/2)</TD></TR></TABLE><P></P><TABLE CLASS="s" CELLSPACING="0" WIDTH="100%"><TR><TD CLASS="l">1</TD><TD>/*******************************************************************************</TD></TR><TR><TD CLASS="l">2</TD><TD> * Copyright (c) 2002, 2006 IBM Corporation and others.</TD></TR><TR><TD CLASS="l">3</TD><TD> * All rights reserved. This program and the accompanying materials</TD></TR><TR><TD CLASS="l">4</TD><TD> * are made available under the terms of the Eclipse Public License v1.0</TD></TR><TR><TD CLASS="l">5</TD><TD> * which accompanies this distribution, and is available at</TD></TR><TR><TD CLASS="l">6</TD><TD> * http://www.eclipse.org/legal/epl-v10.html</TD></TR><TR><TD CLASS="l">7</TD><TD> *</TD></TR><TR><TD CLASS="l">8</TD><TD> * Contributors:</TD></TR><TR><TD CLASS="l">9</TD><TD> *     IBM Corporation - initial API and implementation</TD></TR><TR><TD CLASS="l">10</TD><TD> *     Jens Lukowski/Innoopract - initial renaming/restructuring</TD></TR><TR><TD CLASS="l">11</TD><TD> *     </TD></TR><TR><TD CLASS="l">12</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">13</TD><TD>package org.eclipse.wst.xml.core.internal.contentmodel.internal.util;</TD></TR><TR><TD CLASS="l">14</TD><TD> </TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.ArrayList;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.util.Enumeration;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.util.HashMap;</TD></TR><TR><TD CLASS="l">18</TD><TD>import java.util.Hashtable;</TD></TR><TR><TD CLASS="l">19</TD><TD>import java.util.Iterator;</TD></TR><TR><TD CLASS="l">20</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">21</TD><TD>import java.util.Vector;</TD></TR><TR><TD CLASS="l">22</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMAnyElement;</TD></TR><TR><TD CLASS="l">23</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMContent;</TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMDataType;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMDocument;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMElementDeclaration;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMGroup;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMNode;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.CMNodeList;</TD></TR><TR><TD CLASS="l"><A NAME="14">30</A></TD><TD>import org.eclipse.wst.xml.core.internal.contentmodel.util.CMVisitor;</TD></TR><TR><TD CLASS="l">31</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="20">32</A></TD><TD> </TD></TR><TR><TD CLASS="l">33</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">34</TD><TD>public class CMValidator</TD></TR><TR><TD CLASS="l">35</TD><TD>{</TD></TR><TR CLASS="c"><TD CLASS="l">36</TD><TD>  protected static StringElementContentComparator stringContentComparitor = new StringElementContentComparator();</TD></TR><TR CLASS="c"><TD CLASS="l">37</TD><TD>  protected Hashtable graphNodeTable = new Hashtable();</TD></TR><TR><TD CLASS="l">38</TD><TD> </TD></TR><TR><TD CLASS="l">39</TD><TD>  /**</TD></TR><TR><TD CLASS="l">40</TD><TD>   * GraphNode</TD></TR><TR><TD CLASS="l">41</TD><TD>   */</TD></TR><TR><TD CLASS="l">42</TD><TD>  protected static class GraphNode</TD></TR><TR><TD CLASS="l">43</TD><TD>  {</TD></TR><TR><TD CLASS="l"><A NAME="2c">44</A></TD><TD>    public String name;</TD></TR><TR><TD CLASS="l">45</TD><TD>    public boolean isTerminal;</TD></TR><TR CLASS="c"><TD CLASS="l">46</TD><TD>    public Vector arcList = new Vector();</TD></TR><TR><TD CLASS="l">47</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">48</TD><TD>    public GraphNode(String name)</TD></TR><TR><TD CLASS="l">49</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">50</TD><TD>      this.name = name;</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="2f">51</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">52</TD><TD> </TD></TR><TR><TD CLASS="l">53</TD><TD>    public void addArc(Arc arc)</TD></TR><TR><TD CLASS="l">54</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">55</TD><TD>      arcList.addElement(arc);</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="2d">56</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">57</TD><TD> </TD></TR><TR><TD CLASS="l">58</TD><TD>    public String toString()</TD></TR><TR><TD CLASS="l">59</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">60</TD><TD>      return &#34;[GraphNode &#34; + name + &#34;]&#34;; //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">61</TD><TD>    }</TD></TR><TR><TD CLASS="l">62</TD><TD>  }</TD></TR><TR><TD CLASS="l">63</TD><TD> </TD></TR><TR><TD CLASS="l">64</TD><TD> </TD></TR><TR><TD CLASS="l">65</TD><TD>  /**</TD></TR><TR><TD CLASS="l">66</TD><TD>   * Arc</TD></TR><TR><TD CLASS="l">67</TD><TD>   */</TD></TR><TR><TD CLASS="l">68</TD><TD>  protected static class Arc</TD></TR><TR><TD CLASS="l">69</TD><TD>  {</TD></TR><TR><TD CLASS="l">70</TD><TD>    public static final int ELEMENT  = 1;</TD></TR><TR><TD CLASS="l">71</TD><TD>    public static final int REPEAT   = 2;</TD></TR><TR><TD CLASS="l">72</TD><TD>    public static final int OPTIONAL = 3;</TD></TR><TR><TD CLASS="l">73</TD><TD>    public static final int PREV_IN  = 4;</TD></TR><TR><TD CLASS="l">74</TD><TD>    public static final int OUT_NEXT = 5;</TD></TR><TR><TD CLASS="l">75</TD><TD>    public static final int LINK     = 6;</TD></TR><TR><TD CLASS="l">76</TD><TD> </TD></TR><TR><TD CLASS="l">77</TD><TD>    public int kind;</TD></TR><TR><TD CLASS="l">78</TD><TD>    public String name;</TD></TR><TR><TD CLASS="l">79</TD><TD>    public GraphNode node;</TD></TR><TR><TD CLASS="l"><A NAME="4d">80</A></TD><TD>    public CMNode cmNode;</TD></TR><TR><TD CLASS="l">81</TD><TD> </TD></TR><TR><TD CLASS="l">82</TD><TD>    public Arc(int kind, GraphNode node, CMNode cmNode)</TD></TR><TR><TD CLASS="l"><A NAME="4f">83</A></TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">84</TD><TD>      this(kind, &#34;&#34;, node, cmNode); //$NON-NLS-1$</TD></TR><TR CLASS="c"><TD CLASS="l">85</TD><TD>    }</TD></TR><TR><TD CLASS="l">86</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">87</TD><TD>    protected Arc(int kind, String name, GraphNode node, CMNode cmNode)</TD></TR><TR><TD CLASS="l">88</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">89</TD><TD>      this.name = name;</TD></TR><TR CLASS="c"><TD CLASS="l">90</TD><TD>      this.kind = kind;</TD></TR><TR CLASS="c"><TD CLASS="l">91</TD><TD>      this.node = node;</TD></TR><TR CLASS="c"><TD CLASS="l">92</TD><TD>      this.cmNode = cmNode;</TD></TR><TR CLASS="c"><TD CLASS="l">93</TD><TD>    }</TD></TR><TR><TD CLASS="l">94</TD><TD>  }</TD></TR><TR><TD CLASS="l">95</TD><TD> </TD></TR><TR><TD CLASS="l">96</TD><TD> </TD></TR><TR><TD CLASS="l">97</TD><TD>  /**</TD></TR><TR><TD CLASS="l">98</TD><TD>   * GraphGenerator</TD></TR><TR><TD CLASS="l">99</TD><TD>   */</TD></TR><TR><TD CLASS="l">100</TD><TD>  protected static class GraphGenerator extends CMVisitor</TD></TR><TR><TD CLASS="l">101</TD><TD>  {</TD></TR><TR><TD CLASS="l">102</TD><TD>    public int indent;</TD></TR><TR><TD CLASS="l">103</TD><TD>    public int count;</TD></TR><TR><TD CLASS="l">104</TD><TD>    public GraphNode startGraphNode;</TD></TR><TR><TD CLASS="l">105</TD><TD>    public Context context;</TD></TR><TR><TD CLASS="l">106</TD><TD> </TD></TR><TR><TD CLASS="l">107</TD><TD>    protected static class Context</TD></TR><TR><TD CLASS="l"><A NAME="40">108</A></TD><TD>    {</TD></TR><TR><TD CLASS="l">109</TD><TD>      GraphNode from;</TD></TR><TR><TD CLASS="l">110</TD><TD>      GraphNode to;</TD></TR><TR><TD CLASS="l">111</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">112</TD><TD>      Context(GraphNode from, GraphNode to)</TD></TR><TR><TD CLASS="l">113</TD><TD>      {</TD></TR><TR CLASS="c"><TD CLASS="l">114</TD><TD>        this.from = from;</TD></TR><TR CLASS="c"><TD CLASS="l">115</TD><TD>        this.to = to;</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="41">116</A></TD><TD>      }</TD></TR><TR><TD CLASS="l">117</TD><TD> </TD></TR><TR><TD CLASS="l">118</TD><TD>      GraphNode getLastGraphNode()</TD></TR><TR><TD CLASS="l">119</TD><TD>      {</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="67% line coverage (6 out of 9 instructions)">120</TD><TD TITLE="67% line coverage (6 out of 9 instructions)">        return (to != null) ? to : from;</TD></TR><TR><TD CLASS="l"><A NAME="36">121</A></TD><TD>      }</TD></TR><TR><TD CLASS="l">122</TD><TD>    }</TD></TR><TR><TD CLASS="l">123</TD><TD> </TD></TR><TR><TD CLASS="l">124</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">125</TD><TD>    protected GraphGenerator()</TD></TR><TR><TD CLASS="l">126</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">127</TD><TD>      startGraphNode = new GraphNode(getGraphNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">128</TD><TD>      context = new Context(startGraphNode, null);</TD></TR><TR CLASS="c"><TD CLASS="l">129</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="3c">130</A></TD><TD> </TD></TR><TR><TD CLASS="l">131</TD><TD> </TD></TR><TR><TD CLASS="l">132</TD><TD>    protected void generateGraph(CMElementDeclaration ed)</TD></TR><TR><TD CLASS="l">133</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">134</TD><TD>      int contentType = ed.getContentType();</TD></TR><TR><TD CLASS="l">135</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">136</TD><TD>      if (contentType == CMElementDeclaration.MIXED ||</TD></TR><TR CLASS="c"><TD CLASS="l">137</TD><TD>          contentType == CMElementDeclaration.ELEMENT)</TD></TR><TR><TD CLASS="l">138</TD><TD>      {</TD></TR><TR CLASS="c"><TD CLASS="l">139</TD><TD>        visitCMNode(ed.getContent());</TD></TR><TR><TD CLASS="l">140</TD><TD>      }</TD></TR><TR><TD CLASS="l">141</TD><TD>      // CMElementDeclaration.PCDATA... no graph required</TD></TR><TR><TD CLASS="l">142</TD><TD>      // CMElementDeclaration.ANY... no graph required</TD></TR><TR CLASS="c"><TD CLASS="l">143</TD><TD>      context.getLastGraphNode().isTerminal = true;</TD></TR><TR CLASS="c"><TD CLASS="l">144</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="3d">145</A></TD><TD> </TD></TR><TR><TD CLASS="l">146</TD><TD> </TD></TR><TR><TD CLASS="l">147</TD><TD>    protected String getGraphNodeName()</TD></TR><TR><TD CLASS="l">148</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">149</TD><TD>      return &#34;n&#34; + count++; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">150</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="3e">151</A></TD><TD> </TD></TR><TR><TD CLASS="l">152</TD><TD> </TD></TR><TR><TD CLASS="l">153</TD><TD>    protected GraphNode getStartGraphNode()</TD></TR><TR><TD CLASS="l">154</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">155</TD><TD>      return startGraphNode;</TD></TR><TR><TD CLASS="l">156</TD><TD>    }</TD></TR><TR><TD CLASS="l">157</TD><TD> </TD></TR><TR><TD CLASS="l">158</TD><TD> </TD></TR><TR><TD CLASS="l">159</TD><TD>    /**</TD></TR><TR><TD CLASS="l">160</TD><TD>     *                repeat</TD></TR><TR><TD CLASS="l">161</TD><TD>     *             +----#-----+</TD></TR><TR><TD CLASS="l">162</TD><TD>     *             |          |</TD></TR><TR><TD CLASS="l">163</TD><TD>     *             v          |</TD></TR><TR><TD CLASS="l">164</TD><TD>     *  prev --#-&gt; in --'x'-&gt; out --#-&gt; next</TD></TR><TR><TD CLASS="l">165</TD><TD>     *  |                               ^</TD></TR><TR><TD CLASS="l">166</TD><TD>     *  |                               |</TD></TR><TR><TD CLASS="l">167</TD><TD>     *  +----------------#--------------+</TD></TR><TR><TD CLASS="l">168</TD><TD>     *                optional</TD></TR><TR><TD CLASS="l"><A NAME="3b">169</A></TD><TD>     *</TD></TR><TR><TD CLASS="l">170</TD><TD>     */</TD></TR><TR><TD CLASS="l">171</TD><TD>    protected void createArcs(GraphNode in, GraphNode out, CMContent cmContent)</TD></TR><TR><TD CLASS="l">172</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">173</TD><TD>      createArcs(in, out, cmContent, false);</TD></TR><TR CLASS="c"><TD CLASS="l">174</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="39">175</A></TD><TD> </TD></TR><TR><TD CLASS="l">176</TD><TD>    protected void createArcs(GraphNode in, GraphNode out, CMContent cmContent, boolean isAllGroup)</TD></TR><TR><TD CLASS="l">177</TD><TD>    {</TD></TR><TR><TD CLASS="l">178</TD><TD>      //println(&#34;+createArcs() &#34; + ed.getDescription() + &#34; &#34; + ed.getMinOccur());</TD></TR><TR CLASS="c"><TD CLASS="l">179</TD><TD>      GraphNode prev = context.from;</TD></TR><TR CLASS="c"><TD CLASS="l">180</TD><TD>      GraphNode next = new GraphNode(getGraphNodeName());</TD></TR><TR><TD CLASS="l">181</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">182</TD><TD>      prev.addArc(new Arc(Arc.PREV_IN, in, cmContent));</TD></TR><TR CLASS="c"><TD CLASS="l">183</TD><TD>      out.addArc(new Arc(Arc.OUT_NEXT, next, cmContent));</TD></TR><TR><TD CLASS="l">184</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">185</TD><TD>      if (context.to != null)</TD></TR><TR><TD CLASS="l">186</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">187</TD><TD>        next.addArc(new Arc(Arc.LINK, context.to, cmContent));</TD></TR><TR><TD CLASS="l">188</TD><TD>      }</TD></TR><TR><TD CLASS="l">189</TD><TD>      else</TD></TR><TR><TD CLASS="l">190</TD><TD>      {</TD></TR><TR CLASS="c"><TD CLASS="l">191</TD><TD>        context.from = next;</TD></TR><TR><TD CLASS="l">192</TD><TD>      }</TD></TR><TR><TD CLASS="l">193</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">194</TD><TD>      if (cmContent.getMinOccur() == 0)</TD></TR><TR><TD CLASS="l">195</TD><TD>      {</TD></TR><TR><TD CLASS="l">196</TD><TD>        // todo... should we see if an optional arc has already been added?</TD></TR><TR CLASS="c"><TD CLASS="l">197</TD><TD>        prev.addArc(new Arc(Arc.OPTIONAL, next, cmContent));</TD></TR><TR><TD CLASS="l">198</TD><TD>      }</TD></TR><TR><TD CLASS="l">199</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">200</TD><TD>      if (cmContent.getMaxOccur() == -1 || cmContent.getMaxOccur() &gt; 1 || isAllGroup)</TD></TR><TR><TD CLASS="l">201</TD><TD>      {</TD></TR><TR CLASS="c"><TD CLASS="l">202</TD><TD>        out.addArc(new Arc(Arc.REPEAT, in, cmContent));</TD></TR><TR><TD CLASS="l">203</TD><TD>      }</TD></TR><TR CLASS="c"><TD CLASS="l">204</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="38">205</A></TD><TD> </TD></TR><TR><TD CLASS="l">206</TD><TD> </TD></TR><TR><TD CLASS="l">207</TD><TD>    public void visitCMGroup(CMGroup group)</TD></TR><TR><TD CLASS="l">208</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">209</TD><TD>      Context prevContext = context;</TD></TR><TR CLASS="c"><TD CLASS="l">210</TD><TD>      GraphNode in = new GraphNode(&#34;(&#34; + getGraphNodeName()); //$NON-NLS-1$</TD></TR><TR CLASS="c"><TD CLASS="l">211</TD><TD>      GraphNode out = new GraphNode(&#34;)&#34; + getGraphNodeName()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">212</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">213</TD><TD>      int groupOperator = group.getOperator();</TD></TR><TR CLASS="c"><TD CLASS="l">214</TD><TD>      if (groupOperator == CMGroup.SEQUENCE)</TD></TR><TR><TD CLASS="l">215</TD><TD>      {</TD></TR><TR CLASS="c"><TD CLASS="l">216</TD><TD>        context = new Context(in, null);</TD></TR><TR CLASS="c"><TD CLASS="l">217</TD><TD>        super.visitCMGroup(group);</TD></TR><TR CLASS="c"><TD CLASS="l">218</TD><TD>        context.from.addArc(new Arc(Arc.LINK, out, group));</TD></TR><TR><TD CLASS="l">219</TD><TD>      }</TD></TR><TR CLASS="z"><TD CLASS="l">220</TD><TD>      else if (groupOperator == CMGroup.CHOICE ||</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD>               groupOperator == CMGroup.ALL)</TD></TR><TR><TD CLASS="l">222</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">223</TD><TD>        context = new Context(in, out);</TD></TR><TR CLASS="z"><TD CLASS="l">224</TD><TD>        super.visitCMGroup(group);</TD></TR><TR><TD CLASS="l">225</TD><TD>      }</TD></TR><TR><TD CLASS="l">226</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">227</TD><TD>      context = prevContext;</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="87% line coverage (13 out of 15 instructions)">228</TD><TD TITLE="87% line coverage (13 out of 15 instructions)">      createArcs(in, out, group, groupOperator == CMGroup.ALL);</TD></TR><TR CLASS="c"><TD CLASS="l">229</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="3f">230</A></TD><TD> </TD></TR><TR><TD CLASS="l">231</TD><TD> </TD></TR><TR><TD CLASS="l">232</TD><TD>    public void visitCMElementDeclaration(CMElementDeclaration ed)</TD></TR><TR><TD CLASS="l">233</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">234</TD><TD>      GraphNode in = new GraphNode(getGraphNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">235</TD><TD>      GraphNode out = new GraphNode(getGraphNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">236</TD><TD>      createArcs(in, out, ed);</TD></TR><TR CLASS="c"><TD CLASS="l">237</TD><TD>      in.addArc(new Arc(Arc.ELEMENT, ed.getElementName(), out, ed));</TD></TR><TR CLASS="c"><TD CLASS="l">238</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="37">239</A></TD><TD>                            </TD></TR><TR><TD CLASS="l">240</TD><TD> </TD></TR><TR><TD CLASS="l">241</TD><TD>    public void visitCMAnyElement(CMAnyElement anyElement)</TD></TR><TR><TD CLASS="l">242</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">243</TD><TD>      GraphNode in = new GraphNode(getGraphNodeName());</TD></TR><TR CLASS="z"><TD CLASS="l">244</TD><TD>      GraphNode out = new GraphNode(getGraphNodeName());</TD></TR><TR CLASS="z"><TD CLASS="l">245</TD><TD>      createArcs(in, out, anyElement);</TD></TR><TR CLASS="z"><TD CLASS="l">246</TD><TD>      in.addArc(new Arc(Arc.ELEMENT, &#34;any&#34;, out, anyElement)); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">247</TD><TD>    }</TD></TR><TR><TD CLASS="l">248</TD><TD>  }</TD></TR><TR><TD CLASS="l">249</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="23">250</A></TD><TD>  // todo.. implement cache strategy hook, handle name spaces, locals etc.</TD></TR><TR><TD CLASS="l">251</TD><TD>  //</TD></TR><TR><TD CLASS="l">252</TD><TD>  public GraphNode lookupOrCreateGraph(CMElementDeclaration element)</TD></TR><TR><TD CLASS="l">253</TD><TD>  {</TD></TR><TR CLASS="c"><TD CLASS="l">254</TD><TD>    Object key = element;</TD></TR><TR CLASS="c"><TD CLASS="l">255</TD><TD>    GraphNode node = (GraphNode)graphNodeTable.get(key);</TD></TR><TR CLASS="c"><TD CLASS="l">256</TD><TD>    if (node == null)</TD></TR><TR><TD CLASS="l">257</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">258</TD><TD>      node = createGraph(element);</TD></TR><TR CLASS="c"><TD CLASS="l">259</TD><TD>      graphNodeTable.put(key, node);</TD></TR><TR><TD CLASS="l">260</TD><TD>    }</TD></TR><TR CLASS="c"><TD CLASS="l">261</TD><TD>    return node;</TD></TR><TR><TD CLASS="l"><A NAME="22">262</A></TD><TD>  }</TD></TR><TR><TD CLASS="l">263</TD><TD> </TD></TR><TR><TD CLASS="l">264</TD><TD>  public GraphNode createGraph(CMElementDeclaration element)</TD></TR><TR><TD CLASS="l">265</TD><TD>  {</TD></TR><TR CLASS="c"><TD CLASS="l">266</TD><TD>    GraphGenerator generator = new GraphGenerator();</TD></TR><TR CLASS="c"><TD CLASS="l">267</TD><TD>    generator.generateGraph(element);</TD></TR><TR CLASS="c"><TD CLASS="l">268</TD><TD>    return generator.getStartGraphNode();</TD></TR><TR><TD CLASS="l">269</TD><TD>  }</TD></TR><TR><TD CLASS="l">270</TD><TD> </TD></TR><TR><TD CLASS="l">271</TD><TD> </TD></TR><TR><TD CLASS="l">272</TD><TD>  public void printGraph(GraphNode node, Vector namedArcList, Vector unamedArcList, int indent)</TD></TR><TR><TD CLASS="l"><A NAME="1c">273</A></TD><TD>  {</TD></TR><TR><TD CLASS="l">274</TD><TD>    //String decoration = node.isTerminal ? &#34; *&#34; : &#34;&#34;;</TD></TR><TR><TD CLASS="l">275</TD><TD>    //printlnIndented(indent, &#34;GraphNode:&#34; + node.name + decoration);</TD></TR><TR><TD CLASS="l">276</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">277</TD><TD>    indent += 2;</TD></TR><TR CLASS="z"><TD CLASS="l">278</TD><TD>    for (Enumeration e = node.arcList.elements() ; e.hasMoreElements() ;)</TD></TR><TR><TD CLASS="l">279</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">280</TD><TD>      Arc arc = (Arc)e.nextElement();</TD></TR><TR><TD CLASS="l">281</TD><TD>      //boolean visit = false;</TD></TR><TR><TD CLASS="l">282</TD><TD>      //printlnIndented(indent, &#34;Arc:&#34; + arc.name + &#34; (&#34; + arc.kind + &#34;)&#34;); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$</TD></TR><TR CLASS="z"><TD CLASS="l">283</TD><TD>      if (arc.kind == Arc.ELEMENT)</TD></TR><TR><TD CLASS="l">284</TD><TD>      {</TD></TR><TR><TD CLASS="l">285</TD><TD>        //table.add(currentGrammarObject, arc.grammarObject);</TD></TR><TR CLASS="z"><TD CLASS="l">286</TD><TD>        if (!namedArcList.contains(arc))</TD></TR><TR><TD CLASS="l">287</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">288</TD><TD>          namedArcList.add(arc);</TD></TR><TR CLASS="z"><TD CLASS="l">289</TD><TD>          unamedArcList = new Vector();</TD></TR><TR CLASS="z"><TD CLASS="l">290</TD><TD>          printGraph(arc.node, namedArcList, unamedArcList, indent + 2);</TD></TR><TR><TD CLASS="l">291</TD><TD>        }</TD></TR><TR><TD CLASS="l">292</TD><TD>      }</TD></TR><TR><TD CLASS="l">293</TD><TD>      else</TD></TR><TR><TD CLASS="l">294</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">295</TD><TD>        if (!unamedArcList.contains(arc))</TD></TR><TR><TD CLASS="l">296</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">297</TD><TD>          unamedArcList.add(arc);</TD></TR><TR CLASS="z"><TD CLASS="l">298</TD><TD>          printGraph(arc.node, namedArcList, unamedArcList, indent + 2);</TD></TR><TR><TD CLASS="l">299</TD><TD>        }</TD></TR><TR><TD CLASS="l">300</TD><TD>      }</TD></TR><TR><TD CLASS="l">301</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1b">302</A></TD><TD>  }</TD></TR><TR><TD CLASS="l">303</TD><TD> </TD></TR><TR><TD CLASS="l">304</TD><TD>  public void printGraph(GraphNode node)</TD></TR><TR><TD CLASS="l">305</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">306</TD><TD>    printGraph(node, new Vector(), new Vector(), 0);</TD></TR><TR CLASS="z"><TD CLASS="l">307</TD><TD>  }</TD></TR><TR><TD CLASS="l">308</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="24">309</A></TD><TD> </TD></TR><TR><TD CLASS="l">310</TD><TD>  public void validateElementList(ElementList list, GraphNode node, ElementContentComparator comparator, Result result, boolean loopFlag)</TD></TR><TR><TD CLASS="l">311</TD><TD>  {</TD></TR><TR><TD CLASS="l">312</TD><TD>    //println(&#34;+validateElementList &#34; + node + &#34; &#34; + list);</TD></TR><TR CLASS="c"><TD CLASS="l">313</TD><TD>    if (list == null &amp;&amp; node.isTerminal)</TD></TR><TR><TD CLASS="l">314</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">315</TD><TD>      result.isValid = true;</TD></TR><TR><TD CLASS="l">316</TD><TD>    }</TD></TR><TR><TD CLASS="l">317</TD><TD>    else</TD></TR><TR><TD CLASS="l">318</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">319</TD><TD>      for (Iterator i = node.arcList.iterator(); i.hasNext();)</TD></TR><TR><TD CLASS="l">320</TD><TD>      {</TD></TR><TR CLASS="c"><TD CLASS="l">321</TD><TD>        Arc arc = (Arc)i.next();</TD></TR><TR CLASS="c"><TD CLASS="l">322</TD><TD>        boolean traverseArc = false;</TD></TR><TR CLASS="c"><TD CLASS="l">323</TD><TD>        if (arc.kind == Arc.ELEMENT)</TD></TR><TR><TD CLASS="l">324</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">325</TD><TD>          if (list != null &amp;&amp; comparator.matches(list.head, arc.cmNode))</TD></TR><TR><TD CLASS="l">326</TD><TD>          {</TD></TR><TR CLASS="c"><TD CLASS="l">327</TD><TD>            loopFlag = false;</TD></TR><TR CLASS="c"><TD CLASS="l">328</TD><TD>            traverseArc = true;</TD></TR><TR CLASS="c"><TD CLASS="l">329</TD><TD>            list = list.tail; // increment our position in the list</TD></TR><TR><TD CLASS="l">330</TD><TD>          }</TD></TR><TR><TD CLASS="l">331</TD><TD>        }</TD></TR><TR CLASS="c"><TD CLASS="l">332</TD><TD>        else if (arc.kind == Arc.REPEAT)</TD></TR><TR><TD CLASS="l">333</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">334</TD><TD>          if (!loopFlag)</TD></TR><TR><TD CLASS="l">335</TD><TD>          {</TD></TR><TR CLASS="c"><TD CLASS="l">336</TD><TD>            traverseArc = true;</TD></TR><TR><TD CLASS="l">337</TD><TD>          }</TD></TR><TR CLASS="c"><TD CLASS="l">338</TD><TD>          loopFlag = true;</TD></TR><TR><TD CLASS="l">339</TD><TD>        }</TD></TR><TR><TD CLASS="l">340</TD><TD>        else</TD></TR><TR><TD CLASS="l">341</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">342</TD><TD>          traverseArc = true;</TD></TR><TR><TD CLASS="l">343</TD><TD>        }</TD></TR><TR><TD CLASS="l">344</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">345</TD><TD>        if (traverseArc)</TD></TR><TR><TD CLASS="l">346</TD><TD>        {</TD></TR><TR><TD CLASS="l">347</TD><TD>          // test to see if we can push this arc due to facet constraints</TD></TR><TR><TD CLASS="l">348</TD><TD>          //</TD></TR><TR CLASS="c"><TD CLASS="l">349</TD><TD>          if (result.canPush(arc))</TD></TR><TR><TD CLASS="l">350</TD><TD>          {          </TD></TR><TR><TD CLASS="l">351</TD><TD>            // see if this arc leads to a correct solution          </TD></TR><TR CLASS="c"><TD CLASS="l">352</TD><TD>            result.push(arc);</TD></TR><TR CLASS="c"><TD CLASS="l">353</TD><TD>            validateElementList(list, arc.node, comparator, result, loopFlag);</TD></TR><TR CLASS="c"><TD CLASS="l">354</TD><TD>            if (result.isValid)</TD></TR><TR><TD CLASS="l">355</TD><TD>            {</TD></TR><TR CLASS="c"><TD CLASS="l">356</TD><TD>              break;</TD></TR><TR><TD CLASS="l">357</TD><TD>            }</TD></TR><TR CLASS="c"><TD CLASS="l">358</TD><TD>            result.pop(arc);</TD></TR><TR><TD CLASS="l">359</TD><TD>          }</TD></TR><TR><TD CLASS="l">360</TD><TD>        }</TD></TR><TR><TD CLASS="l">361</TD><TD>      }</TD></TR><TR><TD CLASS="l">362</TD><TD>    }</TD></TR><TR CLASS="c"><TD CLASS="l">363</TD><TD>  }</TD></TR><TR><TD CLASS="l">364</TD><TD> </TD></TR><TR><TD CLASS="l">365</TD><TD> </TD></TR><TR><TD CLASS="l">366</TD><TD>  /**</TD></TR><TR><TD CLASS="l"><A NAME="1f">367</A></TD><TD>   *</TD></TR><TR><TD CLASS="l">368</TD><TD>   */</TD></TR><TR><TD CLASS="l">369</TD><TD>  protected static ElementList createElementList(int contentType, List v, ElementContentComparator comparator, Result result)</TD></TR><TR><TD CLASS="l">370</TD><TD>  {</TD></TR><TR CLASS="c"><TD CLASS="l">371</TD><TD>    ElementList first = null;</TD></TR><TR CLASS="c"><TD CLASS="l">372</TD><TD>    ElementList prev = null;</TD></TR><TR><TD CLASS="l">373</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">374</TD><TD>    int size = v.size();</TD></TR><TR CLASS="c"><TD CLASS="l">375</TD><TD>    for (int i = 0; i &lt; size; i++)</TD></TR><TR><TD CLASS="l">376</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">377</TD><TD>      Object o = v.get(i);</TD></TR><TR CLASS="c"><TD CLASS="l">378</TD><TD>      if (o != null &amp;&amp; !comparator.isIgnorable(o))</TD></TR><TR><TD CLASS="l">379</TD><TD>      {</TD></TR><TR CLASS="c"><TD CLASS="l">380</TD><TD>        if (comparator.isElement(o))</TD></TR><TR><TD CLASS="l">381</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">382</TD><TD>          ElementList list = new ElementList();</TD></TR><TR CLASS="c"><TD CLASS="l">383</TD><TD>          list.head = o;</TD></TR><TR><TD CLASS="l">384</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">385</TD><TD>          if (prev != null)</TD></TR><TR><TD CLASS="l">386</TD><TD>          {</TD></TR><TR CLASS="c"><TD CLASS="l">387</TD><TD>            prev.tail = list;</TD></TR><TR><TD CLASS="l">388</TD><TD>          }</TD></TR><TR><TD CLASS="l">389</TD><TD>          else</TD></TR><TR><TD CLASS="l">390</TD><TD>          {</TD></TR><TR CLASS="c"><TD CLASS="l">391</TD><TD>            first = list;</TD></TR><TR><TD CLASS="l">392</TD><TD>          }</TD></TR><TR CLASS="c"><TD CLASS="l">393</TD><TD>          prev = list;</TD></TR><TR><TD CLASS="l">394</TD><TD>        }</TD></TR><TR CLASS="z"><TD CLASS="l">395</TD><TD>        else if (contentType == CMElementDeclaration.ELEMENT)</TD></TR><TR><TD CLASS="l">396</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">397</TD><TD>          result.isValid = false;</TD></TR><TR CLASS="z"><TD CLASS="l">398</TD><TD>          result.errorIndex = i;</TD></TR><TR CLASS="z"><TD CLASS="l">399</TD><TD>          result.errorMessage = &#34;Element can not include PCDATA content&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">400</TD><TD>        }</TD></TR><TR><TD CLASS="l">401</TD><TD>      }</TD></TR><TR><TD CLASS="l">402</TD><TD>    }</TD></TR><TR CLASS="c"><TD CLASS="l">403</TD><TD>    return first;</TD></TR><TR><TD CLASS="l">404</TD><TD>  }</TD></TR><TR><TD CLASS="l">405</TD><TD> </TD></TR><TR><TD CLASS="l">406</TD><TD>  /**</TD></TR><TR><TD CLASS="l"><A NAME="1e">407</A></TD><TD>   *</TD></TR><TR><TD CLASS="l">408</TD><TD>   */</TD></TR><TR><TD CLASS="l">409</TD><TD>  public void validate(CMElementDeclaration ed, List elementContent, ElementContentComparator comparator, Result result)</TD></TR><TR><TD CLASS="l">410</TD><TD>  {</TD></TR><TR CLASS="c"><TD CLASS="l">411</TD><TD>    int contentType = ed.getContentType();</TD></TR><TR><TD CLASS="l">412</TD><TD> </TD></TR><TR CLASS="c"><TD CLASS="l">413</TD><TD>    if (contentType == CMElementDeclaration.MIXED ||</TD></TR><TR CLASS="c"><TD CLASS="l">414</TD><TD>        contentType == CMElementDeclaration.ELEMENT)</TD></TR><TR><TD CLASS="l">415</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">416</TD><TD>      ElementList elementList = createElementList(contentType, elementContent, comparator, result);</TD></TR><TR CLASS="c"><TD CLASS="l">417</TD><TD>      if (result.isValid == true)</TD></TR><TR><TD CLASS="l">418</TD><TD>      {  </TD></TR><TR><TD CLASS="l">419</TD><TD>        // defect 226213 ... elements with a large number of children will cause the recursion based validation</TD></TR><TR><TD CLASS="l">420</TD><TD>        // algorithm to stack overflow ... as a quick fix assume any element with a large number of children is valid        </TD></TR><TR CLASS="c"><TD CLASS="l">421</TD><TD>        if (elementContent.size() &lt; 500)</TD></TR><TR><TD CLASS="l">422</TD><TD>        {</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="69% line coverage (11 out of 16 instructions)">423</TD><TD TITLE="69% line coverage (11 out of 16 instructions)">          boolean isGraphValidationNeeded = !(elementList == null &amp;&amp; contentType == CMElementDeclaration.MIXED);</TD></TR><TR><TD CLASS="l">424</TD><TD>                      </TD></TR><TR><TD CLASS="l">425</TD><TD>          // exlicity handle 'All' groups</TD></TR><TR><TD CLASS="l">426</TD><TD>          //</TD></TR><TR CLASS="c"><TD CLASS="l">427</TD><TD>          CMContent content = ed.getContent();</TD></TR><TR CLASS="c"><TD CLASS="l">428</TD><TD>          if (content.getNodeType() == CMNode.GROUP)</TD></TR><TR><TD CLASS="l">429</TD><TD>          {</TD></TR><TR CLASS="c"><TD CLASS="l">430</TD><TD>            CMGroup group = (CMGroup)content;</TD></TR><TR CLASS="c"><TD CLASS="l">431</TD><TD>            if (group.getOperator() == CMGroup.ALL)</TD></TR><TR><TD CLASS="l">432</TD><TD>            {</TD></TR><TR CLASS="z"><TD CLASS="l">433</TD><TD>              isGraphValidationNeeded = false;</TD></TR><TR CLASS="z"><TD CLASS="l">434</TD><TD>              validatAllGroupContent(elementContent, comparator, group, result);                               </TD></TR><TR><TD CLASS="l">435</TD><TD>            }              </TD></TR><TR><TD CLASS="l">436</TD><TD>          }  </TD></TR><TR><TD CLASS="l">437</TD><TD>          </TD></TR><TR CLASS="c"><TD CLASS="l">438</TD><TD>          if (isGraphValidationNeeded)</TD></TR><TR><TD CLASS="l">439</TD><TD>          {</TD></TR><TR><TD CLASS="l">440</TD><TD>            // validate the elementList using a graph</TD></TR><TR><TD CLASS="l">441</TD><TD>            //</TD></TR><TR CLASS="c"><TD CLASS="l">442</TD><TD>            result.isValid = false;</TD></TR><TR CLASS="c"><TD CLASS="l">443</TD><TD>            GraphNode node = lookupOrCreateGraph(ed);</TD></TR><TR CLASS="c"><TD CLASS="l">444</TD><TD>            validateElementList(elementList, node, comparator, result, false);</TD></TR><TR><TD CLASS="l">445</TD><TD>          }</TD></TR><TR><TD CLASS="l">446</TD><TD>        }</TD></TR><TR><TD CLASS="l">447</TD><TD>      }</TD></TR><TR><TD CLASS="l">448</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">449</TD><TD>    else if (contentType == CMElementDeclaration.PCDATA)</TD></TR><TR><TD CLASS="l">450</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">451</TD><TD>      int size = elementContent.size();</TD></TR><TR CLASS="z"><TD CLASS="l">452</TD><TD>      for (int i = 0; i &lt; size; i++)</TD></TR><TR><TD CLASS="l">453</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">454</TD><TD>        Object o = elementContent.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">455</TD><TD>        if (comparator.isElement(o))</TD></TR><TR><TD CLASS="l">456</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">457</TD><TD>          result.isValid = false;</TD></TR><TR CLASS="z"><TD CLASS="l">458</TD><TD>          result.errorIndex = i;</TD></TR><TR CLASS="z"><TD CLASS="l">459</TD><TD>          result.errorMessage = &#34;Element may only include PCDATA content&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">460</TD><TD>          break;</TD></TR><TR><TD CLASS="l">461</TD><TD>        }</TD></TR><TR><TD CLASS="l">462</TD><TD>      }</TD></TR><TR><TD CLASS="l">463</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">464</TD><TD>    else if (contentType == CMElementDeclaration.EMPTY)</TD></TR><TR><TD CLASS="l">465</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">466</TD><TD>      int size = elementContent.size();</TD></TR><TR CLASS="z"><TD CLASS="l">467</TD><TD>      for (int i = 0; i &lt; size; i++)</TD></TR><TR><TD CLASS="l">468</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">469</TD><TD>        Object o = elementContent.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">470</TD><TD>        if (!comparator.isIgnorable(o))</TD></TR><TR><TD CLASS="l">471</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">472</TD><TD>          result.isValid = false;</TD></TR><TR CLASS="z"><TD CLASS="l">473</TD><TD>          result.errorIndex = i;</TD></TR><TR CLASS="z"><TD CLASS="l">474</TD><TD>          result.errorMessage = &#34;Element may not contain PCDATA or Element content&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">475</TD><TD>          break;</TD></TR><TR><TD CLASS="l">476</TD><TD>        }</TD></TR><TR><TD CLASS="l">477</TD><TD>      }</TD></TR><TR><TD CLASS="l">478</TD><TD>    }</TD></TR><TR><TD CLASS="l">479</TD><TD>    //else if (contentType == CMElementDeclaration.ANY)</TD></TR><TR><TD CLASS="l">480</TD><TD>    // {</TD></TR><TR><TD CLASS="l"><A NAME="50">481</A></TD><TD>    //   assume elementContent will always be valid for this content type</TD></TR><TR><TD CLASS="l">482</TD><TD>    // }</TD></TR><TR CLASS="c"><TD CLASS="l">483</TD><TD>  }</TD></TR><TR><TD CLASS="l">484</TD><TD>    </TD></TR><TR CLASS="c"><TD CLASS="l">485</TD><TD>  static class ItemCount</TD></TR><TR><TD CLASS="l">486</TD><TD>  {</TD></TR><TR CLASS="c"><TD CLASS="l">487</TD><TD>    int count = 0;    </TD></TR><TR><TD CLASS="l"><A NAME="1d">488</A></TD><TD>  }</TD></TR><TR><TD CLASS="l">489</TD><TD>  </TD></TR><TR><TD CLASS="l">490</TD><TD>  private void validatAllGroupContent(List elementContent, ElementContentComparator comparator, CMGroup allGroup, Result result) </TD></TR><TR><TD CLASS="l">491</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">492</TD><TD>    boolean isValid = true;</TD></TR><TR CLASS="z"><TD CLASS="l">493</TD><TD>    boolean isPartiallyValid = true;</TD></TR><TR CLASS="z"><TD CLASS="l">494</TD><TD>    HashMap map = new HashMap();</TD></TR><TR CLASS="z"><TD CLASS="l">495</TD><TD>    CMNodeList list = allGroup.getChildNodes();</TD></TR><TR CLASS="z"><TD CLASS="l">496</TD><TD>    for (int j = list.getLength() - 1; j &gt;= 0; j--)</TD></TR><TR><TD CLASS="l">497</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">498</TD><TD>      CMNode node = list.item(j);      </TD></TR><TR CLASS="z"><TD CLASS="l">499</TD><TD>      if (map.get(node) == null)</TD></TR><TR><TD CLASS="l">500</TD><TD>      {  </TD></TR><TR CLASS="z"><TD CLASS="l">501</TD><TD>        map.put(node, new ItemCount());</TD></TR><TR><TD CLASS="l">502</TD><TD>      }  </TD></TR><TR><TD CLASS="l">503</TD><TD>    }    </TD></TR><TR CLASS="z"><TD CLASS="l">504</TD><TD>    int validitionCount = 0;</TD></TR><TR CLASS="z"><TD CLASS="l">505</TD><TD>    for (Iterator i = elementContent.iterator(); i.hasNext(); validitionCount++)</TD></TR><TR><TD CLASS="l">506</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">507</TD><TD>      Object o = i.next();        </TD></TR><TR CLASS="z"><TD CLASS="l">508</TD><TD>      if (comparator.isElement(o))</TD></TR><TR><TD CLASS="l">509</TD><TD>      {              </TD></TR><TR><TD CLASS="l">510</TD><TD>        // test to see if the element is listed in the all group</TD></TR><TR><TD CLASS="l">511</TD><TD>        //</TD></TR><TR CLASS="z"><TD CLASS="l">512</TD><TD>        CMNode matchingCMNode = null;</TD></TR><TR CLASS="z"><TD CLASS="l">513</TD><TD>        for (int j = list.getLength() - 1; j &gt;= 0; j--)</TD></TR><TR><TD CLASS="l">514</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">515</TD><TD>          CMNode node = list.item(j);</TD></TR><TR CLASS="z"><TD CLASS="l">516</TD><TD>          if (comparator.matches(o, node))</TD></TR><TR><TD CLASS="l">517</TD><TD>          {</TD></TR><TR CLASS="z"><TD CLASS="l">518</TD><TD>            matchingCMNode = node;</TD></TR><TR CLASS="z"><TD CLASS="l">519</TD><TD>            break;</TD></TR><TR><TD CLASS="l">520</TD><TD>          }             </TD></TR><TR><TD CLASS="l">521</TD><TD>        }                              </TD></TR><TR CLASS="z"><TD CLASS="l">522</TD><TD>        if (matchingCMNode == null)</TD></TR><TR><TD CLASS="l">523</TD><TD>        {     </TD></TR><TR CLASS="z"><TD CLASS="l">524</TD><TD>          isPartiallyValid = false;</TD></TR><TR CLASS="z"><TD CLASS="l">525</TD><TD>          isValid = false;</TD></TR><TR CLASS="z"><TD CLASS="l">526</TD><TD>          break;</TD></TR><TR><TD CLASS="l">527</TD><TD>        }</TD></TR><TR><TD CLASS="l">528</TD><TD>        else</TD></TR><TR><TD CLASS="l">529</TD><TD>        {  </TD></TR><TR><TD CLASS="l">530</TD><TD>          // test to see that the element occurs only once</TD></TR><TR><TD CLASS="l">531</TD><TD>          //</TD></TR><TR CLASS="z"><TD CLASS="l">532</TD><TD>          ItemCount itemCount = (ItemCount)map.get(matchingCMNode);</TD></TR><TR CLASS="z"><TD CLASS="l">533</TD><TD>          if (itemCount != null)</TD></TR><TR><TD CLASS="l">534</TD><TD>          {  </TD></TR><TR CLASS="z"><TD CLASS="l">535</TD><TD>            if (itemCount.count &gt; 0)</TD></TR><TR><TD CLASS="l">536</TD><TD>            {</TD></TR><TR><TD CLASS="l">537</TD><TD>              // we don't want to allow too many elements!</TD></TR><TR><TD CLASS="l">538</TD><TD>              // we consider 'not enough' to be partially valid... but not 'too many'</TD></TR><TR CLASS="z"><TD CLASS="l">539</TD><TD>              isPartiallyValid = false;</TD></TR><TR CLASS="z"><TD CLASS="l">540</TD><TD>              break;</TD></TR><TR><TD CLASS="l">541</TD><TD>            }  </TD></TR><TR><TD CLASS="l">542</TD><TD>            else</TD></TR><TR><TD CLASS="l">543</TD><TD>            {</TD></TR><TR CLASS="z"><TD CLASS="l">544</TD><TD>              itemCount.count++;</TD></TR><TR><TD CLASS="l">545</TD><TD>            }  </TD></TR><TR><TD CLASS="l">546</TD><TD>          }</TD></TR><TR><TD CLASS="l">547</TD><TD>        }  </TD></TR><TR><TD CLASS="l">548</TD><TD>      }  </TD></TR><TR><TD CLASS="l">549</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">550</TD><TD>    if (isValid)</TD></TR><TR><TD CLASS="l">551</TD><TD>    {  </TD></TR><TR CLASS="z"><TD CLASS="l">552</TD><TD>      for (int j = list.getLength() - 1; j &gt;= 0; j--)</TD></TR><TR><TD CLASS="l">553</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">554</TD><TD>        CMNode node = list.item(j);      </TD></TR><TR CLASS="z"><TD CLASS="l">555</TD><TD>        if (node.getNodeType() == CMNode.ELEMENT_DECLARATION)</TD></TR><TR><TD CLASS="l">556</TD><TD>        {  </TD></TR><TR CLASS="z"><TD CLASS="l">557</TD><TD>          CMContent content = (CMContent)node;</TD></TR><TR CLASS="z"><TD CLASS="l">558</TD><TD>          ItemCount itemCount = (ItemCount)map.get(node);</TD></TR><TR><TD CLASS="l">559</TD><TD>//          System.out.print(&#34;content &#34; + content.getNodeName() + &#34; &#34; + content.getMinOccur());</TD></TR><TR CLASS="z"><TD CLASS="l">560</TD><TD>          if (itemCount.count &lt; content.getMinOccur())</TD></TR><TR><TD CLASS="l">561</TD><TD>          {  </TD></TR><TR CLASS="z"><TD CLASS="l">562</TD><TD>            isValid = false;</TD></TR><TR CLASS="z"><TD CLASS="l">563</TD><TD>            break;</TD></TR><TR><TD CLASS="l">564</TD><TD>          }  </TD></TR><TR><TD CLASS="l">565</TD><TD>        }  </TD></TR><TR><TD CLASS="l">566</TD><TD>      }</TD></TR><TR><TD CLASS="l">567</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">568</TD><TD>    if (result instanceof ElementPathRecordingResult &amp;&amp; isPartiallyValid)</TD></TR><TR><TD CLASS="l">569</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">570</TD><TD>      ((ElementPathRecordingResult)result).setPartialValidationCount(validitionCount);</TD></TR><TR><TD CLASS="l">571</TD><TD>    }  </TD></TR><TR CLASS="z"><TD CLASS="l">572</TD><TD>    result.isValid = isValid;</TD></TR><TR CLASS="z"><TD CLASS="l">573</TD><TD>  }  </TD></TR><TR><TD CLASS="l"><A NAME="1a">574</A></TD><TD>  </TD></TR><TR><TD CLASS="l">575</TD><TD>  </TD></TR><TR><TD CLASS="l">576</TD><TD>  public void getOriginArray(CMElementDeclaration ed, List elementContent, ElementContentComparator comparator, ElementPathRecordingResult result)</TD></TR><TR><TD CLASS="l">577</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">578</TD><TD>    CMNode[] cmNodeArray = null;</TD></TR><TR CLASS="z"><TD CLASS="l">579</TD><TD>    validate(ed, elementContent, comparator, result);</TD></TR><TR CLASS="z"><TD CLASS="l">580</TD><TD>    if (result.isValid)</TD></TR><TR><TD CLASS="l">581</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">582</TD><TD>      CMDataType dataType = ed.getDataType();</TD></TR><TR CLASS="z"><TD CLASS="l">583</TD><TD>      int size = elementContent.size();</TD></TR><TR CLASS="z"><TD CLASS="l">584</TD><TD>      cmNodeArray = new CMNode[size];</TD></TR><TR CLASS="z"><TD CLASS="l">585</TD><TD>      Vector originList = result.getElementOriginList();</TD></TR><TR CLASS="z"><TD CLASS="l">586</TD><TD>      int originListSize = originList.size(); </TD></TR><TR CLASS="z"><TD CLASS="l">587</TD><TD>      int originListIndex = 0;</TD></TR><TR CLASS="z"><TD CLASS="l">588</TD><TD>      for (int i = 0; i &lt; size; i++)</TD></TR><TR><TD CLASS="l">589</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">590</TD><TD>        Object o = elementContent.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">591</TD><TD>        if (comparator.isElement(o))</TD></TR><TR><TD CLASS="l">592</TD><TD>        {     </TD></TR><TR CLASS="z"><TD CLASS="l">593</TD><TD>          if (originListIndex &lt; originListSize)</TD></TR><TR><TD CLASS="l">594</TD><TD>          {</TD></TR><TR CLASS="z"><TD CLASS="l">595</TD><TD>            cmNodeArray[i] = (CMNode)originList.get(originListIndex);</TD></TR><TR CLASS="z"><TD CLASS="l">596</TD><TD>            originListIndex++;</TD></TR><TR><TD CLASS="l">597</TD><TD>          }</TD></TR><TR><TD CLASS="l">598</TD><TD>        }</TD></TR><TR CLASS="z"><TD CLASS="l">599</TD><TD>        else if (comparator.isPCData(o))</TD></TR><TR><TD CLASS="l">600</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">601</TD><TD>          cmNodeArray[i] = dataType;</TD></TR><TR><TD CLASS="l">602</TD><TD>        }</TD></TR><TR><TD CLASS="l">603</TD><TD>        // else the CMNode at this index is null</TD></TR><TR><TD CLASS="l">604</TD><TD>      }</TD></TR><TR CLASS="z"><TD CLASS="l">605</TD><TD>      result.setOriginArray(cmNodeArray);</TD></TR><TR><TD CLASS="l">606</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">607</TD><TD>  }</TD></TR><TR><TD CLASS="l"><A NAME="15">608</A></TD><TD>  </TD></TR><TR><TD CLASS="l">609</TD><TD>  private void collectNamedArcs(GraphNode node, List namedArcList, int indent)</TD></TR><TR><TD CLASS="l">610</TD><TD>  {</TD></TR><TR><TD CLASS="l">611</TD><TD>    //printlnIndented(indent, &#34;GraphNode:&#34; + node.name + decoration);</TD></TR><TR CLASS="z"><TD CLASS="l">612</TD><TD>    indent += 2;</TD></TR><TR CLASS="z"><TD CLASS="l">613</TD><TD>    for (Iterator i = node.arcList.iterator(); i.hasNext() ;)</TD></TR><TR><TD CLASS="l">614</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">615</TD><TD>      Arc arc = (Arc)i.next();</TD></TR><TR><TD CLASS="l">616</TD><TD>      //printlnIndented(indent, &#34;Arc:&#34; + arc.name + &#34; (&#34; + arc.kind + &#34;)&#34;); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$</TD></TR><TR CLASS="z"><TD CLASS="l">617</TD><TD>      if (arc.kind == Arc.ELEMENT)</TD></TR><TR><TD CLASS="l">618</TD><TD>      { </TD></TR><TR CLASS="z"><TD CLASS="l">619</TD><TD>        if (!namedArcList.contains(arc))</TD></TR><TR><TD CLASS="l">620</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">621</TD><TD>          namedArcList.add(arc);</TD></TR><TR CLASS="z"><TD CLASS="l">622</TD><TD>          collectNamedArcs(arc.node, namedArcList, indent + 2);</TD></TR><TR><TD CLASS="l">623</TD><TD>        }</TD></TR><TR><TD CLASS="l">624</TD><TD>      }</TD></TR><TR CLASS="z"><TD CLASS="l">625</TD><TD>      else if (arc.kind != Arc.REPEAT &amp;&amp; arc.kind != Arc.OPTIONAL)</TD></TR><TR><TD CLASS="l">626</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">627</TD><TD>        collectNamedArcs(arc.node, namedArcList, indent + 2);</TD></TR><TR><TD CLASS="l">628</TD><TD>      }</TD></TR><TR><TD CLASS="l">629</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">630</TD><TD>  }</TD></TR><TR><TD CLASS="l"><A NAME="18">631</A></TD><TD>  </TD></TR><TR><TD CLASS="l">632</TD><TD>  </TD></TR><TR><TD CLASS="l">633</TD><TD>  private List getMatchingArcs(CMElementDeclaration ed, String elementName)</TD></TR><TR><TD CLASS="l">634</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">635</TD><TD>    List arcList = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">636</TD><TD>    GraphNode graphNode = lookupOrCreateGraph(ed);</TD></TR><TR CLASS="z"><TD CLASS="l">637</TD><TD>    if (elementName == null)</TD></TR><TR><TD CLASS="l">638</TD><TD>    {</TD></TR><TR><TD CLASS="l">639</TD><TD>      // here we add the 'root' arc</TD></TR><TR CLASS="z"><TD CLASS="l">640</TD><TD>      for (Iterator i = graphNode.arcList.iterator(); i.hasNext() ;)</TD></TR><TR><TD CLASS="l">641</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">642</TD><TD>        Arc arc = (Arc)i.next();</TD></TR><TR CLASS="z"><TD CLASS="l">643</TD><TD>        if (arc.kind == Arc.PREV_IN)</TD></TR><TR><TD CLASS="l">644</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">645</TD><TD>          arcList.add(arc);</TD></TR><TR CLASS="z"><TD CLASS="l">646</TD><TD>          break;</TD></TR><TR><TD CLASS="l">647</TD><TD>        }  </TD></TR><TR><TD CLASS="l">648</TD><TD>      }</TD></TR><TR><TD CLASS="l">649</TD><TD>    }</TD></TR><TR><TD CLASS="l">650</TD><TD>    else</TD></TR><TR><TD CLASS="l">651</TD><TD>    { </TD></TR><TR CLASS="z"><TD CLASS="l">652</TD><TD>      List namedArcs = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">653</TD><TD>      collectNamedArcs(graphNode, namedArcs, 0);</TD></TR><TR CLASS="z"><TD CLASS="l">654</TD><TD>      for (Iterator i = namedArcs.iterator(); i.hasNext(); )</TD></TR><TR><TD CLASS="l">655</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">656</TD><TD>        Arc arc = (Arc)i.next();</TD></TR><TR CLASS="z"><TD CLASS="l">657</TD><TD>        if (arc.cmNode != null &amp;&amp; elementName.equals(arc.cmNode.getNodeName()))</TD></TR><TR><TD CLASS="l">658</TD><TD>        {  </TD></TR><TR CLASS="z"><TD CLASS="l">659</TD><TD>          arcList.add(arc);</TD></TR><TR><TD CLASS="l">660</TD><TD>        }  </TD></TR><TR><TD CLASS="l">661</TD><TD>      }  </TD></TR><TR><TD CLASS="l">662</TD><TD>    }      </TD></TR><TR CLASS="z"><TD CLASS="l">663</TD><TD>    return arcList;</TD></TR><TR><TD CLASS="l">664</TD><TD>  }</TD></TR><TR><TD CLASS="l">665</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="16">666</A></TD><TD>  </TD></TR><TR><TD CLASS="l">667</TD><TD>  private void collectNextSiblings(GraphNode node, List nextSiblingList, List namedArcList, List unamedArcList, int indent)</TD></TR><TR><TD CLASS="l">668</TD><TD>  {</TD></TR><TR><TD CLASS="l">669</TD><TD>    //printlnIndented(indent, &#34;GraphNode:&#34; + node.name + decoration);</TD></TR><TR CLASS="z"><TD CLASS="l">670</TD><TD>    indent += 2;</TD></TR><TR CLASS="z"><TD CLASS="l">671</TD><TD>    for (Iterator i = node.arcList.iterator(); i.hasNext(); )</TD></TR><TR><TD CLASS="l">672</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">673</TD><TD>      Arc arc = (Arc)i.next();</TD></TR><TR CLASS="z"><TD CLASS="l">674</TD><TD>      if (arc.kind == Arc.ELEMENT)</TD></TR><TR><TD CLASS="l">675</TD><TD>      {       </TD></TR><TR CLASS="z"><TD CLASS="l">676</TD><TD>        if (!namedArcList.contains(arc))</TD></TR><TR><TD CLASS="l">677</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">678</TD><TD>          if (arc.cmNode != null)</TD></TR><TR><TD CLASS="l">679</TD><TD>          {  </TD></TR><TR CLASS="z"><TD CLASS="l">680</TD><TD>            nextSiblingList.add(arc.cmNode);</TD></TR><TR CLASS="z"><TD CLASS="l">681</TD><TD>            if (arc.cmNode.getNodeType() == CMNode.ELEMENT_DECLARATION ||</TD></TR><TR CLASS="z"><TD CLASS="l">682</TD><TD>                arc.cmNode.getNodeType() == CMNode.ANY_ELEMENT)</TD></TR><TR><TD CLASS="l">683</TD><TD>            {              </TD></TR><TR CLASS="z"><TD CLASS="l">684</TD><TD>              namedArcList.add(arc);</TD></TR><TR CLASS="z"><TD CLASS="l">685</TD><TD>              CMContent cmNode = (CMContent)arc.cmNode; </TD></TR><TR CLASS="z"><TD CLASS="l">686</TD><TD>              if (cmNode.getMinOccur() == 0)</TD></TR><TR><TD CLASS="l">687</TD><TD>              {</TD></TR><TR CLASS="z"><TD CLASS="l">688</TD><TD>                unamedArcList = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">689</TD><TD>                collectNextSiblings(arc.node, nextSiblingList, namedArcList, unamedArcList, indent + 2);</TD></TR><TR><TD CLASS="l">690</TD><TD>              }</TD></TR><TR><TD CLASS="l">691</TD><TD>            }            </TD></TR><TR><TD CLASS="l">692</TD><TD>          }</TD></TR><TR><TD CLASS="l">693</TD><TD>        }</TD></TR><TR><TD CLASS="l">694</TD><TD>      }  </TD></TR><TR><TD CLASS="l">695</TD><TD>      else</TD></TR><TR><TD CLASS="l">696</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">697</TD><TD>        if (!unamedArcList.contains(arc))</TD></TR><TR><TD CLASS="l">698</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">699</TD><TD>          unamedArcList.add(arc);</TD></TR><TR CLASS="z"><TD CLASS="l">700</TD><TD>          collectNextSiblings(arc.node, nextSiblingList, namedArcList, unamedArcList, indent + 2);</TD></TR><TR><TD CLASS="l">701</TD><TD>        }</TD></TR><TR><TD CLASS="l">702</TD><TD>      }</TD></TR><TR><TD CLASS="l">703</TD><TD>    }  </TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="19">704</A></TD><TD>  }</TD></TR><TR><TD CLASS="l">705</TD><TD>    </TD></TR><TR><TD CLASS="l">706</TD><TD>  public CMNode[] getNextSiblings(CMElementDeclaration ed, String elementName)</TD></TR><TR><TD CLASS="l">707</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">708</TD><TD>    List arcList = getMatchingArcs(ed, elementName);</TD></TR><TR CLASS="z"><TD CLASS="l">709</TD><TD>    List nextSiblingList = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">710</TD><TD>    for (Iterator i = arcList.iterator(); i.hasNext(); )</TD></TR><TR><TD CLASS="l">711</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">712</TD><TD>      Arc arc = (Arc)i.next();</TD></TR><TR CLASS="z"><TD CLASS="l">713</TD><TD>      collectNextSiblings(arc.node, nextSiblingList, new ArrayList(), new ArrayList(), 0);      </TD></TR><TR><TD CLASS="l">714</TD><TD>    }  </TD></TR><TR CLASS="z"><TD CLASS="l">715</TD><TD>    CMNode[] result = new CMNode[nextSiblingList.size()];</TD></TR><TR CLASS="z"><TD CLASS="l">716</TD><TD>    nextSiblingList.toArray(result);    </TD></TR><TR><TD CLASS="l">717</TD><TD>    //System.out.print(&#34;getNextSibling(&#34; +elementName + &#34;)&#34;);</TD></TR><TR><TD CLASS="l">718</TD><TD>    //for (int i = 0; i &lt; result.length; i++)</TD></TR><TR><TD CLASS="l">719</TD><TD>    //{</TD></TR><TR><TD CLASS="l">720</TD><TD>    //  System.out.print(&#34;[&#34; + result[i].getNodeName() + &#34;]&#34;);</TD></TR><TR><TD CLASS="l">721</TD><TD>    //}  </TD></TR><TR><TD CLASS="l">722</TD><TD>    //System.out.println();</TD></TR><TR CLASS="z"><TD CLASS="l">723</TD><TD>    return result;</TD></TR><TR><TD CLASS="l">724</TD><TD>  }</TD></TR><TR><TD CLASS="l"><A NAME="30">725</A></TD><TD> </TD></TR><TR><TD CLASS="l">726</TD><TD>  /**</TD></TR><TR><TD CLASS="l">727</TD><TD>   *</TD></TR><TR><TD CLASS="l">728</TD><TD>   */</TD></TR><TR CLASS="c"><TD CLASS="l">729</TD><TD>  public static class Result</TD></TR><TR><TD CLASS="l">730</TD><TD>  {</TD></TR><TR CLASS="c"><TD CLASS="l">731</TD><TD>    public boolean isValid = true;</TD></TR><TR CLASS="c"><TD CLASS="l">732</TD><TD>    public int errorIndex = -1;</TD></TR><TR><TD CLASS="l">733</TD><TD>    public String errorMessage;</TD></TR><TR><TD CLASS="l"><A NAME="31">734</A></TD><TD>    public boolean isRepeatTraversed; // detects if a repeat has been traversed</TD></TR><TR><TD CLASS="l">735</TD><TD> </TD></TR><TR><TD CLASS="l">736</TD><TD>    public boolean canPush(Arc arc)</TD></TR><TR><TD CLASS="l">737</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">738</TD><TD>      return true;</TD></TR><TR><TD CLASS="l">739</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="34">740</A></TD><TD>    </TD></TR><TR><TD CLASS="l">741</TD><TD>    public void push(Arc arc)</TD></TR><TR><TD CLASS="l">742</TD><TD>    {</TD></TR><TR><TD CLASS="l">743</TD><TD>      // overide this method to record traversed nodes</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="33">744</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">745</TD><TD>    public void pop(Arc arc)</TD></TR><TR><TD CLASS="l">746</TD><TD>    {</TD></TR><TR><TD CLASS="l"><A NAME="32">747</A></TD><TD>      // overide this method to record traversed nodes</TD></TR><TR CLASS="z"><TD CLASS="l">748</TD><TD>    }</TD></TR><TR><TD CLASS="l">749</TD><TD>    public CMNode[] getOriginArray()</TD></TR><TR><TD CLASS="l">750</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">751</TD><TD>      return null;</TD></TR><TR><TD CLASS="l">752</TD><TD>    }</TD></TR><TR><TD CLASS="l">753</TD><TD>  }</TD></TR><TR><TD CLASS="l"><A NAME="43">754</A></TD><TD> </TD></TR><TR><TD CLASS="l">755</TD><TD>  /**</TD></TR><TR><TD CLASS="l">756</TD><TD>   *</TD></TR><TR><TD CLASS="l">757</TD><TD>   */</TD></TR><TR CLASS="c"><TD CLASS="l">758</TD><TD>  public static class ElementPathRecordingResult extends Result</TD></TR><TR><TD CLASS="l">759</TD><TD>  {  </TD></TR><TR CLASS="c"><TD CLASS="l">760</TD><TD>    protected List activeItemCountList = new ArrayList();</TD></TR><TR CLASS="c"><TD CLASS="l">761</TD><TD>    protected List inactiveItemCountList = new ArrayList();    </TD></TR><TR CLASS="c"><TD CLASS="l">762</TD><TD>    protected Vector elementOriginStack = new Vector();</TD></TR><TR CLASS="c"><TD CLASS="l">763</TD><TD>    protected CMNode[] originArray = null;</TD></TR><TR CLASS="c"><TD CLASS="l">764</TD><TD>    protected int partialValidationCount = 0;</TD></TR><TR><TD CLASS="l">765</TD><TD> </TD></TR><TR><TD CLASS="l">766</TD><TD>    </TD></TR><TR><TD CLASS="l"><A NAME="48">767</A></TD><TD>    // this method is used to support facet counts</TD></TR><TR><TD CLASS="l">768</TD><TD>    //</TD></TR><TR><TD CLASS="l">769</TD><TD>    public boolean canPush(Arc arc)</TD></TR><TR><TD CLASS="l">770</TD><TD>    {     </TD></TR><TR CLASS="c"><TD CLASS="l">771</TD><TD>      boolean result = true;        </TD></TR><TR><TD CLASS="l">772</TD><TD>      try</TD></TR><TR><TD CLASS="l">773</TD><TD>      {        </TD></TR><TR CLASS="c"><TD CLASS="l">774</TD><TD>        if (arc.kind == Arc.REPEAT)</TD></TR><TR><TD CLASS="l">775</TD><TD>        {          </TD></TR><TR CLASS="c"><TD CLASS="l">776</TD><TD>          if (arc.cmNode instanceof CMContent)</TD></TR><TR><TD CLASS="l">777</TD><TD>          {</TD></TR><TR CLASS="c"><TD CLASS="l">778</TD><TD>            CMContent content = (CMContent)arc.cmNode;</TD></TR><TR><TD CLASS="l">779</TD><TD>            </TD></TR><TR><TD CLASS="l">780</TD><TD>            // we only need to do 'special' facet checking if the maxOccurs is &gt; 1</TD></TR><TR><TD CLASS="l">781</TD><TD>            // values of '0' and '-1' (unbounded) work 'for free' without any special checking</TD></TR><TR><TD CLASS="l">782</TD><TD>            //</TD></TR><TR CLASS="c"><TD CLASS="l">783</TD><TD>            if (content.getMaxOccur() &gt; 1)</TD></TR><TR><TD CLASS="l">784</TD><TD>            {  </TD></TR><TR CLASS="z"><TD CLASS="l">785</TD><TD>              ItemCount itemCount = (ItemCount)activeItemCountList.get(activeItemCountList.size() - 1);</TD></TR><TR><TD CLASS="l">786</TD><TD>              </TD></TR><TR><TD CLASS="l">787</TD><TD>              // here we need to compute if we can do another repeat</TD></TR><TR><TD CLASS="l">788</TD><TD>              // if we increase the repeat count by '1' will this violate the maxOccurs</TD></TR><TR><TD CLASS="l">789</TD><TD>              //</TD></TR><TR CLASS="z"><TD CLASS="l">790</TD><TD>              if (itemCount.count + 1 &gt;= content.getMaxOccur())</TD></TR><TR><TD CLASS="l">791</TD><TD>              {</TD></TR><TR CLASS="z"><TD CLASS="l">792</TD><TD>                result = false;</TD></TR><TR><TD CLASS="l">793</TD><TD>              }</TD></TR><TR><TD CLASS="l">794</TD><TD>            }</TD></TR><TR><TD CLASS="l">795</TD><TD>            //System.out.println(&#34;canPush REPEAT (&#34; + itemCount.count + &#34;)&#34; + content.getNodeName() + &#34; result= &#34; + result);            </TD></TR><TR><TD CLASS="l">796</TD><TD>          } </TD></TR><TR><TD CLASS="l">797</TD><TD>        }       </TD></TR><TR><TD CLASS="l">798</TD><TD>      }</TD></TR><TR CLASS="z"><TD CLASS="l">799</TD><TD>      catch (Exception e)</TD></TR><TR><TD CLASS="l">800</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">801</TD><TD>        e.printStackTrace();</TD></TR><TR><TD CLASS="l">802</TD><TD>      }</TD></TR><TR><TD CLASS="l">803</TD><TD>      //System.out.flush();</TD></TR><TR CLASS="c"><TD CLASS="l">804</TD><TD>      return result;</TD></TR><TR><TD CLASS="l"><A NAME="4c">805</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">806</TD><TD>    </TD></TR><TR><TD CLASS="l">807</TD><TD>    public void push(Arc arc)</TD></TR><TR><TD CLASS="l">808</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">809</TD><TD>      if (arc.kind == Arc.ELEMENT)</TD></TR><TR><TD CLASS="l">810</TD><TD>      {</TD></TR><TR><TD CLASS="l">811</TD><TD>        //System.out.println(&#34;[X]push(&#34; + arc.kind + &#34;)&#34; + arc.cmNode.getNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">812</TD><TD>        elementOriginStack.add(arc.cmNode);</TD></TR><TR CLASS="c"><TD CLASS="l">813</TD><TD>        partialValidationCount = Math.max(elementOriginStack.size(), partialValidationCount);</TD></TR><TR><TD CLASS="l">814</TD><TD>      }</TD></TR><TR CLASS="c"><TD CLASS="l">815</TD><TD>      else if (arc.kind == Arc.PREV_IN)</TD></TR><TR><TD CLASS="l">816</TD><TD>      {</TD></TR><TR><TD CLASS="l">817</TD><TD>        //System.out.println(&#34;[X]push(&#34; + arc.kind + &#34;)&#34; + arc.cmNode.getNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">818</TD><TD>        activeItemCountList.add(new ItemCount());   </TD></TR><TR><TD CLASS="l">819</TD><TD>      }</TD></TR><TR CLASS="c"><TD CLASS="l">820</TD><TD>      else if (arc.kind == Arc.OUT_NEXT)</TD></TR><TR><TD CLASS="l">821</TD><TD>      {        </TD></TR><TR><TD CLASS="l">822</TD><TD>        //System.out.println(&#34;[X]push(&#34; + arc.kind + &#34;)&#34; + arc.cmNode.getNodeName() + &#34;[&#34; + arc + &#34;]&#34;);</TD></TR><TR CLASS="c"><TD CLASS="l">823</TD><TD>        int size = activeItemCountList.size();</TD></TR><TR CLASS="c"><TD CLASS="l">824</TD><TD>        ItemCount itemCount = (ItemCount)activeItemCountList.get(size - 1);</TD></TR><TR CLASS="c"><TD CLASS="l">825</TD><TD>        activeItemCountList.remove(size - 1);</TD></TR><TR CLASS="c"><TD CLASS="l">826</TD><TD>        inactiveItemCountList.add(itemCount); </TD></TR><TR><TD CLASS="l">827</TD><TD>      }      </TD></TR><TR CLASS="c"><TD CLASS="l">828</TD><TD>      else if (arc.kind == Arc.REPEAT)</TD></TR><TR><TD CLASS="l">829</TD><TD>      {</TD></TR><TR><TD CLASS="l">830</TD><TD>        //System.out.println(&#34;[X]push(&#34; + arc.kind + &#34;)&#34; + arc.cmNode.getNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">831</TD><TD>        ItemCount itemCount = (ItemCount)activeItemCountList.get(activeItemCountList.size() - 1);</TD></TR><TR CLASS="c"><TD CLASS="l">832</TD><TD>        itemCount.count++;</TD></TR><TR><TD CLASS="l">833</TD><TD>        //System.out.println(&#34;repeat(&#34; + itemCount.count + &#34;)&#34; + arc.cmNode.getNodeName());</TD></TR><TR><TD CLASS="l">834</TD><TD>      }        </TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="4b">835</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">836</TD><TD> </TD></TR><TR><TD CLASS="l">837</TD><TD>    public void pop(Arc arc)</TD></TR><TR><TD CLASS="l">838</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">839</TD><TD>      if (arc.kind == Arc.ELEMENT)</TD></TR><TR><TD CLASS="l">840</TD><TD>      {</TD></TR><TR><TD CLASS="l">841</TD><TD>        //System.out.println(&#34;[X]pop(&#34; + arc.kind + &#34;)&#34; + arc.cmNode.getNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">842</TD><TD>        int size = elementOriginStack.size();</TD></TR><TR CLASS="c"><TD CLASS="l">843</TD><TD>        elementOriginStack.remove(size - 1);</TD></TR><TR><TD CLASS="l">844</TD><TD>      }</TD></TR><TR CLASS="c"><TD CLASS="l">845</TD><TD>      else if (arc.kind == Arc.PREV_IN)</TD></TR><TR><TD CLASS="l">846</TD><TD>      {</TD></TR><TR><TD CLASS="l">847</TD><TD>        //System.out.println(&#34;[X]pop(&#34; + arc.kind + &#34;)&#34; + arc.cmNode.getNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">848</TD><TD>        activeItemCountList.remove(activeItemCountList.size() - 1);        </TD></TR><TR><TD CLASS="l">849</TD><TD>      }</TD></TR><TR CLASS="c"><TD CLASS="l">850</TD><TD>      else if (arc.kind == Arc.OUT_NEXT)</TD></TR><TR><TD CLASS="l">851</TD><TD>      {</TD></TR><TR><TD CLASS="l">852</TD><TD>        //System.out.println(&#34;[X]pop(&#34; + arc.kind + &#34;)&#34; + arc.cmNode.getNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">853</TD><TD>        int size = inactiveItemCountList.size();</TD></TR><TR CLASS="c"><TD CLASS="l">854</TD><TD>        ItemCount itemCount = (ItemCount)inactiveItemCountList.get(size - 1);</TD></TR><TR CLASS="c"><TD CLASS="l">855</TD><TD>        inactiveItemCountList.remove(size - 1);</TD></TR><TR CLASS="c"><TD CLASS="l">856</TD><TD>        activeItemCountList.add(itemCount);     </TD></TR><TR><TD CLASS="l">857</TD><TD>      }  </TD></TR><TR CLASS="c"><TD CLASS="l">858</TD><TD>      else if (arc.kind == Arc.REPEAT)</TD></TR><TR><TD CLASS="l">859</TD><TD>      {</TD></TR><TR><TD CLASS="l">860</TD><TD>        //System.out.println(&#34;[X]pop(&#34; + arc.kind + &#34;)&#34; + arc.cmNode.getNodeName());</TD></TR><TR CLASS="c"><TD CLASS="l">861</TD><TD>        ItemCount itemCount = (ItemCount)activeItemCountList.get(activeItemCountList.size() - 1);</TD></TR><TR CLASS="c"><TD CLASS="l">862</TD><TD>        itemCount.count--;</TD></TR><TR><TD CLASS="l">863</TD><TD>      }     </TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="44">864</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">865</TD><TD> </TD></TR><TR><TD CLASS="l">866</TD><TD>    public Vector getElementOriginList()</TD></TR><TR><TD CLASS="l">867</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">868</TD><TD>      return elementOriginStack;</TD></TR><TR><TD CLASS="l"><A NAME="45">869</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">870</TD><TD> </TD></TR><TR><TD CLASS="l">871</TD><TD>    public CMNode[] getOriginArray()</TD></TR><TR><TD CLASS="l">872</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">873</TD><TD>      return originArray;</TD></TR><TR><TD CLASS="l"><A NAME="46">874</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">875</TD><TD> </TD></TR><TR><TD CLASS="l">876</TD><TD>    public void setOriginArray(CMNode[] originArray)</TD></TR><TR><TD CLASS="l">877</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">878</TD><TD>      this.originArray = originArray;</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="4a">879</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">880</TD><TD>    </TD></TR><TR><TD CLASS="l">881</TD><TD>    public int getPartialValidationCount()</TD></TR><TR><TD CLASS="l">882</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">883</TD><TD>      return partialValidationCount;</TD></TR><TR><TD CLASS="l"><A NAME="47">884</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">885</TD><TD> </TD></TR><TR><TD CLASS="l">886</TD><TD>    public void setPartialValidationCount(int partialValidationCount)</TD></TR><TR><TD CLASS="l">887</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">888</TD><TD>      this.partialValidationCount = partialValidationCount;</TD></TR><TR CLASS="z"><TD CLASS="l">889</TD><TD>    }</TD></TR><TR><TD CLASS="l">890</TD><TD>  }  </TD></TR><TR><TD CLASS="l"><A NAME="a">891</A></TD><TD> </TD></TR><TR><TD CLASS="l">892</TD><TD>  /**</TD></TR><TR><TD CLASS="l">893</TD><TD>   *</TD></TR><TR><TD CLASS="l">894</TD><TD>   */</TD></TR><TR CLASS="z"><TD CLASS="l">895</TD><TD>  public static class PathRecordingResult extends Result</TD></TR><TR><TD CLASS="l">896</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="f">897</A></TD><TD>    protected Vector arcList = new Vector();</TD></TR><TR><TD CLASS="l">898</TD><TD> </TD></TR><TR><TD CLASS="l">899</TD><TD>    public void push(Arc arc)</TD></TR><TR><TD CLASS="l">900</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">901</TD><TD>      arcList.add(arc);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="e">902</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">903</TD><TD> </TD></TR><TR><TD CLASS="l">904</TD><TD>    public void pop(Arc arc)</TD></TR><TR><TD CLASS="l">905</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">906</TD><TD>      int size = arcList.size();</TD></TR><TR CLASS="z"><TD CLASS="l">907</TD><TD>      arcList.remove(size - 1);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="c">908</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">909</TD><TD> </TD></TR><TR><TD CLASS="l">910</TD><TD>    public List getArcList()</TD></TR><TR><TD CLASS="l">911</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">912</TD><TD>      List list = new Vector();</TD></TR><TR CLASS="z"><TD CLASS="l">913</TD><TD>      for (Iterator iterator = arcList.iterator(); iterator.hasNext(); )</TD></TR><TR><TD CLASS="l">914</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">915</TD><TD>        Arc arc = (Arc)iterator.next();</TD></TR><TR CLASS="z"><TD CLASS="l">916</TD><TD>        if (arc.kind == Arc.ELEMENT)</TD></TR><TR><TD CLASS="l">917</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">918</TD><TD>          list.add(arc);</TD></TR><TR><TD CLASS="l">919</TD><TD>        }</TD></TR><TR><TD CLASS="l">920</TD><TD>      }</TD></TR><TR CLASS="z"><TD CLASS="l">921</TD><TD>      return list;</TD></TR><TR><TD CLASS="l"><A NAME="d">922</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">923</TD><TD> </TD></TR><TR><TD CLASS="l">924</TD><TD>    public MatchModelNode getMatchModel()</TD></TR><TR><TD CLASS="l">925</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">926</TD><TD>      MatchModelNodeBuilder builder = new MatchModelNodeBuilder(arcList);</TD></TR><TR CLASS="z"><TD CLASS="l">927</TD><TD>      builder.buildMatchModel();</TD></TR><TR CLASS="z"><TD CLASS="l">928</TD><TD>      return builder.getRoot();</TD></TR><TR><TD CLASS="l">929</TD><TD>    }</TD></TR><TR><TD CLASS="l">930</TD><TD>  }</TD></TR><TR><TD CLASS="l">931</TD><TD> </TD></TR><TR><TD CLASS="l">932</TD><TD>  /**</TD></TR><TR><TD CLASS="l">933</TD><TD>   *</TD></TR><TR><TD CLASS="l">934</TD><TD>   */</TD></TR><TR><TD CLASS="l">935</TD><TD>  public static class MatchModelNode</TD></TR><TR><TD CLASS="l">936</TD><TD>  {</TD></TR><TR><TD CLASS="l"><A NAME="0">937</A></TD><TD>    public CMNode cmNode;</TD></TR><TR CLASS="z"><TD CLASS="l">938</TD><TD>    public List children = new Vector();</TD></TR><TR><TD CLASS="l">939</TD><TD>    public Object data;</TD></TR><TR><TD CLASS="l">940</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">941</TD><TD>    public MatchModelNode(MatchModelNode parent, CMNode cmNode)</TD></TR><TR><TD CLASS="l">942</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">943</TD><TD>      this.cmNode = cmNode;</TD></TR><TR CLASS="z"><TD CLASS="l">944</TD><TD>    }</TD></TR><TR><TD CLASS="l">945</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="2">946</A></TD><TD>    public void printModel(int indent)</TD></TR><TR><TD CLASS="l">947</TD><TD>    {</TD></TR><TR><TD CLASS="l">948</TD><TD>      //String cmNodeName = cmNode != null ? cmNode.getNodeName() : &#34;null&#34;;</TD></TR><TR><TD CLASS="l">949</TD><TD>      //printlnIndented(indent, &#34;MatchModelNode : &#34; + cmNodeName);</TD></TR><TR CLASS="z"><TD CLASS="l">950</TD><TD>      for (Iterator iterator = children.iterator(); iterator.hasNext(); )</TD></TR><TR><TD CLASS="l">951</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">952</TD><TD>        MatchModelNode child = (MatchModelNode)iterator.next();</TD></TR><TR CLASS="z"><TD CLASS="l">953</TD><TD>        child.printModel(indent + 2);</TD></TR><TR><TD CLASS="l">954</TD><TD>      }</TD></TR><TR CLASS="z"><TD CLASS="l">955</TD><TD>    }</TD></TR><TR><TD CLASS="l">956</TD><TD>  }</TD></TR><TR><TD CLASS="l">957</TD><TD> </TD></TR><TR><TD CLASS="l">958</TD><TD>  public static class MatchModelNodeBuilder</TD></TR><TR><TD CLASS="l">959</TD><TD>  {</TD></TR><TR><TD CLASS="l">960</TD><TD>    protected List arcList;</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="3">961</A></TD><TD>    protected List stack = new Vector();</TD></TR><TR><TD CLASS="l">962</TD><TD>    protected MatchModelNode root;</TD></TR><TR><TD CLASS="l">963</TD><TD>    protected MatchModelNode current;</TD></TR><TR><TD CLASS="l">964</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">965</TD><TD>    public MatchModelNodeBuilder(List arcList)</TD></TR><TR><TD CLASS="l">966</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">967</TD><TD>      this.arcList = arcList;</TD></TR><TR CLASS="z"><TD CLASS="l">968</TD><TD>      root = new MatchModelNode(null, null);</TD></TR><TR CLASS="z"><TD CLASS="l">969</TD><TD>      push(root);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="9">970</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">971</TD><TD> </TD></TR><TR><TD CLASS="l">972</TD><TD>    protected void push(MatchModelNode node)</TD></TR><TR><TD CLASS="l">973</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">974</TD><TD>      current = node;</TD></TR><TR CLASS="z"><TD CLASS="l">975</TD><TD>      stack.add(node);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="8">976</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">977</TD><TD> </TD></TR><TR><TD CLASS="l">978</TD><TD>    protected void pop()</TD></TR><TR><TD CLASS="l">979</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">980</TD><TD>      int size = stack.size();</TD></TR><TR CLASS="z"><TD CLASS="l">981</TD><TD>      stack.remove(size - 1);</TD></TR><TR CLASS="z"><TD CLASS="l">982</TD><TD>      current = (MatchModelNode)stack.get(size - 2);</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="7">983</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">984</TD><TD> </TD></TR><TR><TD CLASS="l">985</TD><TD>    public boolean isCMGroup(CMNode cmNode)</TD></TR><TR><TD CLASS="l">986</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">987</TD><TD>      return cmNode != null &amp;&amp; cmNode.getNodeType() == CMNode.GROUP;</TD></TR><TR><TD CLASS="l"><A NAME="5">988</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">989</TD><TD> </TD></TR><TR><TD CLASS="l">990</TD><TD>    public void buildMatchModel()</TD></TR><TR><TD CLASS="l">991</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">992</TD><TD>      for (Iterator iterator = arcList.iterator(); iterator.hasNext(); )</TD></TR><TR><TD CLASS="l">993</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">994</TD><TD>        Arc arc = (Arc)iterator.next();</TD></TR><TR><TD CLASS="l">995</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">996</TD><TD>        if (arc.kind == Arc.ELEMENT)</TD></TR><TR><TD CLASS="l">997</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">998</TD><TD>          current.children.add(new MatchModelNode(current, arc.cmNode));</TD></TR><TR><TD CLASS="l">999</TD><TD>        }</TD></TR><TR CLASS="z"><TD CLASS="l">1000</TD><TD>        else if (arc.kind == Arc.PREV_IN)</TD></TR><TR><TD CLASS="l">1001</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">1002</TD><TD>          if (isCMGroup(arc.cmNode))</TD></TR><TR><TD CLASS="l">1003</TD><TD>          {</TD></TR><TR CLASS="z"><TD CLASS="l">1004</TD><TD>            MatchModelNode newModelNode = new MatchModelNode(current, arc.cmNode);</TD></TR><TR CLASS="z"><TD CLASS="l">1005</TD><TD>            current.children.add(newModelNode);</TD></TR><TR CLASS="z"><TD CLASS="l">1006</TD><TD>            push(newModelNode);</TD></TR><TR><TD CLASS="l">1007</TD><TD>          }</TD></TR><TR><TD CLASS="l">1008</TD><TD>        }</TD></TR><TR CLASS="z"><TD CLASS="l">1009</TD><TD>        else if (arc.kind == Arc.OUT_NEXT)</TD></TR><TR><TD CLASS="l">1010</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">1011</TD><TD>          if (isCMGroup(arc.cmNode))</TD></TR><TR><TD CLASS="l">1012</TD><TD>          {</TD></TR><TR CLASS="z"><TD CLASS="l">1013</TD><TD>            pop();</TD></TR><TR><TD CLASS="l">1014</TD><TD>          }</TD></TR><TR><TD CLASS="l">1015</TD><TD>        }</TD></TR><TR CLASS="z"><TD CLASS="l">1016</TD><TD>        else if (arc.kind == Arc.REPEAT)</TD></TR><TR><TD CLASS="l">1017</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">1018</TD><TD>          if (isCMGroup(arc.cmNode))</TD></TR><TR><TD CLASS="l">1019</TD><TD>          {</TD></TR><TR CLASS="z"><TD CLASS="l">1020</TD><TD>            pop();</TD></TR><TR CLASS="z"><TD CLASS="l">1021</TD><TD>            MatchModelNode newModelNode = new MatchModelNode(current, arc.cmNode);</TD></TR><TR CLASS="z"><TD CLASS="l">1022</TD><TD>            current.children.add(newModelNode);</TD></TR><TR CLASS="z"><TD CLASS="l">1023</TD><TD>            push(newModelNode);</TD></TR><TR><TD CLASS="l">1024</TD><TD>          }</TD></TR><TR><TD CLASS="l">1025</TD><TD>        }</TD></TR><TR><TD CLASS="l">1026</TD><TD>      }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="6">1027</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">1028</TD><TD> </TD></TR><TR><TD CLASS="l">1029</TD><TD>    public MatchModelNode getRoot()</TD></TR><TR><TD CLASS="l">1030</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">1031</TD><TD>      return root;</TD></TR><TR><TD CLASS="l">1032</TD><TD>    }</TD></TR><TR><TD CLASS="l">1033</TD><TD>  }</TD></TR><TR><TD CLASS="l">1034</TD><TD> </TD></TR><TR><TD CLASS="l">1035</TD><TD> </TD></TR><TR><TD CLASS="l">1036</TD><TD>  /**</TD></TR><TR><TD CLASS="l">1037</TD><TD>   *</TD></TR><TR><TD CLASS="l">1038</TD><TD>   */</TD></TR><TR><TD CLASS="l">1039</TD><TD>  public interface ElementContentComparator</TD></TR><TR><TD CLASS="l">1040</TD><TD>  {</TD></TR><TR><TD CLASS="l">1041</TD><TD>    public boolean isIgnorable(Object o);</TD></TR><TR><TD CLASS="l">1042</TD><TD>    public boolean isPCData(Object o);</TD></TR><TR><TD CLASS="l">1043</TD><TD>    public boolean isElement(Object o);</TD></TR><TR><TD CLASS="l">1044</TD><TD>    public boolean matches(Object o, CMNode cmNode);</TD></TR><TR><TD CLASS="l">1045</TD><TD>  }</TD></TR><TR><TD CLASS="l"><A NAME="10">1046</A></TD><TD> </TD></TR><TR><TD CLASS="l">1047</TD><TD>  /**</TD></TR><TR><TD CLASS="l">1048</TD><TD>   * A linked list</TD></TR><TR><TD CLASS="l">1049</TD><TD>   */</TD></TR><TR CLASS="c"><TD CLASS="l">1050</TD><TD>  public static class ElementList</TD></TR><TR><TD CLASS="l">1051</TD><TD>  {</TD></TR><TR><TD CLASS="l">1052</TD><TD>    protected Object head;</TD></TR><TR><TD CLASS="l"><A NAME="11">1053</A></TD><TD>    protected ElementList tail;</TD></TR><TR><TD CLASS="l">1054</TD><TD> </TD></TR><TR><TD CLASS="l">1055</TD><TD>    public static ElementList create(List v)</TD></TR><TR><TD CLASS="l">1056</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">1057</TD><TD>      ElementList first = null;</TD></TR><TR CLASS="z"><TD CLASS="l">1058</TD><TD>      ElementList prev = null;</TD></TR><TR><TD CLASS="l">1059</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">1060</TD><TD>      for (Iterator iterator = v.iterator(); iterator.hasNext(); )</TD></TR><TR><TD CLASS="l">1061</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">1062</TD><TD>        Object o = iterator.next();</TD></TR><TR CLASS="z"><TD CLASS="l">1063</TD><TD>        if (o != null)</TD></TR><TR><TD CLASS="l">1064</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">1065</TD><TD>          ElementList list = new ElementList();</TD></TR><TR CLASS="z"><TD CLASS="l">1066</TD><TD>          list.head = o;</TD></TR><TR><TD CLASS="l">1067</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">1068</TD><TD>          if (prev != null)</TD></TR><TR><TD CLASS="l">1069</TD><TD>          {</TD></TR><TR CLASS="z"><TD CLASS="l">1070</TD><TD>            prev.tail = list;</TD></TR><TR><TD CLASS="l">1071</TD><TD>          }</TD></TR><TR><TD CLASS="l">1072</TD><TD>          else</TD></TR><TR><TD CLASS="l">1073</TD><TD>          {</TD></TR><TR CLASS="z"><TD CLASS="l">1074</TD><TD>            first = list;</TD></TR><TR><TD CLASS="l">1075</TD><TD>          }</TD></TR><TR CLASS="z"><TD CLASS="l">1076</TD><TD>          prev = list;</TD></TR><TR><TD CLASS="l">1077</TD><TD>        }</TD></TR><TR><TD CLASS="l">1078</TD><TD>      }</TD></TR><TR CLASS="z"><TD CLASS="l">1079</TD><TD>      return first;</TD></TR><TR><TD CLASS="l">1080</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="12">1081</A></TD><TD> </TD></TR><TR><TD CLASS="l">1082</TD><TD> </TD></TR><TR><TD CLASS="l">1083</TD><TD>    public String toString()</TD></TR><TR><TD CLASS="l">1084</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">1085</TD><TD>      String string = &#34;[&#34; + head + &#34;],&#34;; //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">1086</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">1087</TD><TD>      if (tail != null)</TD></TR><TR><TD CLASS="l">1088</TD><TD>      {</TD></TR><TR CLASS="z"><TD CLASS="l">1089</TD><TD>        string += tail.toString();</TD></TR><TR><TD CLASS="l">1090</TD><TD>      }</TD></TR><TR><TD CLASS="l">1091</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">1092</TD><TD>      return string;</TD></TR><TR><TD CLASS="l">1093</TD><TD>    }</TD></TR><TR><TD CLASS="l">1094</TD><TD>  }</TD></TR><TR><TD CLASS="l"><A NAME="25">1095</A></TD><TD> </TD></TR><TR><TD CLASS="l">1096</TD><TD>  /**</TD></TR><TR><TD CLASS="l">1097</TD><TD>   * StringElementContentComparator</TD></TR><TR><TD CLASS="l">1098</TD><TD>   */</TD></TR><TR CLASS="c"><TD CLASS="l"><A NAME="2b">1099</A></TD><TD>  public static class StringElementContentComparator implements ElementContentComparator</TD></TR><TR><TD CLASS="l">1100</TD><TD>  {</TD></TR><TR><TD CLASS="l">1101</TD><TD>    public boolean isIgnorable(Object o)</TD></TR><TR><TD CLASS="l">1102</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">1103</TD><TD>      String string = o.toString();</TD></TR><TR CLASS="c"><TD CLASS="l">1104</TD><TD>      return string.startsWith(&#34;!&#34;) || string.startsWith(&#34;?&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l"><A NAME="28">1105</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">1106</TD><TD> </TD></TR><TR><TD CLASS="l">1107</TD><TD>    public boolean isPCData(Object o)</TD></TR><TR><TD CLASS="l">1108</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">1109</TD><TD>      String string = o.toString();</TD></TR><TR CLASS="p"><TD CLASS="l" TITLE="87% line coverage (13 out of 15 instructions)">1110</TD><TD TITLE="87% line coverage (13 out of 15 instructions)">      return string.startsWith(&#34;'&#34;) || string.startsWith(&#34;\&#34;&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR><TD CLASS="l"><A NAME="2a">1111</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">1112</TD><TD> </TD></TR><TR><TD CLASS="l">1113</TD><TD>    public boolean isElement(Object o)</TD></TR><TR><TD CLASS="l">1114</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">1115</TD><TD>      return !isIgnorable(o) &amp;&amp; !isPCData(o);</TD></TR><TR><TD CLASS="l"><A NAME="27">1116</A></TD><TD>    }</TD></TR><TR><TD CLASS="l">1117</TD><TD> </TD></TR><TR><TD CLASS="l">1118</TD><TD>    public boolean matches(Object o, CMNode cmNode)</TD></TR><TR><TD CLASS="l">1119</TD><TD>    {</TD></TR><TR CLASS="c"><TD CLASS="l">1120</TD><TD>      boolean result = false;</TD></TR><TR CLASS="c"><TD CLASS="l">1121</TD><TD>      if (cmNode.getNodeType() == CMNode.ELEMENT_DECLARATION)</TD></TR><TR><TD CLASS="l">1122</TD><TD>      { </TD></TR><TR CLASS="c"><TD CLASS="l">1123</TD><TD>        CMElementDeclaration element = (CMElementDeclaration)cmNode;</TD></TR><TR CLASS="c"><TD CLASS="l">1124</TD><TD>        String name = o.toString();                              </TD></TR><TR CLASS="c"><TD CLASS="l">1125</TD><TD>        int index = name.indexOf(&#34;]&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="c"><TD CLASS="l">1126</TD><TD>        if (index != -1)</TD></TR><TR><TD CLASS="l">1127</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">1128</TD><TD>          name = name.substring(index + 1);</TD></TR><TR><TD CLASS="l">1129</TD><TD>        }</TD></TR><TR CLASS="c"><TD CLASS="l">1130</TD><TD>        result = name.equalsIgnoreCase(element.getElementName());        </TD></TR><TR><TD CLASS="l">1131</TD><TD> </TD></TR><TR><TD CLASS="l">1132</TD><TD>        // TODO... here's we consider substitution groups... revisit to see if this should be moved into validator code</TD></TR><TR CLASS="c"><TD CLASS="l">1133</TD><TD>        if (!result)</TD></TR><TR><TD CLASS="l">1134</TD><TD>        {</TD></TR><TR CLASS="c"><TD CLASS="l">1135</TD><TD>          CMNodeList cmNodeList = (CMNodeList)element.getProperty(&#34;SubstitutionGroup&#34;);   //$NON-NLS-1$</TD></TR><TR CLASS="c"><TD CLASS="l">1136</TD><TD>          if (cmNodeList != null)</TD></TR><TR><TD CLASS="l">1137</TD><TD>          {</TD></TR><TR CLASS="c"><TD CLASS="l">1138</TD><TD>            int cmNodeListLength = cmNodeList.getLength();</TD></TR><TR CLASS="c"><TD CLASS="l">1139</TD><TD>            if (cmNodeListLength &gt; 1)</TD></TR><TR><TD CLASS="l">1140</TD><TD>            {                        </TD></TR><TR CLASS="z"><TD CLASS="l">1141</TD><TD>              for (int i = 0; i &lt; cmNodeListLength; i++)</TD></TR><TR><TD CLASS="l">1142</TD><TD>              {                                                               </TD></TR><TR CLASS="z"><TD CLASS="l">1143</TD><TD>                CMElementDeclaration alternativeCMElementDeclaration = (CMElementDeclaration)cmNodeList.item(i);</TD></TR><TR CLASS="z"><TD CLASS="l">1144</TD><TD>                String altName = alternativeCMElementDeclaration.getElementName();</TD></TR><TR CLASS="z"><TD CLASS="l">1145</TD><TD>                result = name.equalsIgnoreCase(altName);</TD></TR><TR CLASS="z"><TD CLASS="l">1146</TD><TD>                if (result)</TD></TR><TR><TD CLASS="l">1147</TD><TD>                {</TD></TR><TR CLASS="z"><TD CLASS="l">1148</TD><TD>                  break;</TD></TR><TR><TD CLASS="l">1149</TD><TD>                }</TD></TR><TR><TD CLASS="l">1150</TD><TD>              }</TD></TR><TR><TD CLASS="l">1151</TD><TD>            }</TD></TR><TR><TD CLASS="l">1152</TD><TD>          }</TD></TR><TR><TD CLASS="l">1153</TD><TD>        }         </TD></TR><TR><TD CLASS="l">1154</TD><TD>      }   </TD></TR><TR CLASS="z"><TD CLASS="l">1155</TD><TD>      else if (cmNode.getNodeType() == CMNode.ANY_ELEMENT)</TD></TR><TR><TD CLASS="l">1156</TD><TD>      {                                   </TD></TR><TR CLASS="z"><TD CLASS="l">1157</TD><TD>        String string = o.toString();</TD></TR><TR CLASS="z"><TD CLASS="l">1158</TD><TD>        if (string.equals(&#34;*&#34;)) //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">1159</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">1160</TD><TD>          result = true;</TD></TR><TR><TD CLASS="l">1161</TD><TD>        }</TD></TR><TR><TD CLASS="l">1162</TD><TD>        else</TD></TR><TR><TD CLASS="l">1163</TD><TD>        {</TD></TR><TR CLASS="z"><TD CLASS="l">1164</TD><TD>          CMAnyElement anyElement = (CMAnyElement)cmNode;</TD></TR><TR CLASS="z"><TD CLASS="l">1165</TD><TD>          String anyElementURI = anyElement.getNamespaceURI();    </TD></TR><TR CLASS="z"><TD CLASS="l">1166</TD><TD>          if (anyElementURI != null)</TD></TR><TR><TD CLASS="l">1167</TD><TD>          {           </TD></TR><TR CLASS="z"><TD CLASS="l">1168</TD><TD>            if (anyElementURI.equals(&#34;##any&#34;)) //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">1169</TD><TD>            {                               </TD></TR><TR CLASS="z"><TD CLASS="l">1170</TD><TD>              result = true;</TD></TR><TR><TD CLASS="l">1171</TD><TD>            }</TD></TR><TR CLASS="z"><TD CLASS="l">1172</TD><TD>            else if (anyElementURI.equals(&#34;##other&#34;)) //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">1173</TD><TD>            {     </TD></TR><TR CLASS="z"><TD CLASS="l">1174</TD><TD>              result = true;    </TD></TR><TR CLASS="z"><TD CLASS="l">1175</TD><TD>              CMDocument cmDocument = (CMDocument)anyElement.getProperty(&#34;CMDocument&#34;);   //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">1176</TD><TD>              if (cmDocument != null)</TD></TR><TR><TD CLASS="l">1177</TD><TD>              {</TD></TR><TR CLASS="z"><TD CLASS="l">1178</TD><TD>                String excludedURI = (String)cmDocument.getProperty(&#34;http://org.eclipse.wst/cm/properties/targetNamespaceURI&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">1179</TD><TD>                if (excludedURI != null)</TD></TR><TR><TD CLASS="l">1180</TD><TD>                { </TD></TR><TR CLASS="z"><TD CLASS="l">1181</TD><TD>                  String specifiedURI = getURIForContentSpecification(string);</TD></TR><TR CLASS="z"><TD CLASS="l">1182</TD><TD>                  if (specifiedURI != null &amp;&amp; excludedURI.equals(specifiedURI))</TD></TR><TR><TD CLASS="l">1183</TD><TD>                  { </TD></TR><TR CLASS="z"><TD CLASS="l">1184</TD><TD>                    result = false;</TD></TR><TR><TD CLASS="l">1185</TD><TD>                  } </TD></TR><TR><TD CLASS="l">1186</TD><TD>                }</TD></TR><TR><TD CLASS="l">1187</TD><TD>              }</TD></TR><TR><TD CLASS="l">1188</TD><TD>            } </TD></TR><TR CLASS="z"><TD CLASS="l">1189</TD><TD>            else if (anyElementURI.equals(&#34;##targetNamespace&#34;)) //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">1190</TD><TD>            {</TD></TR><TR CLASS="z"><TD CLASS="l">1191</TD><TD>              result = true;</TD></TR><TR CLASS="z"><TD CLASS="l">1192</TD><TD>              CMDocument cmDocument = (CMDocument)anyElement.getProperty(&#34;CMDocument&#34;);   //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">1193</TD><TD>              if (cmDocument != null)</TD></TR><TR><TD CLASS="l">1194</TD><TD>              {     </TD></TR><TR CLASS="z"><TD CLASS="l">1195</TD><TD>                String targetNamespaceURI = (String)cmDocument.getProperty(&#34;http://org.eclipse.wst/cm/properties/targetNamespaceURI&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">1196</TD><TD>                String specifiedURI = getURIForContentSpecification(string);</TD></TR><TR CLASS="z"><TD CLASS="l">1197</TD><TD>                if (specifiedURI != null &amp;&amp; !targetNamespaceURI.equals(specifiedURI))</TD></TR><TR><TD CLASS="l">1198</TD><TD>                { </TD></TR><TR CLASS="z"><TD CLASS="l">1199</TD><TD>                  result = false;</TD></TR><TR><TD CLASS="l">1200</TD><TD>                } </TD></TR><TR><TD CLASS="l">1201</TD><TD>              }</TD></TR><TR><TD CLASS="l">1202</TD><TD>            }</TD></TR><TR><TD CLASS="l">1203</TD><TD>            else  </TD></TR><TR><TD CLASS="l">1204</TD><TD>            {        </TD></TR><TR CLASS="z"><TD CLASS="l">1205</TD><TD>              result = true;</TD></TR><TR CLASS="z"><TD CLASS="l">1206</TD><TD>              String specifiedURI = getURIForContentSpecification(string);</TD></TR><TR CLASS="z"><TD CLASS="l">1207</TD><TD>              if (specifiedURI != null &amp;&amp; !anyElementURI.equals(specifiedURI))</TD></TR><TR><TD CLASS="l">1208</TD><TD>              { </TD></TR><TR CLASS="z"><TD CLASS="l">1209</TD><TD>                result = false;</TD></TR><TR><TD CLASS="l">1210</TD><TD>              }      </TD></TR><TR><TD CLASS="l">1211</TD><TD>            }</TD></TR><TR><TD CLASS="l">1212</TD><TD>          }  </TD></TR><TR><TD CLASS="l">1213</TD><TD>          else </TD></TR><TR><TD CLASS="l">1214</TD><TD>          {          </TD></TR><TR CLASS="z"><TD CLASS="l">1215</TD><TD>            result = true;</TD></TR><TR><TD CLASS="l">1216</TD><TD>          }        </TD></TR><TR><TD CLASS="l">1217</TD><TD>        }</TD></TR><TR><TD CLASS="l">1218</TD><TD>      }</TD></TR><TR CLASS="c"><TD CLASS="l">1219</TD><TD>      return result;</TD></TR><TR><TD CLASS="l">1220</TD><TD>    }     </TD></TR><TR><TD CLASS="l"><A NAME="26">1221</A></TD><TD>    </TD></TR><TR><TD CLASS="l">1222</TD><TD> </TD></TR><TR><TD CLASS="l">1223</TD><TD>    protected String getURIForContentSpecification(String specification)</TD></TR><TR><TD CLASS="l">1224</TD><TD>    {           </TD></TR><TR CLASS="z"><TD CLASS="l">1225</TD><TD>      String result = null;</TD></TR><TR CLASS="z"><TD CLASS="l">1226</TD><TD>      int index = specification.indexOf(&#34;]&#34;); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">1227</TD><TD>      if (index != -1)</TD></TR><TR><TD CLASS="l">1228</TD><TD>      {                </TD></TR><TR CLASS="z"><TD CLASS="l">1229</TD><TD>        result = specification.substring(1, index);</TD></TR><TR><TD CLASS="l">1230</TD><TD>      } </TD></TR><TR CLASS="z"><TD CLASS="l">1231</TD><TD>      return result;  </TD></TR><TR><TD CLASS="l">1232</TD><TD>    }</TD></TR><TR><TD CLASS="l"><A NAME="17">1233</A></TD><TD>  }      </TD></TR><TR><TD CLASS="l">1234</TD><TD> </TD></TR><TR><TD CLASS="l">1235</TD><TD>  public static List createStringList(String arg[], int startIndex)</TD></TR><TR><TD CLASS="l">1236</TD><TD>  {</TD></TR><TR CLASS="z"><TD CLASS="l">1237</TD><TD>    Vector v = new Vector();</TD></TR><TR CLASS="z"><TD CLASS="l">1238</TD><TD>    for (int i = startIndex; i &lt; arg.length; i++)</TD></TR><TR><TD CLASS="l">1239</TD><TD>    {</TD></TR><TR CLASS="z"><TD CLASS="l">1240</TD><TD>      v.add(arg[i]);</TD></TR><TR><TD CLASS="l">1241</TD><TD>    }</TD></TR><TR CLASS="z"><TD CLASS="l">1242</TD><TD>    return v;</TD></TR><TR><TD CLASS="l">1243</TD><TD>  }</TD></TR><TR><TD CLASS="l">1244</TD><TD>}</TD></TR></TABLE><P></P><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="a8.html">org.eclipse.wst.xml.core.internal.contentmodel.internal.util</A>]</TD></TR><TR><TD CLASS="tl"><A HREF="http://www.eclemma.org/support.html">EMMA 2.0.5312 EclEmma Fix 1</A> (C) Vladimir Roubtsov</TD></TR></TABLE></BODY></HTML>