<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>Then by all means, make the X3D and JSON output have the same normalization</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>Monday, January 22, 2018 12:01 AM<br><b>To: </b><a href="mailto:yottzumm@gmail.com">John Carlson</a><br><b>Cc: </b><a href="mailto:x3d-public@web3d.org">x3d-public@web3d.org</a><br><b>Subject: </b>Re: X3dToJson.xslt still removing spaces from comments. See thisoutput from Java compared to JavaScript and JavaScript output</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>X3D Canonical Form says that whitespace is normalized, and X3DJSAIL output attempts to follow that.  The first of the following rules can be interpreted that way, though I'm not seeing explicit mention of comments.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>X3D Compressed Binary Encoding: 4.2.3 X3D canonical form</p><p class=MsoNormal>http://www.web3d.org/documents/specifications/19776-3/V3.1/Part03/concepts.html#X3DCanonicalForm</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>====================</p><p class=MsoNormal>a. Whitespace rules:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>     All whitespace characters are converted to a normalized (single-occurrence) blank character.</p><p class=MsoNormal>     Whitespace includes comma separators between all MF-type array values, including MFString arrays.</p><p class=MsoNormal>     All literal characters within an SFString value are retained verbatim.</p><p class=MsoNormal>     All literal characters within MFString array values are retained verbatim.</p><p class=MsoNormal>====================</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I thought another prior requirement might be in XML Recommendation or XML Infoset, but didn't find it...</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>XML Information Set (Second Edition)</p><p class=MsoNormal>http://www.w3.org/TR/xml-infoset</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Extensible Markup Language (XML) 1.0 (Fifth Edition)</p><p class=MsoNormal>https://www.w3.org/TR/xml</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Not sure where the excess whitespace is getting stripped, didn't find anything like that in the CommentsBlock source.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Wouldn't surprise me if DOM loader was doing that, in which case it can't be "fixed" or retained any differently - confirmation or further sleuthing welcome..</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>In practice I have seen tools normalize whitespace.  Seems like a good practice, you don't want invisible characters (or tool idiosyncrasies independently deciding that strictly equivalent information in a model might vary in terms of whitespace.  That's bad for digital signature, encryption, security back doors, etc.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>So, if anything, I'd lean towards explicitly requiring the normalization of whitespace in comments for X3D Canonical Form.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 1/20/2018 10:29 PM, John Carlson wrote:</p><p class=MsoNormal>> See subject.  Excess spaces are being removed from comments in JSON output from X3DJSAIL.</p><p class=MsoNormal>> </p><p class=MsoNormal>> $ diff HelloWorldProgramOutput.Nashorn.x3d HelloWorldProgramOutput.Nashorn.js.new.x3d</p><p class=MsoNormal>> </p><p class=MsoNormal>> 73c73</p><p class=MsoNormal>> </p><p class=MsoNormal>> <                     <!-- Comment example A, plain quotation marks:  He said, "Immel did it!" --></p><p class=MsoNormal>> </p><p class=MsoNormal>> ---</p><p class=MsoNormal>> </p><p class=MsoNormal>>  >                     <!-- Comment example A, plain quotation marks: He said, "Immel did it!" --></p><p class=MsoNormal>> </p><p class=MsoNormal>> 112a113</p><p class=MsoNormal>> </p><p class=MsoNormal>>  ></p><p class=MsoNormal>> </p><p class=MsoNormal>> 230a232</p><p class=MsoNormal>> </p><p class=MsoNormal>>  ></p><p class=MsoNormal>> </p><p class=MsoNormal>> 248,252c250</p><p class=MsoNormal>> </p><p class=MsoNormal>> <         <!-- Test success: x3dModel.findNodeByDEF(DeclarativeAppearanceExample) = <Appearance DEF='DeclarativeAppearanceExample'/> i.e.</p><p class=MsoNormal>> </p><p class=MsoNormal>> < <Appearance DEF='DeclarativeAppearanceExample'></p><p class=MsoNormal>> </p><p class=MsoNormal>> <     <!- - DeclarativeMaterialExample gets overridden by subsequently added MaterialModulator ProtoInstance - -></p><p class=MsoNormal>> </p><p class=MsoNormal>> <     <ProtoInstance DEF='MyMaterialModulator' name='MaterialModulator' containerField='material'/></p><p class=MsoNormal>> </p><p class=MsoNormal>> < </Appearance> --></p><p class=MsoNormal>> </p><p class=MsoNormal>> ---</p><p class=MsoNormal>> </p><p class=MsoNormal>>  >         <!-- Test success: x3dModel.findNodeByDEF(DeclarativeAppearanceExample) = <Appearance DEF='DeclarativeAppearanceExample'/> i.e. <Appearance DEF='DeclarativeAppearanceExample'> <!- - DeclarativeMaterialExample gets overridden by subsequently added MaterialModulator ProtoInstance - -> <ProtoInstance DEF='MyMaterialModulator' name='MaterialModulator' containerField='material'/> </Appearance> --></p><p class=MsoNormal>> </p><p class=MsoNormal>> 255c253</p><p class=MsoNormal>> </p><p class=MsoNormal>> <         <!-- Test success: x3dModel.findElementByNameValue("MaterialModulator", "ProtoDeclare")  found --></p><p class=MsoNormal>> </p><p class=MsoNormal>> ---</p><p class=MsoNormal>> </p><p class=MsoNormal>>  >         <!-- Test success: x3dModel.findElementByNameValue("MaterialModulator", "ProtoDeclare") found --></p><p class=MsoNormal>> </p><p class=MsoNormal>> 279,284c277,282</p><p class=MsoNormal>> </p><p class=MsoNormal>> <         <!-- Test success:  AnchorObject.isNode()=true,              siteAnchor.isNode()=true --></p><p class=MsoNormal>> </p><p class=MsoNormal>> <         <!-- Test success:  AnchorObject.isStatement()=false,        siteAnchor.isStatement()=false --></p><p class=MsoNormal>> </p><p class=MsoNormal>> <         <!-- Test success:   ROUTEObject.isNode()=false,     orbitPositionROUTE.isNode()=false --></p><p class=MsoNormal>> </p><p class=MsoNormal>> <         <!-- Test success:   ROUTEObject.isStatement()=true, orbitPositionROUTE.isStatement()=true --></p><p class=MsoNormal>> </p><p class=MsoNormal>> <         <!-- Test success: CommentsBlock.isNode()=false,           testComments.isNode()=false --></p><p class=MsoNormal>> </p><p class=MsoNormal>> <         <!-- Test failure: CommentsBlock.isStatement()=true,      testComments.isStatement()=true --></p><p class=MsoNormal>> </p><p class=MsoNormal>> ---</p><p class=MsoNormal>> </p><p class=MsoNormal>>  >         <!-- Test success: AnchorObject.isNode()=true, siteAnchor.isNode()=true --></p><p class=MsoNormal>> </p><p class=MsoNormal>>  >         <!-- Test success: AnchorObject.isStatement()=false, siteAnchor.isStatement()=false --></p><p class=MsoNormal>> </p><p class=MsoNormal>>  >         <!-- Test success: ROUTEObject.isNode()=false, orbitPositionROUTE.isNode()=false --></p><p class=MsoNormal>> </p><p class=MsoNormal>>  >         <!-- Test success: ROUTEObject.isStatement()=true, orbitPositionROUTE.isStatement()=true --></p><p class=MsoNormal>> </p><p class=MsoNormal>>  >         <!-- Test success: CommentsBlock.isNode()=false, testComments.isNode()=false --></p><p class=MsoNormal>> </p><p class=MsoNormal>>  >         <!-- Test failure: CommentsBlock.isStatement()=true, testComments.isStatement()=true --></p><p class=MsoNormal>> </p><p class=MsoNormal><o:p> </o:p></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>