<div dir="auto"><a href="https://docs.oracle.com/javase/9/docs/api/java/io/InputStream.html#readAllBytes--">https://docs.oracle.com/javase/9/docs/api/java/io/InputStream.html#readAllBytes--</a><div dir="auto"><br></div><div dir="auto">InputStream has readAllBytes in java 9.  CRSN.</div><div dir="auto"><br></div><div dir="auto">JOHN</div></div><br><div class="gmail_quote"><div dir="ltr">On Wed, Jun 6, 2018, 9:41 AM 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">1. Hi John, finally getting back to this one.<br>
<br>
On 4/30/2018 3:15 PM, John Carlson wrote:<br>
> Previously reported problem, now assigned to the X3DLoaderObject, I believe.<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 noreferrer" target="_blank">www.web3d.org/x3d/stylesheets/java/nashorn/examples/Quotes.js</a>.<br>
> <br>
> Can be regenerated by running `ant test.nashorn` in x3d-code/<a href="http://www.web3d.org/x3d/stylesheets/java" rel="noreferrer noreferrer" target="_blank">www.web3d.org/x3d/stylesheets/java</a><br>
> <br>
> See output in nashorn/examples/Json.{json,x3d}<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>
ant -f E:\\x3d-code\\<a href="http://www.web3d.org" rel="noreferrer noreferrer" target="_blank">www.web3d.org</a>\\x3d\\stylesheets\\java test.nashorn<br>
test.nashorn:<br>
===========================================<br>
ant nashorn/build.xml test.nashorn<br>
X3D Nashorn SAI Library.test.nashorn:<br>
Compile:<br>
Compiling 1 source file to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\classes<br>
Compiling 1 source file to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\classes<br>
Copy:<br>
Copying 1 file to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\examples<br>
Copying E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer 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 noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\examples\HelloWorldProgramOutput.x3d<br>
Copying 1 file to E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\examples<br>
Copying E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer 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 noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\examples\HelloWorldProgramOutput.json<br>
Run:<br>
parameter: source file HelloWorldProgramOutput.x3d filesize 20956 bytes, parsed using Document Object Model (DOM) X3DLoader<br>
parameter: "-tojs" for conversion to X3DJSONLD JavaScript source<br>
parameter: "-toFile" "nashorn/examples/HelloWorldProgramOutput.Nashorn.js" for result file name root nashorn/examples/HelloWorldProgramOutput.Nashorn<br>
convert to JS JavaScript:<br>
Warning: toFileJavaScript() is overwriting prior file nashorn/examples/HelloWorldProgramOutput.Nashorn.js<br>
Script DEF=colorTypeConversionScript contains CDATA source-code text, copied as "#sourceText" using "strings" mode<br>
Script DEF=MaterialModulatorScript contains CDATA source-code text, copied as "#sourceText" using "strings" mode<br>
TypeError: input.readAllBytes is not a function<br>
Error: Cannot read file [E:\x3d-code\<a href="http://www.web3d.org" rel="noreferrer noreferrer" target="_blank">www.web3d.org</a>\x3d\stylesheets\java\nashorn\node_modules\xmldom\package.json]:<br>
[Error] TODO problem handling local exception within CommandLine, exiting<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>
        at org.web3d.x3d.jsail.Core.X3DObject.toFileJavaScript(X3DObject.java:1662)<br>
        at org.web3d.x3d.jsail.CommandLine.run(CommandLine.java:628)<br>
        at org.web3d.x3d.jsail.CommandLine.main(CommandLine.java:163)<br>
parameter: source file HelloWorldProgramOutput.x3d filesize 20956 bytes, parsed using Document Object Model (DOM) X3DLoader<br>
parameter: "-toJSON" for conversion to JSON encoding<br>
parameter: "-toFile" "nashorn/examples/HelloWorldProgramOutput.Java.json" for result file name root nashorn/examples/HelloWorldProgramOutput.Java<br>
convert to JSON:<br>
Warning: toFileStylesheetConversion(X3dToJson.xslt) is overwriting prior file nashorn/examples/HelloWorldProgramOutput.Java.json<br>
Script DEF=colorTypeConversionScript contains CDATA source-code text, copied as "#sourceText" using "strings" mode<br>
Script DEF=MaterialModulatorScript contains CDATA source-code text, copied as "#sourceText" using "strings" mode<br>
file conversion successful: HelloWorldProgramOutput.Java.json (39749 bytes)<br>
parameter: source file HelloWorldProgramOutput.x3d filesize 20956 bytes, parsed using Document Object Model (DOM) X3DLoader<br>
parameter: "-toX3D" for conversion to X3D encoding<br>
parameter: "-toFile" "nashorn/examples/HelloWorldProgramOutput.Java.x3d" for result file name root nashorn/examples/HelloWorldProgramOutput.Java<br>
convert to X3D:<br>
Warning: toFileX3D() is overwriting prior file nashorn/examples/HelloWorldProgramOutput.Java.x3d<br>
file conversion successful: HelloWorldProgramOutput.Java.x3d (20956 bytes)<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>
     var input;<br>
     try {<br>
       if (core) {<br>
         var classloader = java.lang.Thread.currentThread().getContextClassLoader();<br>
         input = classloader.getResourceAsStream(filename);<br>
       } else {<br>
        input = new java.io.FileInputStream(filename);<br>
       }<br>
       return new java.lang.String(input.readAllBytes());<br>
     } catch (e) {<br>
       System.err.println(e);<br>
       throw new ModuleError('Cannot read file [' + filename + ']: ', 'IO_ERROR', e);<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 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>
        <a href="https://stackoverflow.com/questions/858980/file-to-byte-in-java" rel="noreferrer 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>
>       [exec] java.lang.ClassCastException: org.web3d.x3d.jsail.Navigation.ViewpointGroupObject cannot be cast to org.web3d.x3d.sai.Grouping.X3DGroupingNode<br>
> <br>
>       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:1146)<br>
> <br>
>       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:542)<br>
> <br>
>       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:542)<br>
> <br>
>       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:430)<br>
> <br>
>       [exec]     at org.web3d.x3d.jsail.X3DLoaderObject.toX3dObjectTree(X3DLoaderObject.java:399)<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>
>       [exec]     at jdk.scripting.nashorn/jdk.nashorn.internal.runtime.ScriptFunctionData.invoke(ScriptFunctionData.java:655)<br>
> <br>
>       [exec]     at jdk.scripting.nashorn/jdk.nashorn.internal.runtime.ScriptFunction.invoke(ScriptFunction.java:513)<br>
> <br>
>       [exec]     at jdk.scripting.nashorn/jdk.nashorn.internal.runtime.ScriptRuntime.apply(ScriptRuntime.java:527)<br>
> <br>
>       [exec]     at jdk.scripting.nashorn/jdk.nashorn.tools.Shell.apply(Shell.java:519)<br>
> <br>
>       [exec]     at jdk.scripting.nashorn/jdk.nashorn.tools.Shell.runScripts(Shell.java:448)<br>
> <br>
>       [exec]     at jdk.scripting.nashorn/jdk.nashorn.tools.Shell.run(Shell.java:186)<br>
> <br>
>       [exec]     at jdk.scripting.nashorn.shell/jdk.nashorn.tools.jjs.Main.main(Main.java:104)<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>
<br>
all the best, Don<br>
-- <br>
Don Brutzman  Naval Postgraduate School, Code USW/Br       <a href="mailto:brutzman@nps.edu" target="_blank" rel="noreferrer">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 noreferrer" target="_blank">http://faculty.nps.edu/brutzman</a><br>
<br>
</blockquote></div>