<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=utf-8"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
.MsoChpDefault
        {mso-style-type:export-only;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style></head><body lang=EN-US link=blue vlink="#954F72"><div class=WordSection1><p class=MsoNormal>Write one java program which loads a scenegraph java program, calls the scenegraph create function on the loaded program which returns the scenegraph, then loading program calls the scenegraph output function.  That way, you don’t have to put the output code each individual Java program (which is undesirable).  I hope you think this idea is better than putting output code in each java file (I just though of it).</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I found XMLUnit too, but I didn’t use it.  I’m still doing the JavaScript thing.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Sent from <a href="https://go.microsoft.com/fwlink/?LinkId=550986">Mail</a> for Windows 10</p><p class=MsoNormal><o:p> </o:p></p><div style='mso-element:para-border-div;border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in'><p class=MsoNormal style='border:none;padding:0in'><b>From: </b><a href="mailto:brutzman@nps.edu">Don Brutzman</a><br><b>Sent: </b>Tuesday, April 18, 2017 3:45 AM<br><b>To: </b><a href="mailto:yottzumm@gmail.com">yottzumm@gmail.com</a><br><b>Cc: </b><a href="mailto:x3d-public@web3d.org">X3D Graphics public mailing list</a>; <a href="mailto:roy.walmsley@ntlworld.com">Roy Walmsley</a>; <a href="mailto:ak@alexkern.de">Alexander Kern</a><br><b>Subject: </b>Re: second release: X3DJSAIL Java translations, javadoc inX3DExamples Archives</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 4/17/2017 10:47 PM, yottzumm@gmail.com wrote:</p><p class=MsoNormal>> Great effort Don, I hope I helped in some small way (heh, heh, waiting for a replacement computer now).</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks John you have helped tons.  Identifying bugs and experimenting with design patterns is totally important and has greatly accelerated our progress, on multiple topics simultaneously.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> I am anxious to look at your output Java code/X3dToJava.xslt to see how I can fix the runtime bugs I encountered.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Each java file is individually inspectable now in the online archives, just like .json versions.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Are you differencing the output of Java against original XML yet?  That would certainly be good test to add.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Agreed that would be good to add to the build scripts, .x3d via .xslt to .java, compiled, and then runtime serialization back out to .x3d.  Every round trip adds multiple QA checks... also a great way to find holes in code.</p><p class=MsoNormal>  </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Have looked for Ant-based XML-diff (or plain-diff) tools, haven't found a native task or seen anything custom that stands out yet.  Suggestions welcome... hey wait a minute, this should work well:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                XMLUnit - Unit Testing XML for Java and .NET</p><p class=MsoNormal>                http://www.xmlunit.org</p><p class=MsoNormal>                "XMLUnit for Java 2.3.0 has been released on 2016-11-12, XMLUnit.NET 2.3.1 has been released on 2017-03-23."</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Also, just noticed that Ant received an upgrade to v10.1 for Java8 about 10 weeks ago, will look at upgrading to that.  That community is extremely careful and thorough with Ant upgrades so it is likely very well tested.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>btw have a hunch about how to handle the java-compilation "code too big" error in example scenes (that generate a method > 64K) when using XSLT.  The tail-recursion pattern can only returns a single string from each node and its children.  The stylesheet console logs reveal that the XSLT is already diagnosing large string values OK already.  Am thinking that I will surround long data structures with delimiters as it proceeds, keeping them inline, then upon completed generation will use the embedded delimiters to split that big comprehensive call into data structures plus call.  Of course, similar to your approach, will also have to come up with a good naming mechanism for those data structures too.  Stay tuned, i should be able to tackle that in another weekend or two.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>all the best, Don</p><p class=MsoNormal>-- </p><p class=MsoNormal>Don Brutzman  Naval Postgraduate School, Code USW/Br       brutzman@nps.edu</p><p class=MsoNormal>Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA   +1.831.656.2149</p><p class=MsoNormal>X3D graphics, virtual worlds, navy robotics http://faculty.nps.edu/brutzman</p><p class=MsoNormal><o:p> </o:p></p></div></body></html>