<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;}
@font-face
        {font-family:inherit;}
/* 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;}
pre
        {mso-style-priority:99;
        mso-style-link:"HTML Preformatted Char";
        margin:0in;
        margin-bottom:.0001pt;
        font-size:10.0pt;
        font-family:"inherit",serif;}
span.HTMLPreformattedChar
        {mso-style-name:"HTML Preformatted Char";
        mso-style-priority:99;
        mso-style-link:"HTML Preformatted";
        font-family:"inherit",serif;}
span.od
        {mso-style-name:od;}
span.ev
        {mso-style-name:ev;}
.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>Not sure if you’ll find this useful or not.  Creates a python dict from ElementTree/XML.  Might there be an dict to XML or JSON converter?</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I’m thinking there is, but I am unwilling to do a search at this time.  May get to it in a couple of hours.  Stiff.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>John</p><p class=MsoNormal><o:p> </o:p></p><div><table class=MsoNormalTable border=0 cellspacing=0 cellpadding=0><tr><td style='padding:0in 0in 0in 0in'><div style='border:solid windowtext 1.0pt;padding:1.0pt 1.0pt 1.0pt 1.0pt' id=vt100><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>from pprint import pprint                                                       </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>from xml.etree import ElementTree as ET                                         </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>from collections import defaultdict                                             </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>                                                                                </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'># code is from                                                                  </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'># https://stackoverflow.com/questions/7684333/converting-xml-to-dictionary-using</span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>-elementtree                                                                    </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'># licensed as Creative Commons with Attribution per stackoverflow license.      </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>                                                                                </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>def etree_to_dict(t):                                                           </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>    d = {t.tag: {} if t.attrib else None}                                       </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>    children = list(t)                                                          </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>    if children:                                                                </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>        dd = defaultdict(list)                                                  </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>        for dc in map(etree_to_dict, children):                                 </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>            for k, v in dc.items():                                             </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>                dd[k].append(v)                                                 </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>        d = {t.tag: {k: v[0] if len(v) == 1 else v                              </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>                     for k, v in dd.items()}}                                   </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>    if t.attrib:                                                                </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>        d[t.tag].update(('@' + k, v)                                            </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>                        for k, v in t.attrib.items())                           </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>    if t.text:                                                                  </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>        text = t.text.strip()                                                   </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>        if children or t.attrib:                                                </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>            if text:                                                            </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>              d[t.tag]['#text'] = text                                          </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>        else:                                                                   </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>            d[t.tag] = text                                                     </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>    return d                                                                    </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>                                                                                </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>tree = ET.parse("../data/HelloWorld.x3d")                                       </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>root = tree.getroot()                                                           </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>xmlstr = ET.tostring(root, encoding='utf8', method='xml')                       </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>e = ET.XML(xmlstr)                                                              </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=ev><span style='color:#BFBFBF'>d = etree_to_dict(e)                                                            </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre><pre style='line-height:111%;background:black'><span class=od><span style='color:#BFBFBF'>print(d) # use pprint as alternative                                            </span></span><span style='color:#BFBFBF'><o:p></o:p></span></pre></div></td></tr></table></div><p class=MsoNormal><o:p> </o:p></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">Brutzman, Donald (Don) (CIV)</a><br><b>Sent: </b>Tuesday, August 20, 2019 10:01 AM<br><b>To: </b><a href="mailto:andreasplesch@gmail.com">Andreas Plesch</a>; <a href="mailto:yottzumm@gmail.com">John Carlson</a><br><b>Cc: </b><a href="mailto:x3d-public@web3d.org">X3D Graphics public mailing list</a><br><b>Subject: </b>Re: [x3d-public] Python X3D package synopsis, TODO items</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Your assessment is correct.  Export methods are needed.  Will work on it, might take a week or two.  Thanks for the priority.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The implementation will likely perform depth-first traversal of the scene graph, so it will be integral to the design pattern.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I will add .x3d validation of serialization outputs to the build script so that we have a high level of Quality Assurance (QA) for this functionality.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Already doing toX3D, toClassicVRML, toVRML97() and toHtmlX3dom/toHtmlX_ITE in X3DJSAIL, will be taking a similar approach in X3DJSAIL.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Just updated the TODO list, further requests welcome.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                Python X3D Package x3d.py: TODO</p><p class=MsoNormal>                https://www.web3d.org/x3d/stylesheets/python/python.html#TODO</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Have fun with Python X3D!   8)</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 8/19/2019 1:14 PM, Andreas Plesch wrote:</p><p class=MsoNormal>>  From what I understand, it is possible to construct a full, in memory representation of an X3D scenegraph with x3d.py. It may also be possible to modify an existing, in memory Python representation using x3d.py. Since renderers/browsers only understand vrml/x3d encodings, I am looking for a method to serialize the Python x3d.py in memory representation. The Pyjnius based Python encoding had such a method but I cannot find anything for x3d.py. Is there way to generate xml from a x3d.py constructed scene ?</p><p class=MsoNormal>> </p><p class=MsoNormal>> Thanks, Andreas</p><p class=MsoNormal>> </p><p class=MsoNormal>> </p><p class=MsoNormal>>     Date: Thu, 15 Aug 2019 07:03:31 +0000</p><p class=MsoNormal>>     From: "Brutzman, Donald (Don) (CIV)" <brutzman@nps.edu <mailto:brutzman@nps.edu>></p><p class=MsoNormal>>     To: John Carlson <yottzumm@gmail.com <mailto:yottzumm@gmail.com>></p><p class=MsoNormal>>     Cc: X3D Graphics public mailing list <x3d-public@web3d.org <mailto:x3d-public@web3d.org>></p><p class=MsoNormal>>     Subject: Re: [x3d-public] Possible new method suggester service based</p><p class=MsoNormal>>              on X3DUOM; Python X3D package synopsis</p><p class=MsoNormal>>     Message-ID: <9ab68137-764a-a81a-0868-6bee9b49893c@nps.edu <mailto:9ab68137-764a-a81a-0868-6bee9b49893c@nps.edu>></p><p class=MsoNormal>>     Content-Type: text/plain; charset="utf-8"</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Hi John.  Yes this diversity of mapToMethod copies has made things a bit confusing, not least of which are the obscure names themselves.  If recalling correctly, I believe that the "mapToMethod" sources were a key part of our herculean only-80%-successful Pyjnius attempts to implement an X3D Python implementation in Java.</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Meanwhile together with Loren Peitso I've implemented a full Python X3D package in python, x3d.py, that is much more pythonic and applies a design that abandoned all overtones of prior java/javascript APIs for X3D.   It is generated from X3DUOM and has fairly thorough smoke tests. Have also written a new X3dToPython.xslt spreadsheet which turned out to be pretty easy to adapt.  Python is quite strict, which is also good.  This has been applied to full X3D Examples Archives to good effect, the vast majority self-validate satisfactorily. So, if it survives upcoming scrutiny, we might be back on the playing field aiming for wide deployment and usage of X3D Python.</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Recent X3DUOM work added "field" and "IS" to X3DUOM and X3D XML Schema, which was relatively straightforward and sensible.  However that took several weeks of refactoring for X3DJSAIL to cope with, that was deployed during the past week.  All Java smoke tests again pass.</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Current deployed Python X3D package x3d.py build is 0.0.2 and trying to finish deployment of 0.0.3 to PyPi.  Will pst report multiple X3DUOM/X3DJSAIL/X3D Schema/X3D Ontology updates when that finishes, fingers crossed, hopefully this week.  You now have most details in this message; current workload here remains immense so i will be staying relatively quiet while working over next few weeks.</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Links:</p><p class=MsoNormal>> </p><p class=MsoNormal>>     https://www.web3d.org/x3d/content/examples/X3dResources.html#Programming</p><p class=MsoNormal>>     https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/stylesheets/build.xml</p><p class=MsoNormal>>     https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/stylesheets/X3dToPython.xslt</p><p class=MsoNormal>>     https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/stylesheets/X3duomToX3dPythonPackage.xslt</p><p class=MsoNormal>> </p><p class=MsoNormal>>     https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/stylesheets/python/</p><p class=MsoNormal>>     https://sourceforge.net/p/x3d/code/HEAD/tree/www.web3d.org/x3d/stylesheets/python/x3d.py</p><p class=MsoNormal>>     https://pypi.org/project/x3d</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Apologies for relative quietness on all this work - certainly not a secret but recent months have been way busy... most of this was announced on x3d-public and in slideset in time for Web3D 2019 and SIGGRAPH 2019 conferences.  Small incremental progress continuing.</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Effective PyPi distribution can eventually lead to Anaconda and Jupyter Notebook distributions too, so there will be no shortage of future Python X3D work to pursue!</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Please start looking it over when possible.  Will also be discussing in Japan with Masaki Aono at upcoming ISO SC224 meeting for X3D-related specifications.  At recent SIGGRAPH meeting of Web3D Korea Chapter, Myeong Won Lee also demoed a native Python X3D player, that would certainly be interesting to align and bundle together if appropriate.</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Suggested path forward for the next month:  as the release unfolds, let's review closely and do a lot more README activity, and then work on making this pure-python candidate answer requirements as best possible.  Your list below can certainly help.</p><p class=MsoNormal>> </p><p class=MsoNormal>>     When time permits, for thoroughness we can also see how prior work on pynius/nashorn/etc. efforts can be aligned or settled in an archival status.  there is a lot of goodness in that work we did, hopefully we can at least document that for potential further progress someday.  if nothing else certainly there are more Python X3D alternatives to compare now.  We'll see.</p><p class=MsoNormal>> </p><p class=MsoNormal>>     p.s. am noticing warnings in current Java 12 build outputs that say jjs may get moved in future releases.  Rust never sleeps...</p><p class=MsoNormal>> </p><p class=MsoNormal>>     Hope all this helps.  Thanks for all efforts to get this far, onward we go together.  Have fun with X3D!  8)</p><p class=MsoNormal>> </p><p class=MsoNormal>> </p><p class=MsoNormal>>     On 8/12/2019 12:13 PM, John Carlson wrote:</p><p class=MsoNormal>>      > I have discovered I have **many** mapToMethod2.js spread all over the place on sourceforge, GitHub, etc.</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > Can we create a service for providing the contents of mapToMethod.js and mapToMethod2.js served up as an interweaved JSON object?</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > I suggest working on the java/nashorn branch to provide this on a JavaScript server using node.js and/or php.? Does anyone want to be maintainer of the server? We can deploy to Heroku as an example.</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > I have many setIS moved to mapToMethod.js from mapToMethod2.js.? Many things need to be retested.</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > I noticed that http was replaced in many places with https (not a problem that I know of).</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > Once we fix mapToMethod*.js, we can move to fieldTypes.js.</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > Steps:</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      >  1. Define use cases/user stories</p><p class=MsoNormal>>      >  2. Design and Document API</p><p class=MsoNormal>>      >  3. Implement reference implementation</p><p class=MsoNormal>>      >  4. Test reference implementation</p><p class=MsoNormal>>      >  5. Rewrite clients to use services</p><p class=MsoNormal>>      >  6. Test clients</p><p class=MsoNormal>>      >  7. Deploy to production node.js and php servers.</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > I need help with 1 and 2.</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > Is there an easier way to accomplish maintain a single master?</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > Thanks,</p><p class=MsoNormal>>      ></p><p class=MsoNormal>>      > John</p><p class=MsoNormal>> </p><p class=MsoNormal>> Andreas Plesch</p><p class=MsoNormal>> Waltham, MA 02453</p><p class=MsoNormal>> </p><p class=MsoNormal>> _______________________________________________</p><p class=MsoNormal>> x3d-public mailing list</p><p class=MsoNormal>> x3d-public@web3d.org</p><p class=MsoNormal>> http://web3d.org/mailman/listinfo/x3d-public_web3d.org</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>