<div dir="ltr">I've got an issue with classpath's containing either ; on ubuntu, or : under git bash (windows).   Can that be fixed in <a href="http://www.web3d.org/x3d/stylesheets/java/nashorn/build.xml">www.web3d.org/x3d/stylesheets/java/nashorn/build.xml</a> (several places, search for ;)?<div><br></div><div>Thanks,</div><div><br></div><div>John</div></div><br><div class="gmail_quote"><div dir="ltr">On Wed, Jun 6, 2018 at 6:20 PM Don Brutzman <<a href="mailto:brutzman@nps.edu">brutzman@nps.edu</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hmmm.  Likely it is your version John, just checked and we have a working round-trip "smoke test" for this construct.<br>
<br>
<a href="http://www.web3d.org/specifications/java/X3DJSAIL.html#Examples" rel="noreferrer" target="_blank">http://www.web3d.org/specifications/java/X3DJSAIL.html#Examples</a><br>
<br>
Excerpts in the examples/ directory, presented in order of production:<br>
<br>
1. HelloWorldProgram.java<br>
<br>
// ========== More object declarations, some with DEF values ==========<br>
String       defaultViewpointDEF = "DefaultView";<br>
String       topDownViewpointDEF = "TopDownView";<br>
ViewpointGroupObject  viewpointGroup = new ViewpointGroupObject(); //  requires <component name='Navigation' level='3'/><br>
ViewpointObject defaultViewpoint = new ViewpointObject(defaultViewpointDEF);<br>
ViewpointObject topDownViewpoint = new ViewpointObject(topDownViewpointDEF);<br>
<br>
2. HelloWorldProgramOutput.x3d<br>
<br>
<ViewpointGroup description='Available viewpoints'><br>
        <Viewpoint DEF='DefaultView' description='Hello X3DJSAIL'/><br>
        <Viewpoint DEF='TopDownView' description='top-down view from above' orientation='1 0 0 -1.570796' position='0 100 0'/><br>
</ViewpointGroup><br>
<br>
3. Ant build.xml in stylesheets/ parent directory:<br>
<br>
         <echo message="==========================================="/><br>
         <echo message="org.web3d.x3d.jsail.CommandLine java/examples/HelloWorldProgramOutput.x3d -toZIP -toFile ${java.examples.dir}/HelloWorldProgramOutput.ant.zip"/><br>
         <java classname="org.web3d.x3d.jsail.CommandLine" classpath="${java.jars.dir}/${<a href="http://jsai.full.archive.jar.name" rel="noreferrer" target="_blank">jsai.full.archive.jar.name</a>};." fork="${fork}"><br>
             <arg value="${java.examples.dir}/HelloWorldProgramOutput.x3d"/><!-- input model --><br>
             <arg value="-toZIP"/><br>
             <arg value="-toFile"/><br>
             <arg value="${java.examples.dir}/HelloWorldProgramOutput.ant.zip"/><br>
         </java><br>
         <echo message="==========================================="/><br>
<br>
4. HelloWorldProgramOutputLog.txt<br>
===========================================<br>
org.web3d.x3d.jsail.CommandLine java/examples/HelloWorldProgramOutput.x3d -toZIP -toFile java/examples/HelloWorldProgramOutput.ant.zip<br>
parameter: source file HelloWorldProgramOutput.x3d filesize 20956 bytes, parsed using Document Object Model (DOM) X3DLoader<br>
parameter: "-toZIP" for conversion to compressed ZIP containing model<br>
parameter: "-toFile" "java/examples/HelloWorldProgramOutput.ant.zip" for result file name root java/examples/HelloWorldProgramOutput.ant<br>
convert to ZIP:<br>
source: java/examples/HelloWorldProgramOutput.x3d filesize 20956 bytes<br>
result: HelloWorldProgramOutput.ant.zip filesize 5574 bytes, compression 26.60% of original<br>
===========================================<br>
<br>
5. HelloWorldProgramOutput.ReloadedDOM.x3d<br>
<br>
<ViewpointGroup description='Available viewpoints'><br>
        <Viewpoint DEF='DefaultView' description='Hello X3DJSAIL'/><br>
        <Viewpoint DEF='TopDownView' description='top-down view from above' orientation='1 0 0 -1.570796' position='0 100 0'/><br>
</ViewpointGroup><br>
<br>
so in this case, YMMV likely indicates that you need an update.<br>
<br>
<br>
On 6/6/2018 2:37 PM, John Carlson wrote:<br>
> Try stepping through with these commands at command prompt or similar (you’ll have to use diff and cp from Ubuntu, now available on Windows or similar commands under DOS)<br>
> <br>
> $ cd /c/x3d-code/<a href="http://www.web3d.org/x3d/stylesheets/java/" rel="noreferrer" target="_blank">www.web3d.org/x3d/stylesheets/java/</a><br>
> <br>
> $ javac -cp lib/javax.json-api-1.0.jar src/net/coderextreme/X3DJSONLD.java<br>
> <br>
> $ cp src/net/coderextreme/X3DJSONLD.class classes/net/coderextreme/<br>
> <br>
> $ jjs -cp "jars/X3DJSAIL.3.3.full.jar;classes" nashorn/examples/Json.js    # you may have to use the Java 8 way of specifying the classpath. See build.xml<br>
> <br>
> $ diff -w nashorn/examples/HelloWorldProgramOutput.Java.x3d nashorn/examples/Json.x3d<br>
> <br>
> 32a33,35<br>
> <br>
>  >         <meta name='translated' content='27 May 2018'/><br>
> <br>
>  >         <meta name='generator' content='X3dToJson.xslt, <a href="http://www.web3d.org/x3d/stylesheets/X3dToJson.html'/" rel="noreferrer" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dToJson.html'/</a>><br>
> <br>
>  >         <meta name='reference' content='X3D JSON encoding: <a href="http://www.web3d.org/wiki/index.php/X3D_JSON_Encoding'/" rel="noreferrer" target="_blank">http://www.web3d.org/wiki/index.php/X3D_JSON_Encoding'/</a>><br>
> <br>
> 35,38c38<br>
> <br>
> <         <ViewpointGroup description='Available viewpoints'><br>
> <br>
> <             <Viewpoint DEF='DefaultView' description='Hello X3DJSAIL'/><br>
> <br>
> <             <Viewpoint DEF='TopDownView' description='top-down view from above' orientation='1 0 0 -1.570796' position='0 100 0'/><br>
> <br>
> <         </ViewpointGroup><br>
> <br>
> ---<br>
> <br>
>  >         <ViewpointGroup description='Available viewpoints'/><br>
> <br>
> You will see the missing Viewpoint’s (children of ViewpointGroup) as above.  Also jjs will generate significant output.<br>
> <br>
> I can’t connect through svn, so I may be out of date.<br>
> <br>
> John<br>
> <br>
> Sent from Mail <<a href="https://go.microsoft.com/fwlink/?LinkId=550986" rel="noreferrer" target="_blank">https://go.microsoft.com/fwlink/?LinkId=550986</a>> for Windows 10<br>
> <br>
> *From: *Don Brutzman <mailto:<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>><br>
> *Sent: *Wednesday, June 6, 2018 9:41 AM<br>
> *To: *John Carlson <mailto:<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>><br>
> *Cc: *<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a> <mailto:<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
> *Subject: *Re: X3DJSAIL, X3dToJava.xslt and DOM X3DLoaderObject testing:anotherClassCastException<br>
> <br>
> 1. Hi John, finally getting back to this one.<br>
> <br>
> On 4/30/2018 3:15 PM, John Carlson wrote:<br>
> <br>
>  > Previously reported problem, now assigned to the X3DLoaderObject, I believe.<br>
> <br>
>  ><br>
> <br>
>  > No Viewpoint children in X3D or JSON output.<br>
> <br>
> Not sure what that means?  Viewpoint node typically does not have any children, except perhaps for a Metadata* node or an IS/connect.<br>
> <br>
>  > Is a problem with X3DLoaderObject, looks like another class cast exception.  X3DJSONLD was eliminated from the problem by printing out the DOM object, and verifying the Viewpoint objects were there.   See x3d-code/<a href="http://www.web3d.org/x3d/stylesheets/java/nashorn/examples/Quotes.js" rel="noreferrer" target="_blank">www.web3d.org/x3d/stylesheets/java/nashorn/examples/Quotes.js</a>.<br>
> <br>
>  ><br>
> <br>
>  > Can be regenerated by running `ant test.nashorn` in x3d-code/<a href="http://www.web3d.org/x3d/stylesheets/java" rel="noreferrer" target="_blank">www.web3d.org/x3d/stylesheets/java</a><br>
> <br>
>  ><br>
> <br>
>  > See output in nashorn/examples/Json.{json,x3d}<br>
> <br>
>  ><br>
> <br>
>  > John<br>
> <br>
> OK have recently updated to Java JDK 1.8.0_172 and adjusted PATH to confirm jjs is running OK.<br>
> <br>
> Have also synchronized X3DJSAIL sudirectory nashorn/ and contents with subversion.<br>
> <br>
> I get the following outputs when running test.nashorn build target:<br>
> <br>
> ============================================================<br>
> <br>
> ant -f E:\\x3d-code\\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\\x3d\\stylesheets\\java test.nashorn<br>
> <br>
> test.nashorn:<br>
> <br>
> ===========================================<br>
> <br>
> ant nashorn/build.xml test.nashorn<br>
> <br>
> X3D Nashorn SAI Library.test.nashorn:<br>
> <br>
> Compile:<br>
> <br>
> Compiling 1 source file to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\classes<br>
> <br>
> Compiling 1 source file to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\classes<br>
> <br>
> Copy:<br>
> <br>
> Copying 1 file to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\examples<br>
> <br>
> Copying E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\examples\HelloWorldProgramOutput.x3d to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\examples\HelloWorldProgramOutput.x3d<br>
> <br>
> Copying 1 file to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\examples<br>
> <br>
> Copying E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\examples\HelloWorldProgramOutput.json to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\examples\HelloWorldProgramOutput.json<br>
> <br>
> Run:<br>
> <br>
> parameter: source file HelloWorldProgramOutput.x3d filesize 20956 bytes, parsed using Document Object Model (DOM) X3DLoader<br>
> <br>
> parameter: "-tojs" for conversion to X3DJSONLD JavaScript source<br>
> <br>
> parameter: "-toFile" "nashorn/examples/HelloWorldProgramOutput.Nashorn.js" for result file name root nashorn/examples/HelloWorldProgramOutput.Nashorn<br>
> <br>
> convert to JS JavaScript:<br>
> <br>
> Warning: toFileJavaScript() is overwriting prior file nashorn/examples/HelloWorldProgramOutput.Nashorn.js<br>
> <br>
> Script DEF=colorTypeConversionScript contains CDATA source-code text, copied as "#sourceText" using "strings" mode<br>
> <br>
> Script DEF=MaterialModulatorScript contains CDATA source-code text, copied as "#sourceText" using "strings" mode<br>
> <br>
> TypeError: input.readAllBytes is not a function<br>
> <br>
> Error: Cannot read file [E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\node_modules\xmldom\package.json]:<br>
> <br>
> [Error] TODO problem handling local exception within CommandLine, exiting<br>
> <br>
> org.web3d.x3d.sai.X3DException: ScriptException when processing fileName nashorn\examples\HelloWorldProgramOutput.Nashorn.js.intermediate.js, unable to save result: javax.script.ScriptException: Error: Cannot load JSON file in nashorn/jvm-npm.js at line number 216 at column number 8<br>
> <br>
>                  at org.web3d.x3d.jsail.Core.X3DObject.toFileJavaScript(X3DObject.java:1662)<br>
> <br>
>                  at org.web3d.x3d.jsail.CommandLine.run(CommandLine.java:628)<br>
> <br>
>                  at org.web3d.x3d.jsail.CommandLine.main(CommandLine.java:163)<br>
> <br>
> parameter: source file HelloWorldProgramOutput.x3d filesize 20956 bytes, parsed using Document Object Model (DOM) X3DLoader<br>
> <br>
> parameter: "-toJSON" for conversion to JSON encoding<br>
> <br>
> parameter: "-toFile" "nashorn/examples/HelloWorldProgramOutput.Java.json" for result file name root nashorn/examples/HelloWorldProgramOutput.Java<br>
> <br>
> convert to JSON:<br>
> <br>
> Warning: toFileStylesheetConversion(X3dToJson.xslt) is overwriting prior file nashorn/examples/HelloWorldProgramOutput.Java.json<br>
> <br>
> Script DEF=colorTypeConversionScript contains CDATA source-code text, copied as "#sourceText" using "strings" mode<br>
> <br>
> Script DEF=MaterialModulatorScript contains CDATA source-code text, copied as "#sourceText" using "strings" mode<br>
> <br>
> file conversion successful: HelloWorldProgramOutput.Java.json (39749 bytes)<br>
> <br>
> parameter: source file HelloWorldProgramOutput.x3d filesize 20956 bytes, parsed using Document Object Model (DOM) X3DLoader<br>
> <br>
> parameter: "-toX3D" for conversion to X3D encoding<br>
> <br>
> parameter: "-toFile" "nashorn/examples/HelloWorldProgramOutput.Java.x3d" for result file name root nashorn/examples/HelloWorldProgramOutput.Java<br>
> <br>
> convert to X3D:<br>
> <br>
> Warning: toFileX3D() is overwriting prior file nashorn/examples/HelloWorldProgramOutput.Java.x3d<br>
> <br>
> file conversion successful: HelloWorldProgramOutput.Java.x3d (20956 bytes)<br>
> <br>
> ===========================================<br>
> <br>
> ============================================================<br>
> <br>
> As you can see, the exception is in nashorn/jvm-npm.js:<br>
> <br>
>                  TypeError: input.readAllBytes is not a function<br>
> <br>
> Header in that file indicates that you have modified it.<br>
> <br>
> Specific javascript code block of interest:<br>
> <br>
>     function readFile (filename, core) {<br>
> <br>
>       var input;<br>
> <br>
>       try {<br>
> <br>
>         if (core) {<br>
> <br>
>           var classloader = java.lang.Thread.currentThread().getContextClassLoader();<br>
> <br>
>           input = classloader.getResourceAsStream(filename);<br>
> <br>
>         } else {<br>
> <br>
>                  input = new java.io.FileInputStream(filename);<br>
> <br>
>         }<br>
> <br>
>         return new java.lang.String(input.readAllBytes());<br>
> <br>
>       } catch (e) {<br>
> <br>
>         System.err.println(e);<br>
> <br>
>         throw new ModuleError('Cannot read file [' + filename + ']: ', 'IO_ERROR', e);<br>
> <br>
>       }<br>
> <br>
>     }<br>
> <br>
> JDK 8 Javadoc for java.io.FileInputStream does not provide a "readAllBytes()" method.  (Nor does JDK 1.9; however I am currently holding at 1.8 to stay compatible with Netbeans 8.)<br>
> <br>
>                  <a href="https://docs.oracle.com/javase/8/docs/api/java/io/FileInputStream.html" rel="noreferrer" target="_blank">https://docs.oracle.com/javase/8/docs/api/java/io/FileInputStream.html</a><br>
> <br>
> So it looks like you need another method.<br>
> <br>
> A search for "java.io.FileInputStream readAllBytes" provides a number of hits.  For example:<br>
> <br>
>                  File to byte[] in Java<br>
> <br>
>                  <a href="https://stackoverflow.com/questions/858980/file-to-byte-in-java" rel="noreferrer" target="_blank">https://stackoverflow.com/questions/858980/file-to-byte-in-java</a><br>
> <br>
> 2. Continuing with your prior error console also appears fruitful:<br>
> <br>
>  >       [exec] [X3DLoaderObject error] Incorrectly handled object construction, current elementObject=ViewpointGroup (ViewpointGroup), child=Viewpoint, java.lang.ClassCastException: org.web3d.x3d.jsail.Navigation.ViewpointGroupObject cannot be cast to org.web3d.x3d.sai.Grouping.X3DGroupingNode<br>
> <br>
>  ><br>
> <br>
>  >       [exec] java.lang.ClassCastException: org.web3d.x3d.jsail.Navigation.ViewpointGroupObject cannot be cast to org.web3d.x3d.sai.Grouping.X3DGroupingNode<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:1146)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:542)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:542)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:430)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:399)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn.scripts/jdk.nashorn.internal.scripts.Script$Recompilation$372$Json$cu1$restOf.:program(nashorn/examples/Json.js:15)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn/jdk.nashorn.internal.runtime.ScriptFunctionData.invoke(ScriptFunctionData.java:655)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn/jdk.nashorn.internal.runtime.ScriptFunction.invoke(ScriptFunction.java:513)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn/jdk.nashorn.internal.runtime.ScriptRuntime.apply(ScriptRuntime.java:527)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn/jdk.nashorn.tools.Shell.apply(Shell.java:519)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn/jdk.nashorn.tools.Shell.runScripts(Shell.java:448)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn/jdk.nashorn.tools.Shell.run(Shell.java:186)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn.shell/jdk.nashorn.tools.jjs.Main.main(Main.java:104)<br>
> <br>
>  ><br>
> <br>
>  >       [exec]     at jdk.scripting.nashorn.shell/jdk.nashorn.tools.jjs.Main.main(Main.java:80)<br>
> <br>
> Looks like it was trying to treat ViewpointGroup like a X3DGroupingNode - but it is not.  ViewpointGroup is not a X3DGroupingNode node, and can only contain a Metadata* node, Viewpoint/OrthoViewpoint/GeoViewpoint and other ViewpointGroup nodes.<br>
> <br>
> This might have been fixed already as part of the many DOM loader improvements performed; not seeing that error in my console.  Worth retesting if you can address the readAllBytes issue.<br>
> <br>
> I've added a warning to X3D tooltips to clarify that.<br>
> <br>
> Hope next round of improvement/testing can sort this one out fully.<br>
all the best, Don<br>
-- <br>
Don Brutzman  Naval Postgraduate School, Code USW/Br       <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a><br>
Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA   +1.831.656.2149<br>
X3D graphics, virtual worlds, navy robotics <a href="http://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">http://faculty.nps.edu/brutzman</a><br>
<br>
</blockquote></div>