<div dir="auto"><div>I've played with x3dom templating on my JSON demons editor learning project, but not for imports or inlines.  json-templates looks interesting to provide transformation.   Hmm. What to work on next?  I don't really want to give up the Python SAI, but fixing 3800 scripts just isn't attractive on a Linux virtual machine.   I may try to find a Python to Java bridge that runs on Windows.<br><div class="gmail_extra"><br><div class="gmail_quote">On Dec 4, 2016 7:16 PM, "Andreas Plesch" <<a href="mailto:andreasplesch@gmail.com">andreasplesch@gmail.com</a>> wrote:<br type="attribution"><blockquote class="quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div><div>Hi John,<br><br></div>not sure if I can help much with a script node for x3dom but x3dom is the by far more used, known and real world tested browser. It also has a lot of advanced functionality outside of the spec. Even the flash renderer was still considered valuable not too long ago. So not obsolete at all although there should be less need for a script node for x3dom with cobweb also available. To me it would be more interesting to explore for example DOM templating as a prototyping mechanism or HTML Imports for inlines. json templating  <a href="https://github.com/datavis-tech/json-templates" target="_blank">https://github.com/datavis-<wbr>tech/json-templates</a> could be fun.<br><br></div>Cobweb is fun to work with since it is very conforming and a great piece of engineering. It just fills another niche than x3dom.<font color="#888888"><br><br></font></div><font color="#888888">-Andreas<br><div><div><br></div></div></font></div><div class="elided-text"><div class="gmail_extra"><br><div class="gmail_quote">On Sun, Dec 4, 2016 at 5:40 PM,  <span dir="ltr"><<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div link="blue" vlink="#954F72" lang="EN-US"><div class="m_-8429209383292808130m_-7820136945112256218WordSection1"><p class="MsoNormal">Thanks, clever.  Thanks for the pull request <span style="font-family:"Segoe UI Emoji",sans-serif">😊</span>.  Now we’ve got scripts working for JSON/XML and JSON/DOM for Cobweb in the X3D JSON Loader (see gears.json in the loader).  Next, do we want to attempt to get scripts working for X3DOM?  See my attempt at X3DJSONLD/Script.js.  My unfamiliarity with the X3D event model is showing.  Or is X3DOM deprecated now?</p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">John </p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Sent from <a href="https://go.microsoft.com/fwlink/?LinkId=550986" target="_blank">Mail</a> for Windows 10</p><p class="MsoNormal"><u></u> <u></u></p><div style="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:andreasplesch@gmail.com" target="_blank">Andreas Plesch</a><br><b>Sent: </b>Sunday, December 4, 2016 5:01 PM<br><b>To: </b><a href="mailto:yottzumm@gmail.com" target="_blank">John Carlson</a><br><b>Cc: </b><a href="mailto:x3d-public@web3d.org" target="_blank">X3D Graphics public mailing list</a>; <a href="mailto:roy.walmsley@ntlworld.com" target="_blank">Roy Walmsley</a>; <a href="mailto:brutzman@nps.edu" target="_blank">Don Brutzman</a><br><b>Subject: </b>Re: loading DOM VRML Script. Cobweb enhancement?</p></div><p class="MsoNormal"><u></u> <u></u></p><div><div><div><div><div><div><p class="MsoNormal" style="margin-bottom:12.0pt">Hi John,</p></div><p class="MsoNormal" style="margin-bottom:12.0pt">So I took the next step and used the DOMParser method to produce a CDATASection for html documents in my cdata branch:<br><br><a href="https://github.com/andreasplesch/X3DJSONLD/blob/cdata/X3DJSONLD.js#L224" target="_blank">https://github.com/andreasples<wbr>ch/X3DJSONLD/blob/cdata/<wbr>X3DJSONLD.js#L224</a></p></div><p class="MsoNormal" style="margin-bottom:12.0pt">Using this method the script in the example work for both html and xhtml:<br><br><a href="https://rawgit.com/andreasplesch/X3DJSONLD/cdata/AP_minimal_JSLD.html" target="_blank">https://rawgit.com/andreasples<wbr>ch/X3DJSONLD/cdata/AP_minimal_<wbr>JSLD.html</a><br><a href="https://rawgit.com/andreasplesch/X3DJSONLD/cdata/AP_minimal_JSLD.xhtml" target="_blank">https://rawgit.com/andreasples<wbr>ch/X3DJSONLD/cdata/AP_minimal_<wbr>JSLD.xhtml</a></p></div><p class="MsoNormal" style="margin-bottom:12.0pt">in cobweb.</p></div><p class="MsoNormal" style="margin-bottom:12.0pt">Cobweb expects to see a CDATASection node. It ignores all text nodes. This is reasonable since using a cdata section is strongly recommended in the x3d encoding spec.</p></div><p class="MsoNormal" style="margin-bottom:12.0pt">I issued a PR in case you are interested in adopting this:</p><div><div><div><div><div><p class="MsoNormal" style="margin-bottom:12.0pt"><a href="https://github.com/coderextreme/X3DJSONLD/pull/4" target="_blank">https://github.com/coderextrem<wbr>e/X3DJSONLD/pull/4</a></p></div><div><p class="MsoNormal">-Andreas</p></div><div><p class="MsoNormal"><u></u> <u></u></p></div></div></div></div></div></div><div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">On Sun, Dec 4, 2016 at 3:42 PM, Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>> wrote:</p><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in"><div><div><div><div><p class="MsoNormal" style="margin-bottom:12.0pt">Hi John,</p></div><p class="MsoNormal" style="margin-bottom:12.0pt">I saw that you already tried createCDATASection but commented that perhaps because it did not work for html. I reenabled createCDATASection here:<br><br><a href="https://github.com/andreasplesch/X3DJSONLD/blob/master/X3DJSONLD.js#L235" target="_blank">https://github.com/andreasples<wbr>ch/X3DJSONLD/blob/master/<wbr>X3DJSONLD.js#L235</a></p></div><p class="MsoNormal" style="margin-bottom:12.0pt">and with that change the simple script example works (!) in an xhtml document:<br><br><a href="https://rawgit.com/andreasplesch/X3DJSONLD/master/AP_minimal_JSLD.xhtml" target="_blank">https://rawgit.com/andreasples<wbr>ch/X3DJSONLD/master/AP_<wbr>minimal_JSLD.xhtml</a></p></div><p class="MsoNormal">-Andreas</p><div><div><p class="MsoNormal"><u></u> <u></u></p></div></div></div><div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">On Sun, Dec 4, 2016 at 3:31 PM, Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>> wrote:</p><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in"><div><div><div><p class="MsoNormal" style="margin-bottom:12.0pt">Hi John,</p></div><p class="MsoNormal" style="margin-bottom:12.0pt">I looked at the <a href="http://www.web3d.org/x3d/content/examples/Basic/ScriptConformance/TouchSensorIsOverEventECMAScript.json" target="_blank">http://www.web3d.org/x3d/conte<wbr>nt/examples/Basic/ScriptConfor<wbr>mance/TouchSensorIsOverEventEC<wbr>MAScript.json</a> example.</p></div><p class="MsoNormal">The problem is that X3DJSONLD turns the script node into a DOM node with correct field node children but the script text is contained in raw text nodes:</p><div><div><div><p class="MsoNormal"><br><field><br><field></p><div><p class="MsoNormal" style="margin-bottom:12.0pt">#text "<![CDATA["<br>#text "ecmascript:function isOver(val) {     if (val == true)     {         diffuseColor_changed = new SFColor(1,0,0);     }     else     {         diffuseColor_changed = new SFColor(0,0,1);    }}"<br>#text "]]>"</p></div><div><p class="MsoNormal">The script text should be contained in the nodeValue/textContent of a CDATASection :</p></div><div><p class="MsoNormal" style="margin-bottom:12.0pt"><br><field><br><field><br>CDATASection nodeValue=textContent="ecmascr<wbr>ipt:function isOver(val) {     if (val == true)     {         diffuseColor_changed = new SFColor(1,0,0);     }     else     {         diffuseColor_changed = new SFColor(0,0,1);    }}"<br><br><a href="https://developer.mozilla.org/en-US/docs/Web/API/Document/createCDATASection" target="_blank">https://developer.mozilla.org/<wbr>en-US/docs/Web/API/Document/cr<wbr>eateCDATASection</a></p></div><div><p class="MsoNormal" style="margin-bottom:12.0pt">However, createCDATASection only works with xhtml.</p></div><div><p class="MsoNormal" style="margin-bottom:12.0pt">I am sneaking a CDATASection into a html document using DOMParser in xml mode here:<br><br><a href="https://github.com/andreasplesch/cobweb_dom/blob/master/cobweb/cobweb_dom.js#L34" target="_blank">https://github.com/andreasples<wbr>ch/cobweb_dom/blob/master/<wbr>cobweb/cobweb_dom.js#L34</a></p></div><div><p class="MsoNormal" style="margin-bottom:12.0pt">I think DOMParser.parseFromString("<![<wbr>CDATA[ scripttext using > and < ]]>", <span class="m_-8429209383292808130m_-7820136945112256218m-2059514568631322761m-7590909182361465553gmail-pl-pds">'</span><span class="m_-8429209383292808130m_-7820136945112256218m-2059514568631322761m-7590909182361465553gmail-pl-s">application/xml</span><span class="m_-8429209383292808130m_-7820136945112256218m-2059514568631322761m-7590909182361465553gmail-pl-pds">'</span>); should return a document with a single cdatasection node which then can be appended to the script node.<br><br><a href="https://github.com/coderextreme/X3DJSONLD/blob/master/X3DJSONLD.js#L224" target="_blank">https://github.com/coderextrem<wbr>e/X3DJSONLD/blob/master/<wbr>X3DJSONLD.js#L224</a></p></div><div><p class="MsoNormal">looks like the function where an actual CDATASection node needs to be created instead of raw text nodes.</p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal" style="margin-bottom:12.0pt">Hope this helps,</p></div><div><p class="MsoNormal">Andreas</p></div><div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">On Sun, Dec 4, 2016 at 1:42 PM, Andreas Plesch <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>> wrote:</p><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in"><div><p>Hi John,</p><p>X3dom is designed to work with the XML encoding or a dom. So for x3dom it would be necessary to first create a DOM from the json. It will be difficult to get around that.</p><p>Cobweb has parsers which parse XML or vrml into a scene graph. So it should be possible to make a parser for json, probably following what the XML parser does. But the easier path would be also to create a DOM from the json first.</p><p>How do you envision you or others would use json encoded x3d content to add value to a project ? Easier manipulation as a js object ? Easier programmatic content creation ? As an exchange/transmission format, a bit similar to gltf ?</p><p><u></u> <u></u></p><p><a href="http://www.web3d.org/x3d/content/examples/Basic/ScriptConformance/" target="_blank">http://www.web3d.org/x3d/conte<wbr>nt/examples/Basic/ScriptConfor<wbr>mance/</a></p><p>has good examples to test scripting. For example,</p><p><a href="http://www.web3d.org/x3d/content/examples/Basic/ScriptConformance/TouchSensorIsOverEventECMAScriptIndex.html" target="_blank">http://www.web3d.org/x3d/conte<wbr>nt/examples/Basic/ScriptConfor<wbr>mance/TouchSensorIsOverEventEC<wbr>MAScriptIndex.html</a></p><p><a href="http://www.web3d.org/x3d/content/examples/Basic/ScriptConformance/TouchSensorIsOverEventECMAScript.json" target="_blank">http://www.web3d.org/x3d/conte<wbr>nt/examples/Basic/ScriptConfor<wbr>mance/TouchSensorIsOverEventEC<wbr>MAScript.json</a></p><p>I may give this example a try with the json loader and cobweb.</p><p>-Andreas</p><div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">On Dec 4, 2016 1:49 AM, "John Carlson" <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> wrote:</p><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in"><p>Perhaps it's time for me to dig into Cobweb and X3DOM to see how they can be extended to support JSON?  If it's through DOM, which is fine by me, I would have to look and see how the various encodings are loaded after DOM is loaded.</p><div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">On Dec 4, 2016 1:40 AM, "John Carlson" <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> wrote:</p><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in"><p>Again, the X3D JSON Loader is a proof of concept patch until we get full JSON support in Cobweb and X3DOM, if desired.</p><div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">On Dec 4, 2016 1:24 AM, "John Carlson" <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> wrote:</p><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in"><p>Because I may not have the full x3d examples downloaded.   And I do want to test to see if JSON inclusion works.</p><div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">On Dec 2, 2016 3:04 PM, "Andreas Plesch" <<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>> wrote:</p><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in"><div><p class="MsoNormal">Hi John,</p><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">I tried a bit to load gears.json with X3DJSONLD:</p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal"><a href="https://raw.githubusercontent.com/andreasplesch/X3DJSONLD/master/AP_minimal_JSLD.html" target="_blank">https://raw.githubusercontent.<wbr>com/andreasplesch/X3DJSONLD/ma<wbr>ster/AP_minimal_JSLD.html</a></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">But even before any script parsing/loading, there is a problem with the ExternProtoDeclare node in gears.json. It has a url field to Rotor.x3d which is replaced by the json loader with Rotor.json before being handed off to cobweb with importDocument(). Cobweb does not know what to do with the Rotor.json file and gives up.</p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Why modify the url field value ? If the scene author wants to use a .json encoded scene, she will put it in  the url field just like a .wrl encoded scene.</p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">On another note, I agree that eval() cannot be avoided if script should be supported. cobweb itself also uses eval() (after some setup and massaging) to run the x3d script.</p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">type="application/x-vrmlscript<wbr>" is necessary because without it the web browser will try to run the script "as is" as soon as it gets appended to the page DOM. When cobweb gets a chance to check for the type attribute, it is already too late. So it cannot use the attribute to prevent it from running. It can only not reject it which is what it does.</p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">-Andreas</p></div><div><p class="MsoNormal"><u></u> <u></u></p></div></div><div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">On Thu, Dec 1, 2016 at 1:02 AM, <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> wrote:</p><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in"><div><div><p class="MsoNormal">It appears that Cobweb is fouled up with DOM loading of scripts, even with the additional name value pair.  See gears.x3d/gears.json and load DOM through importDocument.  And independent test would help.  I am not sure which of my X3DCanvases gets loaded first and I am using absolute indexing, so it could be the XML loaded one that is failing.  Basically, we need a good way to load scripts coming in through JSON I think, and the only real way I know how to do it is eval or cobweb with JSON to XML conversion and VRMLscript.  If Cobweb could use the VRMLscript from JSON or DOM, that might be ideal.</p><p class="MsoNormal"> </p><p class="MsoNormal">This is with cobweb 2.4.</p><p class="MsoNormal"> </p><p class="MsoNormal">John</p><p class="MsoNormal"> </p><p class="MsoNormal">Sent from <a href="https://go.microsoft.com/fwlink/?LinkId=550986" target="_blank">Mail</a> for Windows 10</p><p class="MsoNormal"> <u></u><u></u></p><div style="border:none;border-top:solid windowtext 1.0pt;padding:3.0pt 0in 0in 0in;border-color:-moz-use-text-color -moz-use-text-color"><p class="MsoNormal"><b>From: </b><a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a><br><b>Sent: </b>Thursday, December 1, 2016 12:32 AM<br><b>To: </b><a href="mailto:andreasplesch@gmail.com" target="_blank">Andreas Plesch</a>; <a href="mailto:brutzman@nps.edu" target="_blank">Don Brutzman</a>; <a href="mailto:roy.walmsley@ntlworld.com" target="_blank">Roy Walmsley</a><br><b>Subject: </b>FW: loading X3D DOM. Latest Cobweb techniques?</p></div><p class="MsoNormal"> </p><p class="MsoNormal">Would it be possible to get a name/value of  </p><p class="MsoNormal"> </p><p class="MsoNormal">"@<span class="m_-8429209383292808130m_-7820136945112256218m-2059514568631322761m-7590909182361465553gmail-m-1818107344132003502gmail-m6814112949669356284m7174440674528929433m-637341298042191590m4670831100320161873m3334206258020055149m-8313888796625588714html-attribute-name"><span style="font-size:13.5pt;font-family:"Courier New"">type"</span></span><span style="font-size:13.5pt;font-family:"Courier New";color:#881280"> : "</span><span class="m_-8429209383292808130m_-7820136945112256218m-2059514568631322761m-7590909182361465553gmail-m-1818107344132003502gmail-m6814112949669356284m7174440674528929433m-637341298042191590m4670831100320161873m3334206258020055149m-8313888796625588714html-attribute-value"><span style="font-size:13.5pt;font-family:"Courier New"">application/x-vrmlscript"</span></span></p><p class="MsoNormal"><span style="font-size:13.5pt;font-family:"Courier New";color:#881280"> </span></p><p class="MsoNormal"><span style="font-size:13.5pt;font-family:"Courier New";color:#881280">On the Script tag in X3D JSON?  I will do some testing here first to see if it will help.</span></p><p class="MsoNormal"><span style="font-size:13.5pt;font-family:"Courier New";color:#881280"> </span></p><p class="MsoNormal"><span style="font-size:13.5pt;font-family:"Courier New";color:#881280">John</span></p><p class="MsoNormal"> </p><div style="border:none;border-top:solid windowtext 1.0pt;padding:3.0pt 0in 0in 0in;border-color:-moz-use-text-color -moz-use-text-color"><p class="MsoNormal"><b>From: </b><a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a><br><b>Sent: </b>Thursday, December 1, 2016 12:24 AM<br><b>To: </b><a href="mailto:andreasplesch@gmail.com" target="_blank">Andreas Plesch</a><br><b>Subject: </b>RE: loading X3D DOM. Latest Cobweb techniques?</p></div><p class="MsoNormal"> </p><p class="MsoNormal">One thing I noticed once I got both DOM and XML views loaded, was that I think the DOM VRML script tag was disabled, but the XML one worked.  Was there some attribute to add to the Script tag to make it work?  Can I add it in both XML and DOM?  Thanks, John  I will start email search.</p><p class="MsoNormal"> </p><p class="MsoNormal"> </p><p class="MsoNormal"> </p></div></div></blockquote></div><p class="MsoNormal"><br><br clear="all"><span class="m_-8429209383292808130m_-7820136945112256218m-2059514568631322761m-7590909182361465553gmail-hoenzb"><span style="color:#888888"><u></u><u></u></span></span></p><div><p class="MsoNormal"><u></u> <u></u></p></div><p class="MsoNormal"><span class="m_-8429209383292808130m_-7820136945112256218m-2059514568631322761m-7590909182361465553gmail-hoenzb"><span style="color:#888888">-- </span><u></u><u></u></span></p><div><p class="MsoNormal"><span style="color:#888888">Andreas Plesch<br>39 Barbara Rd.<br>Waltham, MA 02453</span></p></div></div></blockquote></div></div></blockquote></div></div></blockquote></div></div></blockquote></div></div></div></blockquote></div><p class="MsoNormal"><span style="color:#888888"><br><br clear="all"><br><span class="m_-8429209383292808130m_-7820136945112256218hoenzb">-- </span></span><span class="m_-8429209383292808130m_-7820136945112256218hoenzb"><u></u><u></u></span></p><div><p class="MsoNormal"><span style="color:#888888">Andreas Plesch<br>39 Barbara Rd.<br>Waltham, MA 02453</span></p></div></div></div></div></div></div></blockquote></div><p class="MsoNormal"><span style="color:#888888"><br><br clear="all"><br><span class="m_-8429209383292808130m_-7820136945112256218hoenzb">-- </span></span><span class="m_-8429209383292808130m_-7820136945112256218hoenzb"><u></u><u></u></span></p><div><p class="MsoNormal"><span style="color:#888888">Andreas Plesch<br>39 Barbara Rd.<br>Waltham, MA 02453</span></p></div></div></blockquote></div><p class="MsoNormal"><br><br clear="all"><br>-- </p></div><p class="MsoNormal">Andreas Plesch<br>39 Barbara Rd.<br>Waltham, MA 02453</p><p class="MsoNormal"><u></u> <u></u></p></div></div></blockquote></div><br><br clear="all"><br>-- <br><div class="m_-8429209383292808130gmail_signature" data-smartmail="gmail_signature">Andreas Plesch<br>39 Barbara Rd.<br>Waltham, MA 02453</div>
</div>
</div></blockquote></div><br></div></div></div>