<div dir="auto">Implementing a fix is trivial in x3djsonld.py following the sample patch.</div><div dir="auto"><br></div><div dir="auto">I am more curious if we could code generate a solution i guess.  I don’t have any bright ideas at this point.</div><div dir="auto"><br></div><div dir="auto">I am hoping for a release of x3djsonld.py in the near term and i may just do some code grinding.</div><div dir="auto"><br></div><div dir="auto">I can also report other issues, I just don’t want to create a blizzard, so one at a time.</div><div dir="auto"><br></div><div dir="auto">Perhaps i can track issues and patches by myself until you are ready.</div><div dir="auto"><br></div><div dir="auto">That sounds more effective.</div><div dir="auto"><br></div><div dir="auto">John</div><div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Jun 13, 2022 at 9:52 AM Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu">brutzman@nps.edu</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;padding-left:1ex;border-left-color:rgb(204,204,204)"><div lang="EN-US" link="blue" vlink="purple" style="word-wrap:break-word"><div><p class="MsoNormal">Initial definitions for a <field> declaration have default type SFString for maximum flexibility of values.<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Author definitions of a <field> declaration (within a Script or ProtoInterface) might well vary, so the library needs to support such author overrides.<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Looking at X3D Examples is always a good approach to see what works.  The build logs for various language conversions are helpfully verbose so that you can see what the baseline versions are doing.<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Have fun with X3D!  8)<u></u><u></u></p><div><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""><u style="font-family:"Courier New""></u> <u style="font-family:"Courier New""></u></span></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">all the best, Don<u style="font-family:"Courier New""></u><u style="font-family:"Courier New""></u></span></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">-- <u style="font-family:"Courier New""></u><u style="font-family:"Courier New""></u></span></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">Don Brutzman  Naval Postgraduate School, Code USW/Br        <a href="mailto:brutzman@nps.edu" target="_blank" style="font-family:"Courier New"">brutzman@nps.edu</a><u style="font-family:"Courier New""></u><u style="font-family:"Courier New""></u></span></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA    +1.831.656.2149<u style="font-family:"Courier New""></u><u style="font-family:"Courier New""></u></span></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">X3D graphics, virtual worlds, Navy robotics https://</span> <span style="font-size:10pt;font-family:"Courier New""><a href="http://faculty.nps.edu/brutzman" target="_blank" style="font-family:"Courier New"">faculty.nps.edu/brutzman</a><u style="font-family:"Courier New""></u><u style="font-family:"Courier New""></u></span></p></div><p class="MsoNormal"><u></u> <u></u></p><div><div style="border-style:solid none none;border-top-width:1pt;padding:3pt 0in 0in;border-top-color:rgb(225,225,225)"><p class="MsoNormal"><b>From:</b> John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> <br><b>Sent:</b> Monday, June 13, 2022 7:09 AM<br><b>To:</b> Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>><br><b>Cc:</b> Peitso, Loren (CIV) <<a href="mailto:lepeitso@nps.edu" target="_blank">lepeitso@nps.edu</a>>; Vincent Marchetti <<a href="mailto:vmarchetti@kshell.com" target="_blank">vmarchetti@kshell.com</a>>; X3D Graphics public mailing list <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br><b>Subject:</b> Re: Python puzzle related to tupleSize in x3djsonld.py<u></u><u></u></p></div></div><p class="MsoNormal"><u></u> <u></u></p><div style="border:1pt solid rgb(0,70,121);padding:2pt"><p class="MsoNormal" style="line-height:12pt;background-color:rgb(0,70,121)"><span style="font-size:10pt;color:yellow">NPS WARNING: *external sender* verify before acting.<u></u><u></u></span></p></div></div></div><div lang="EN-US" link="blue" vlink="purple" style="word-wrap:break-word"><div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal">On Mon, Jun 13, 2022 at 7:59 AM John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> wrote:<u></u><u></u></p></div><blockquote style="border-style:none none none solid;border-left-width:1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in;border-left-color:rgb(204,204,204)"><div><div><p class="MsoNormal">This temporary patch, just for MFVec3f fields, fixed the arc4.py output from x3djsonld.py. <u></u><u></u></p><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">More research is needed for broader issues and figure out if an x3djsonld.py or x3d.py *patch* would be better.<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">$ git diff x3djsonld.py<br>diff --git a/src/main/python/x3djsonld.py b/src/main/python/x3djsonld.py<br>index ac2b7eacf..9d6bfc665 100644<br>--- a/src/main/python/x3djsonld.py<br>+++ b/src/main/python/x3djsonld.py<br>@@ -44,6 +44,8 @@ def parseArray(lead, trail, grandparent, parent, data, indent, fieldType=None):<br>     if fieldType is None:<br>         fieldType = fieldInfo["fieldType"]<br>     tupleSize = fieldInfo["tupleSize"]<br>+    if fieldType == "MFVec3f":<br>+        tupleSize = 3<br>     #if tupleSize > 1:<br>     #    print("'''"+str(fieldType)+" "+grandparent+"."+parent+"["+str(tupleSize)+"]'''", file=sys.stderr)<br>     for d in data:<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Explanations as to why the patch is needed is welcome.  Vince?<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Unpatched code is here:<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal"><a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2Fcoderextreme%2FX3DJSONLD%2Fblob%2Fmaster%2Fsrc%2Fmain%2Fpython%2Fx3djsonld.py&data=05%7C01%7Cbrutzman%40nps.edu%7Cd989f3064a794c20e28908da4d464dd1%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C637907261615365289%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=lfayOhKWKGukuH6obvZWuagQHjwxHAlT%2B9k5z%2F4rE%2FE%3D&reserved=0" target="_blank">X3DJSONLD/x3djsonld.py at master · coderextreme/X3DJSONLD (github.com)</a><u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Data file passed as an argument is here:<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal"><a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2Fcoderextreme%2FX3DJSONLD%2Fblob%2Fmaster%2Fsrc%2Fmain%2Fdata%2Farc4.json&data=05%7C01%7Cbrutzman%40nps.edu%7Cd989f3064a794c20e28908da4d464dd1%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C637907261615365289%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=5TVn5c1SGmH4TbTLFIA2LLrQLZdlttdnK%2BMXpfYuGAc%3D&reserved=0" target="_blank">X3DJSONLD/arc4.json at master · coderextreme/X3DJSONLD (github.com)</a><u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Is it because the value field originally has type SFString?<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">From field statement .value in X3DUOM:<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">            <field name="value"<br>                    type="SFString"<br>                    accessType="inputOutput"<br>                    description="Provide default initialization value for this field variable (which may be re-initialized later by instantiation value of a named ProtoInstance fieldValue)."/><br>            <ContentModel><u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Also, /class field/ in x3d.py has no TUPLE_SIZE method, and value field is<u></u><u></u></p></div><div><p class="MsoNormal">        ('value', '', FieldType.SFString, AccessType.inputOutput, 'field'),<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">confirming the X3DUOM.<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">It looks like I need some metamojo in x3djsonld.py<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">Help!<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">John<u></u><u></u></p></div></div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal">On Mon, Jun 13, 2022 at 7:24 AM John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> wrote:<u></u><u></u></p></div><blockquote style="border-style:none none none solid;border-left-width:1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in;border-left-color:rgb(204,204,204)"><div><div><p class="MsoNormal">This patch fixed it, problem is in x3djsonld.py (not x3d.py that I know of).<u></u><u></u></p></div><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal">diff --git a/src/main/python/net/coderextreme/data/arc4.py b/src/main/python/net/coderextreme/data/arc4.py<br>index bdb08b22b..c7e330572 100644<br>--- a/src/main/python/net/coderextreme/data/arc4.py<br>+++ b/src/main/python/net/coderextreme/data/arc4.py<br>@@ -21,7 +21,7 @@ PositionInterpolator(DEF="DECLpoint_G1_PI1", key=[float(0),float(1)], keyValue=[<br> Script(DEF="DECLpoint_G1_MB1", field=[field(name="translation", accessType="inputOutput", type="SFVec3f", value=(0,0,0)),<br> field(name="old", accessType="inputOutput", type="SFVec3f", value=(0,0,0)),<br> field(name="set_location", accessType="inputOnly", type="SFTime"),<br>-field(name="keyValue", accessType="inputOutput", type="MFVec3f", value=[0,0,0,0,5,0])<br>+field(name="keyValue", accessType="inputOutput", type="MFVec3f", value=[(0,0,0),(0,5,0)])<br> ],<br> #['', 'ecmascript:', '\t\tfunction set_location(value) {', '                    old = translation;', '\t\t    translation = new SFVec3f(Math.random()*10-5, Math.random()*10-5, Math.random()*10-5);', '                    keyValue = new MFVec3f([old, translation]);', '\t\t    // Browser.println(keyValue);', '\t\t}', '', '', '']<br> ),<br>@@ -42,7 +42,7 @@ PositionInterpolator(DEF="DECLpoint_G2_PI1", key=[float(0),float(1)], keyValue=[<br> Script(DEF="DECLpoint_G2_MB1", field=[field(name="translation", accessType="inputOutput", type="SFVec3f", value=(0,0,0)),<br> field(name="old", accessType="inputOutput", type="SFVec3f", value=(0,0,0)),<br> field(name="set_location", accessType="inputOnly", type="SFTime"),<br>-field(name="keyValue", accessType="inputOutput", type="MFVec3f", value=[0,0,0,0,5,0])<br>+field(name="keyValue", accessType="inputOutput", type="MFVec3f", value=[(0,0,0),(0,5,0)])<br> ],<br> #['', 'ecmascript:', '\t\tfunction set_location(value) {', '                    old = translation;', '\t\t    translation = new SFVec3f(Math.random()*10-5, Math.random()*10-5, Math.random()*10-5);', '                    keyValue = new MFVec3f([old, translation]);', '\t\t    // Browser.println(keyValue);', '\t\t}', '', '', '']<br> ),<u></u><u></u></p></div></div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal">On Mon, Jun 13, 2022 at 7:19 AM John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> wrote:<u></u><u></u></p></div><blockquote style="border-style:none none none solid;border-left-width:1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in;border-left-color:rgb(204,204,204)"><div><p class="MsoNormal">Follow-on report, I will look into arc4.py <u></u><u></u></p><div><p class="MsoNormal"><u></u> <u></u></p></div><div><p class="MsoNormal" style="margin-bottom:12pt">python ../python/x3djsonld.py ../data/arc4.json ../python/net/coderextreme/data/arc4.py<br>Traceback (most recent call last):<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 4961, in assertValidMFVec3f<br>    MFVec3f(value)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 9559, in __init__<br>    self.value = value<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 9581, in value<br>    value = [(x, y, z) for x, y, z in value]<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 9581, in <listcomp><br>    value = [(x, y, z) for x, y, z in value]<br>TypeError: cannot unpack non-iterable int object<br><br>The above exception was the direct cause of the following exception:<br><br>Traceback (most recent call last):<br>  File "C:\Users\john\X3DJSONLD\src\main\python\net\coderextreme\data\arc4.py", line 24, in <module><br>    field(name="keyValue", accessType="inputOutput", type="MFVec3f", value=[0,0,0,0,5,0])<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 12272, in __init__<br>    self.value = value<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 12342, in value<br>    assertValidFieldInitializationValue(<a href="https://nam10.safelinks.protection.outlook.com/?url=http%3A%2F%2Fself.name%2F&data=05%7C01%7Cbrutzman%40nps.edu%7Cd989f3064a794c20e28908da4d464dd1%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C637907261615365289%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=U6wkh3VcbgIWUpFTyeRRxNj4%2FY6ceMgqZu8zuAJ%2Bapg%3D&reserved=0" target="_blank">self.name</a>, self.type, value, parent='field/@value')<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 5413, in assertValidFieldInitializationValue<br>    assertValidMFVec3f(value)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 4965, in assertValidMFVec3f<br>    raise X3DTypeError(str(value)[:100] + ' has type ' + str(type(value)) + ' but is not a valid MFVec3f') from error<br>x3d.X3DTypeError: [0, 0, 0, 0, 5, 0] has type <class 'list'> but is not a valid MFVec3f<br>Error: ../python/net/coderextreme/data/arc4.py failed to parse<u></u><u></u></p></div></div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal">On Sun, Jun 12, 2022 at 8:40 PM Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> wrote:<u></u><u></u></p></div><blockquote style="border-style:none none none solid;border-left-width:1pt;padding:0in 0in 0in 6pt;margin-left:4.8pt;margin-right:0in;border-left-color:rgb(204,204,204)"><div><div><p class="MsoNormal">John, thanks for various problem reports and example corrections, very helpful.<u></u><u></u></p><p class="MsoNormal"><br>Am happy to report integration of multiple fixes, and deployment of new version.<u></u><u></u></p><p class="MsoNormal"> <u></u><u></u></p><ol start="1" type="a"><li class="MsoNormal">I eventually figured out how to fix the upgrade to Saxon HE 11.3 not working, which required addition of xmlresolver jar to CLASSPATH entries.  This unblocked many mysterious build problems. Apparently followed a solution path you had figured out too.  Details at<u></u><u></u></li></ol><p class="MsoNormal"> <u></u><u></u></p><ul type="disc"><li class="MsoNormal"><a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fsaxonica.plan.io%2Fboards%2F3%2Ftopics%2F8478%3Fr%3D8480&data=05%7C01%7Cbrutzman%40nps.edu%7Cd989f3064a794c20e28908da4d464dd1%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C637907261615365289%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=LnmBATXNZBfI4XgRo9sUaP%2B3eA1F7MdgZLELCOADngI%3D&reserved=0" target="_blank">https://saxonica.plan.io/boards/3/topics/8478?r=8480</a><u></u><u></u></li><li class="MsoNormal"><a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fsourceforge.net%2Fp%2Fx3d%2Fcode%2F33141&data=05%7C01%7Cbrutzman%40nps.edu%7Cd989f3064a794c20e28908da4d464dd1%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C637907261615365289%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=YrvLo2VaX580ISJgoI2%2B2eZNjNt3xiIJdBAWmEeMbQE%3D&reserved=0" target="_blank">https://sourceforge.net/p/x3d/code/33141</a><u></u><u></u></li></ul><p class="MsoNormal"> <u></u><u></u></p><ol start="2" type="a"><li class="MsoNormal">You correctly reported missing HANIMVERSIONCHOICES and assertValidHanimVersion() in the updated build.  Cause was our recently disallowing HAnim version 1.0 in X3D4 since several internal design issues were incompatible in HAnim 2.0 and thus X3D4.  Thus only HAnim version 2.0 is now allowed.  This was previously fixed in X3D Schema, now also fixed in X3D DTD and X3D Tooltips and X3DUOM.  The generator stylesheet for x3d now included enumeration lists with only one value, restoring these HANIM version constructs.<u></u><u></u></li></ol><ul type="disc"><li class="MsoNormal">Mantis 641: 26.3.2 - HAnim version number restriction<u></u><u></u></li><li class="MsoNormal"><a href="https://www.web3d.org/member-only/mantis/view.php?id=641" target="_blank">https://www.web3d.org/member-only/mantis/view.php?id=641</a><u></u><u></u></li><li class="MsoNormal"><a href="https://www.web3d.org/specifications/X3dDoctypeDocumentation4.0.html#HAnimHumanoid" target="_blank">https://www.web3d.org/specifications/X3dDoctypeDocumentation4.0.html#HAnimHumanoid</a><u></u><u></u></li><li class="MsoNormal"><a href="https://www.web3d.org/specifications/X3dSchemaDocumentation4.0/x3d-4.0_HAnimHumanoid.html#Link45B" target="_blank">https://www.web3d.org/specifications/X3dSchemaDocumentation4.0/x3d-4.0_HAnimHumanoid.html#Link45B</a><u></u><u></u></li><li class="MsoNormal"><a href="https://www.web3d.org/x3d/tooltips/X3dTooltips.html#HAnimHumanoid.version" target="_blank">https://www.web3d.org/x3d/tooltips/X3dTooltips.html#HAnimHumanoid.version</a><u></u><u></u></li></ul><p class="MsoNormal"> <u></u><u></u></p><ol start="3" type="a"><li class="MsoNormal">Also thanks for following report.  The x3d.py problem validating default values for MFVec2f (such as Extrusion crossSection) and other MFVec default values (such as Extrusion spine) is now fixed in the X3DPSAIL autogeneration of x3d.py.  Excerpt follows, hopefully fixing the test cases you have.  I believe such conversions from long arrays to arrays of typed tuples is already working in X3dToJson.xslt conversions, so this resolution improved x3d.py itself.<u></u><u></u></li></ol><ul type="disc"><li class="MsoNormal">class Extrusion(_X3DGeometryNode):<u></u><u></u></li></ul><p>[…]<u></u><u></u></p><p>('crossSection', [(1, 1), (1, -1), (-1, -1), (-1, 1), (1, 1)], FieldType.MFVec2f, AccessType.initializeOnly, 'Extrusion'),<u></u><u></u></p><p>[…]<u></u><u></u></p><p>('spine', [(0, 0, 0), (0, 1, 0)], FieldType.MFVec3f, AccessType.initializeOnly, 'Extrusion'),<u></u><u></u></p><p>[…]<u></u><u></u></p><p>crossSection = [(1, 1), (1, -1), (-1, -1), (-1, 1), (1, 1)] # default<u></u><u></u></p><p>[…]<u></u><u></u></p><p>spine = [(0, 0, 0), (0, 1, 0)] # default<u></u><u></u></p><ul type="disc"><li class="MsoNormal">etc.<u></u><u></u></li></ul><p class="MsoNormal"> <u></u><u></u></p><ol start="4" type="a"><li class="MsoNormal">Not yet announced broadly, pending ISO/IEC confirmation of acceptance, but have changed internal documentation links in X3DUOM and related products for X3D4 Architecture to change from Committee Draft 1 (CD1) to Draft International Specification (DIS).  Note that all of the effective specification prose is functionally identical, and all Mantis-driven changes for 4.0 are resolved.  The only document modification is removal of CSS-styled markings of proposed additions and proposed deletions.<u></u><u></u></li></ol><ul type="disc"><li class="MsoNormal"><a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-CD1/Part01/Architecture.html" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-CD1/Part01/Architecture.html</a><u></u><u></u></li></ul><p class="MsoNormal" style="margin-left:0.5in">to<u></u><u></u></p><ul type="disc"><li class="MsoNormal"><a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-DIS/Part01/Architecture.html" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-DIS/Part01/Architecture.html</a><u></u><u></u></li></ul><p class="MsoNormal"> <u></u><u></u></p><ol start="5" type="a"><li class="MsoNormal">Pylint log still reports some warnings, but “code has been rated at 9.97/10” and yesterday’s overnight build to convert all X3D models in X3D Examples Archive was pretty clean.  Steady improvement.  8)<u></u><u></u></li></ol><ul type="disc"><li class="MsoNormal"><a href="https://www.web3d.org/x3d/stylesheets/python/build.pylint.log.txt" target="_blank">https://www.web3d.org/x3d/stylesheets/python/build.pylint.log.txt</a><u></u><u></u></li><li class="MsoNormal"><a href="https://www.web3d.org/x3d/content/examples/build.python.all.log.txt" target="_blank">https://www.web3d.org/x3d/content/examples/build.python.all.log.txt</a><u></u><u></u></li></ul><p class="MsoNormal"> <u></u><u></u></p><ol start="6" type="a"><li class="MsoNormal">Am using Python 3.10.4.  Have checked in all X3DPSAIL improvements and deployed new x3d.py package version 4.0.64.1, passing acceptance tests on this end.  Hopefully working well for you too.  The TODO section seems mostly current, further improvements always welcome.<u></u><u></u></li></ol><ul type="disc"><li class="MsoNormal"><a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fpypi.org%2Fproject%2Fx3d&data=05%7C01%7Cbrutzman%40nps.edu%7Cd989f3064a794c20e28908da4d464dd1%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C637907261615365289%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=H4AV3p82Xw9RKZ8DWIW%2FnekQEusPV9uaTUw3IlYz4AQ%3D&reserved=0" target="_blank">https://pypi.org/project/x3d</a><u></u><u></u></li><li class="MsoNormal"><a href="https://www.web3d.org/x3d/stylesheets/python/python.html" target="_blank">https://www.web3d.org/x3d/stylesheets/python/python.html</a><u></u><u></u></li><li class="MsoNormal"><a href="https://www.web3d.org/x3d/stylesheets/python/python.html#TODO" target="_blank">https://www.web3d.org/x3d/stylesheets/python/python.html#TODO</a><u></u><u></u></li></ul><p style="margin-left:0.25in"> <u></u><u></u></p><ol start="7" type="a"><li class="MsoNormal">Just noticed that Python itself issued a new release 3.10.5 a week ago.  Will post again when that upgrade is tested.<u></u><u></u></li></ol><ul type="disc"><li class="MsoNormal">Python 3.10.5. Release Date: June 6, 2022 <u></u><u></u></li><li class="MsoNormal"><a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fwww.python.org%2Fdownloads%2Frelease%2Fpython-3105&data=05%7C01%7Cbrutzman%40nps.edu%7Cd989f3064a794c20e28908da4d464dd1%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C637907261615365289%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=XDVH%2BjVoStjZ7hVa%2BRYpOj5S5shPXqp4r2sztu75s8g%3D&reserved=0" target="_blank">https://www.python.org/downloads/release/python-3105</a><u></u><u></u></li></ul><p class="MsoNormal"> <u></u><u></u></p><p class="MsoNormal">Again thanks for your excellent problem reports and example fixes.  Have fun with X3D Python!  8)<u></u><u></u></p><div><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New""> </span><u></u><u></u></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">all the best, Don</span><u></u><u></u></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">-- </span><u></u><u></u></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">Don Brutzman  Naval Postgraduate School, Code USW/Br        <a href="mailto:brutzman@nps.edu" target="_blank" style="font-family:"Courier New"">brutzman@nps.edu</a></span><u></u><u></u></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA    +1.831.656.2149</span><u></u><u></u></p><p class="MsoNormal"><span style="font-size:10pt;font-family:"Courier New"">X3D graphics, virtual worlds, Navy robotics https://</span> <span style="font-size:10pt;font-family:"Courier New""><a href="http://faculty.nps.edu/brutzman" target="_blank" style="font-family:"Courier New"">faculty.nps.edu/brutzman</a></span><u></u><u></u></p></div><p class="MsoNormal"> <u></u><u></u></p><div><div style="border-style:solid none none;border-top-width:1pt;padding:3pt 0in 0in;border-top-color:rgb(225,225,225)"><p class="MsoNormal"><b>From:</b> John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> <br><b>Sent:</b> Thursday, June 9, 2022 2:21 AM<br><b>To:</b> Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>>; X3D Graphics public mailing list <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br><b>Subject:</b> x3d.py problem validating MFVec2f (non-specified crossSection) default value<u></u><u></u></p></div></div><p class="MsoNormal"> <u></u><u></u></p><div><div><p class="MsoNormal">The most important thing is last in this email, problems validating default MFVec2f crossSection field in x3d.py.  The rest of the email is background. <u></u><u></u></p><div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">To get x3d.py (x3djsonld.py) to handle HelloWorldProgramOutput.json,  I had to remove Extrusions from the example, and change to Spheres. <u></u><u></u></p><div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">Below is the change to the example to make it work:<u></u><u></u></p><div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">diff /c/x3d-code/<a href="http://www.web3d.org/x3d/stylesheets/java/examples/HelloWorldProgramOutput.json" target="_blank">www.web3d.org/x3d/stylesheets/java/examples/HelloWorldProgramOutput.json</a> HelloWorldProgramOutput.json<br>1135c1135<br><                 { "Extrusion":<br>---<br>>                 { "Sphere":<br>2392c2392<br><                 { "Extrusion":<br>---<br>>                 { "Sphere":<br>2693c2693<br>< }<br>\ No newline at end of file<br>---<br>> }<u></u><u></u></p></div></div><div><p class="MsoNormal">============================================================<u></u><u></u></p></div><div><p class="MsoNormal">If one does not make the change to the JSON file, the following error appears.  x3djsonld.py is in X3DJSONLD/src/main/python.<u></u><u></u></p></div><div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">$ python x3djsonld.py<br>'''<br>x3d.py package 4.0.63.7 loaded, have fun with X3D Graphics!<br>'''<br>from x3d import *<br>from x3d import SFBool<br>print(<br>Traceback (most recent call last):<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 4668, in assertValidMFVec2f<br>    MFVec2f(value)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 9184, in __init__<br>    self.value = value<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 9206, in value<br>    value = [(x, y) for x, y, in value]<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 9206, in <listcomp><br>    value = [(x, y) for x, y, in value]<br>ValueError: too many values to unpack (expected 2)<br><br>The above exception was the direct cause of the following exception:<br><br>Traceback (most recent call last):<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 256, in <module><br>    print(parseObject("X3D", data, 0))<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 178, in parseObject<br>    out += parseObject(k, v,indent+1)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 163, in parseObject<br>    out += parseObject(k, v,indent+1)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 192, in parseObject<br>    out += parseArray("[", "]", parent, key, v,indent+1, fieldType)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 57, in parseArray<br>    out += parseObject(parent, d,indent+1)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 178, in parseObject<br>    out += parseObject(k, v,indent+1)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 175, in parseObject<br>    out += parseObject(k, v,indent+1)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 178, in parseObject<br>    out += parseObject(k, v,indent+1)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 125, in parseObject<br>    fieldInfo = getField(parent, key)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3djsonld.py", line 14, in getField<br>    cls = eval(grandparent)()<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 38948, in __init__<br>    self.crossSection = crossSection<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 39005, in crossSection<br>    assertValidMFVec2f(crossSection)<br>  File "C:\Users\john\X3DJSONLD\src\main\python\x3d.py", line 4672, in assertValidMFVec2f<br>    raise X3DTypeError(str(value)[:100] + ' has type ' + str(type(value)) + ' but is not a valid MFVec2f') from error<br>x3d.X3DTypeError: [(1, 1, 1, -1, -1, -1, -1, 1, 1, 1)] has type <class 'list'> but is not a valid MFVec2f<u></u><u></u></p></div><div><p class="MsoNormal">============================================================<u></u><u></u></p></div><div><p class="MsoNormal">What's wrong with the is handling the Extrusion when crossSection is not set, thus x3d.py:<u></u><u></u></p></div><div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">    @crossSection.setter<br>    def crossSection(self, crossSection):<br>        if  crossSection is None:<br>            crossSection = [(1, 1, 1, -1, -1, -1, -1, 1, 1, 1)] # default<br>        assertValidMFVec2f(crossSection)<br>        self.__crossSection = crossSection<u></u><u></u></p></div><div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">Note that crossSection's default is not correct.<u></u><u></u></p></div><div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">Thanks for any fixes to x3d.py.  I will try to fix it now.<u></u><u></u></p></div><div><p class="MsoNormal"> <u></u><u></u></p></div><div><p class="MsoNormal">John<u></u><u></u></p></div></div></div></div></div></div></blockquote></div></blockquote></div></blockquote></div></div></blockquote></div></div></div></div></div></blockquote></div></div>