<div dir="auto">You’re way ahead of me on NetBeans Don. Carpal tunnel is still flaring, of course it’s been flaring since the 80’s or 90’s</div><div dir="auto"><br></div><div dir="auto">I guess I’ll have to get surgery if things get bad, and build a wicked 3D world with ChatGPT.</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 12, 2023 at 3:45 PM Brutzman, Donald (Don) (CIV) <<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"><div lang="EN-US" link="blue" vlink="#954F72" style="word-wrap:break-word"><div class="m_1257134800961922768WordSection1"><p class="MsoNormal">Joe: your second style of construct worked for me in view3dscene yesterday – I launched it to view the .x3d scene using X3D-Edit. So it looks like view3dscene does not forbid the XML syntax, but rather is stricter with the ClassicVRML syntax, which matches what he told us yesterday.<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">If there is a problem in the X3dToClassicVRML.xslt stylesheet conversion, I can fix that. However won’t ever be pushing all the ROUTEs to the end or another location in the scene.<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">NetBeans came out with NetBeans v18 yesterday, will be testing our X3D-Edit plugin with that soon.<u></u><u></u></p><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Courier New""><u></u> <u></u></span></p><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Courier New"">all the best, Don<u></u><u></u></span></p><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Courier New"">-- <u></u><u></u></span></p><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Courier New"">Don Brutzman Naval Postgraduate School, Code USW/Br <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a><u></u><u></u></span></p><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Courier New"">Watkins 270, MOVES Institute, Monterey CA 93943-5000 USA +1.831.656.2149<u></u><u></u></span></p><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Courier New"">X3D graphics, virtual worlds, navy robotics <a href="https://faculty.nps.edu/brutzman" target="_blank">https://faculty.nps.edu/brutzman</a><u></u><u></u></span></p></div><p class="MsoNormal"><u></u> <u></u></p><div><div style="border:none;border-top:solid #e1e1e1 1.0pt;padding:3.0pt 0in 0in 0in"><p class="MsoNormal"><b>From:</b> x3d-public <<a href="mailto:x3d-public-bounces@web3d.org" target="_blank">x3d-public-bounces@web3d.org</a>> <b>On Behalf Of </b>Joseph D Williams<br><b>Sent:</b> Monday, June 12, 2023 12:36 PM<br><b>To:</b> GPU Group <<a href="mailto:gpugroup@gmail.com" target="_blank">gpugroup@gmail.com</a>>; X3D-Public <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br><b>Subject:</b> Re: [x3d-public] Problem in x3dviewscene: ROUTE placement<u></u><u></u></p></div></div><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">No, not tool-generated code. This has run like I show with all available players for 15 or more years without the need to fix. <u></u><u></u></p><p class="MsoNormal">Found this problem in view3dscene when I began to use it when skin started working; looking forward to displacer. <u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Interesting enough for view3dscene, the sequences: <u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Group { <u></u><u></u></p><p class="MsoNormal"> Children [ <u></u><u></u></p><p class="MsoNormal"> Node { … ]<u></u><u></u></p><p class="MsoNormal">]<u></u><u></u></p><p class="MsoNormal">ROUTE … <u></u><u></u></p><p class="MsoNormal">}<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">And <u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Group { <u></u><u></u></p><p class="MsoNormal"> Children [ <u></u><u></u></p><p class="MsoNormal"> Node { … ]<u></u><u></u></p><p class="MsoNormal">] }<u></u><u></u></p><p class="MsoNormal">ROUTE … <u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Are both ok by view3dscene.<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Just does not like:<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Group { <u></u><u></u></p><p class="MsoNormal"> Children [ <u></u><u></u></p><p class="MsoNormal"> Node { … }<u></u><u></u></p><p class="MsoNormal"> ROUTE … <u></u><u></u></p><p class="MsoNormal">] }<u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal">Thanks,<u></u><u></u></p><p class="MsoNormal">Joe<u></u><u></u></p></div></div><div lang="EN-US" link="blue" vlink="#954F72" style="word-wrap:break-word"><div class="m_1257134800961922768WordSection1"><p class="MsoNormal"><u></u> <u></u></p><p class="MsoNormal"><u></u> <u></u></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"><b>From: </b><a href="mailto:gpugroup@gmail.com" target="_blank">GPU Group</a><br><b>Sent: </b>Monday, June 12, 2023 12:12 PM<br><b>To: </b><a href="mailto:x3d-public@web3d.org" target="_blank">X3D-Public</a><br><b>Subject: </b>Re: [x3d-public] Problem in x3dviewscene: ROUTE placement<u></u><u></u></p></div><p class="MsoNormal"><u></u> <u></u></p><div><p class="MsoNormal">ROUTES apply in a context: Scene/ProtoBody. If you were developing an authoring tool, and you read in a scene with ROUTEs anywhere in the context, you'll be scraping the ROUTES out of anywhere and putting them in a context-specific routes list. Then when you write out the scene, at the end of the context you'll spit out the list of ROUTEs.<u></u><u></u></p><div><p class="MsoNormal">So there's no reason not to put ROUTES at the root level of the context. Except if you are re-DEFing (using the same DEF name multiple times down the scenegraph, thereby re-defining what the DEF name refers to) then you would want the ROUTEs close / just after the DEF is applied to the node you want to ROUTE to/from. I think.<u></u><u></u></p></div></div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal">On Mon, Jun 12, 2023 at 1:00 PM GPU Group <<a href="mailto:gpugroup@gmail.com" target="_blank">gpugroup@gmail.com</a>> wrote:<u></u><u></u></p></div><blockquote style="border:none;border-left:solid #cccccc 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt"><div><div><p class="MsoNormal">FreeWRL - OK (Scene root node list is a node list, as is proto root node list, and in general node lists OK placement for ROUTEs in classic file for freeWRL. Parser scrapes them out of MFlist so they don't show in the MFNode list in scenegraph)<u></u><u></u></p><div><p class="MsoNormal">InstantPlayer - OK<u></u><u></u></p></div><div><p class="MsoNormal">Octaga - OK<u></u><u></u></p></div><div><p class="MsoNormal">H3D - syntax error, unexpected ROUTE, expecting identifier or SCRIPT or DEF or USE<u></u><u></u></p></div><div><p class="MsoNormal">WDune - syntax error<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></div><p class="MsoNormal"><u></u> <u></u></p><div><div><p class="MsoNormal">On Mon, Jun 12, 2023 at 12:08 PM Vincent Marchetti <<a href="mailto:vmarchetti@kshell.com" target="_blank">vmarchetti@kshell.com</a>> wrote:<u></u><u></u></p></div></div></blockquote></div><p class="MsoNormal" style="margin-left:9.6pt">My understanding of these results is:<br><br>> On Jun 12, 2023, at 1:41 PM, Joseph D Williams <<a href="mailto:joedwil@earthlink.net" target="_blank">joedwil@earthlink.net</a>> wrote:<br>> <br>> No, not tool-generated code. This has run like I show with all available players for 15 or more years without the need to fix. <br>> Found this problem in view3dscene when I began to use it when skin started working; looking forward to displacer. <br>> <br>> Interesting enough, the sequences: <br>> <br>> Group { <br>> Children [ <br>> Node { … ]<br>> ]<br>> ROUTE … <br>> }<br><br>In this case, the ROUTE statement is in the body of the Group node, alongside the fields of the Group node, as clearly allowed by<br>the Architecture specification and the ClassicVRML grammar.<br><br><br><br><br>> And <br>> <br>> Group { <br>> Children [ <br>> Node { … ]<br>> ] }<br>> ROUTE … <br><br>In this case, the ROUTE statement is at the root level of the Scene, alongside the Group node, as allowed by<br>the Architecture specification and the ClassicVRML grammar.<br><br><br><br>> Are both ok by view3dscene.<br>> <br>> Just does not like:<br>> <br>> Group { <br>> Children [ <br>> Node { … ]<br>> ROUTE … <br>> ] }<br><br>In this case the ROUTE statement appears as one item in the MFNode-typed Children field. The validity of this has been under discussion in this thread. I believe the Architecture prose is ambiguous at best, but that this is forbidden by the ClassciVRML formal grammar.<br><br>It appears to me that other implementors of the ClassicVRML reading chose to accept the invalid placement of the ROUTE statement. I can't speak for Michalis' intentions, but the view3dscene ClassicVRML import does reject what I judge to be invalid syntax. <br><br>Vince Marchetti<br><br><br><br>> Thanks,<br>> Joe<br>> <br>> <br>> <br>> <br>> <br>> From: Vincent Marchetti<br>> Sent: Monday, June 12, 2023 6:55 AM<br>> To: X3D-Public<br>> Subject: Re: [x3d-public] Problem in x3dviewscene: ROUTE placement<br>> <br>> Thank you for identifying the relevant seection of the X3D V4 Architecture. The relevant sentence from section 4.4.8.2 is:<br>> <br>> ROUTE statements may either appear at the top level of an X3D file or inside a node wherever fields may appear.<br>> <br>> It declares the intent of allowing a ROUTE statement inside a node definition in close proximity to a field that the ROUTE modifies, for purpose of readability, but other than that purpose this placement of the ROUTE statement does not change the semantics of a ROUTE statement. I don't think this sentence bears being taken literally to an extreme; otherwise we are obligated to define a additional XML encoding of the ROUTE statement which allows the ROUTE statement to be included as an XML attribute; so that, for example, it can be placed adjacent to the XML encoding of the SFVec3f "translation" field of the Transform element. I am not trying to argue by exaggeration;t I am argujng that the sentence need to be interpreted in accordance with the syntax of a specific encoding.<br>> <br>> The ClassicVRML encoding does allow a ROUTE to be defined in the body of a X3D node; the specific issue we are discussing is whether this includes placing the ROUTE definition inside the ClassicVRML encoding of an MFNode value. We could have a continued discussion about whether inclusion as an item in a MFNode value is included in the text phrase "..wherever fields may appear", but we can also refer to the formal grammar definition of the ClassicVRML appendix which, in my judgement, does not allow that.<br>> <br>> Taking a step back, and asuming that the JoeLevel2LOA3SSPYRWRJKHud.x3dv example was generated by a tool; we have one tool that generates an x3dv file which does not conform to the ClassicVRML formal geometry published in X3D V3.3 . If I understand Don's email report of June 9, the X3D conversion of the x3dv file passed validation, but this was not direct validation of the original x3dv file. So I see the validation situation as:<br>> <br>> 1) The view3dscene code identifies the ClassicVRML error in JoeLevel2LOA3SSPYRWRJKHud.x3dv when asked to render it,'<br>> 2) The conversion code, from x3dv -> x3d, offered by view3dscene, does not flag an error in JoeLevel2LOA3SSPYRWRJKHud.x3dv but does generate a valid x3d scene from it,<br>> <br>> In the example archives, we have not yet identified a ClassicVRML encoding that includes this very specific feature, a ROUTE statement included within an MFNode value of an X3D field, so it is not yet possible to use our example archive for guidance.<br>> <br>> I think these considerations make it premature to change the ClassicVRML grammar definition in the standard.<br>> <br>> Vince Marchetti<br>> <br>> <br>> <br>> > On Jun 12, 2023, at 1:36 AM, Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> wrote:<br>> > <br>> > • Sorry to be unclear, that was not the relevant reference, rather the prior email in the thread.<br>> > <br>> > My mail of 9 June 16:30:04 PDT 2023 holds the relevant reference. Excerpt follows, quoting a quote, and have provided yellow highlights to key phrasing this time.<br>> > <br>> > <br>> > • [x3d-public] Problem in x3dviewscene: ROUTE placement<br>> > • <a href="http://web3d.org/pipermail/x3d-public_web3d.org/2023-June/018836.html" target="_blank">http://web3d.org/pipermail/x3d-public_web3d.org/2023-June/018836.html</a><br>> > <br>> > The intent for ROUTE is that it might appear within other nodes. The<br>> > phrasing in X3D4 Architecture is quite explicit about this:<br>> > <br>> > * X3D 4.0 Part 1: Architecture and base components, clause 4 Concepts, 4.4.8.2 Routes<br>> > * <a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-IS.proof/Part01/concepts.html#Routes" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-IS.proof/Part01/concepts.html#Routes</a><br>> > <br>> > * Routes allows an author to declaratively connect the output events<br>> > of a node to input events of other nodes, providing a way to implement<br>> > complex behaviors without imperative programming. When a routed output event<br>> > is fired, the corresponding destination input event receives notification<br>> > and can process a response to that change. This processing can change the<br>> > state of the node, generate additional events, or change the structure of<br>> > the scene graph. Routes may be created declaratively in an X3D file or<br>> > programmatically via an SAI call.<br>> > * Routes are not nodes. The ROUTE statement is a construct for<br>> > establishing event paths between specified fields of nodes. ROUTE statements<br>> > may either appear at the top level of an X3D file or inside a node wherever<br>> > fields may appear. A ROUTE statement shall only appear after the definition<br>> > of the source and destination nodes. Placing a ROUTE statement within a node<br>> > does not associate it with that node in any way. A ROUTE statement does<br>> > follow the name scoping rules as described in 4.4.7 Run-time name scope.<br>> > <br>> > <br>> > • I next took the offered example scene<br>> > • <a href="https://www.web3d.org/x3d/content/examples/Vrml2Sourcebook/Chapter08AnimatingPositionOrientationScale/Figure08_3PositionInterpolator.x3d" target="_blank">https://www.web3d.org/x3d/content/examples/Vrml2Sourcebook/Chapter08AnimatingPositionOrientationScale/Figure08_3PositionInterpolator.x3d</a><br>> > <br>> > and moved entire scene graph within Scene inside a Group, i.e.<br>> > • <Scene><Group><!—everything including ROUTE statements --></Group></Scene><br>> > • Thus nothing remains in top-level MFNode list of the scene, except for single parent Group<br>> > <br>> > Then tested the modified example.<br>> > • All validation tests passed.<br>> > • Xj3D worked.<br>> > • X3DOM worked.<br>> > • After 10 minutes of reporting to Microsoft that view3dscene was legitimate, and coercing Windows 10 to accept it, view3dscene.exe worked on this modified example too.<br>> > • Searching for “<ROUTE” found 4989 matches in first 500 scenes searched (out of 4060 total archived scenes) so no doubt there are more.<br>> > <br>> > • To my prior list of benefits for flexible placement of ROUTE statements, here is another:<br>> > • Simplifies author and tool addition of code-block patterns and templates within a scene (this a feature used numerous times as an optional authoring assist for event tracing by X3D-Edit, likely to be added as utility features in X3DJSAIL and X3DPSAIL someday as well.)<br>> > Specifically, from X3D-Edit documentation,<br>> > • Trace capabilities are available for ROUTE, sensors, interpolators and other nodes that produce or consume events. Trace output results are logged on the browser console to show the timing and values passed events. When the Trace checkbox is selected by the author, a Script node is inserted immediately after the node to accomplish this task. This is a useful debugging technique.<br>> > • <a href="https://savage.nps.edu/X3D-Edit/images/TraceFeatureReportsRoutedEventValuesOnBrowserConsoleViaScriptOutput.png" target="_blank">https://savage.nps.edu/X3D-Edit/images/TraceFeatureReportsRoutedEventValuesOnBrowserConsoleViaScriptOutput.png</a><br>> > • <a href="https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fx3dgraphics.com%2Fexamples%2FX3dForWebAuthors%2FChapter07-EventAnimationInterpolation%2FChapter07-EventAnimationInterpolation-EventTracing.pdf&data=05%7C01%7Cbrutzman%40nps.edu%7Ce0198912c78d41ded35b08db6b7c6f44%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C638221954925283752%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000%7C%7C%7C&sdata=3t4W81HuNGGYCxyFJ3OOUGfCkItrtYSI%2BcUkgE1CuhA%3D&reserved=0" target="_blank">https://x3dgraphics.com/examples/X3dForWebAuthors/Chapter07-EventAnimationInterpolation/Chapter07-EventAnimationInterpolation-EventTracing.pdf</a><br>> > <br>> > • “Consistency across all file encodings and language bindings is possible.” This is our basic design principle for separation of functionality in X3D architecture from implementation details in all related specifications.<br>> > <br>> > We have immense interoperability already. As promised many times, we will smooth out any mismatches in future X3D 4.0 file encodings and language bindings. Test cases do help too. So stand by for action.<br>> > <br>> > Hopefully the highlighted specification requirement, the ease of creating flexible test cases, and the value of this existing specification capability is presented more clearly now.<br>> > <br>> > Careful consideration, implementation efforts, and consensus-based progress are always appreciated.<br>> > <br>> > Having fun with X3D… I hope that others are too.<br>> > <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="https://faculty.nps.edu/brutzman" target="_blank">https://faculty.nps.edu/brutzman</a><br>> > <br>> > From: <a href="mailto:vmarchetti@kshell.com" target="_blank">vmarchetti@kshell.com</a> <<a href="mailto:vmarchetti@kshell.com" target="_blank">vmarchetti@kshell.com</a>> <br>> > Sent: Sunday, June 11, 2023 4:42 PM<br>> > To: Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>>; X3D-Public <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>> > Cc: Michalis Kamburelis <<a href="mailto:michalis.kambi@gmail.com" target="_blank">michalis.kambi@gmail.com</a>><br>> > Subject: Re: [x3d-public] Problem in x3dviewscene: ROUTE placement<br>> > <br>> > <br>> > On Jun 11, 2023, at 5:09 PM, Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> wrote:<br>> > <br>> > Not trying to invent anything here, rather point out what is specified (and also common practice). I already gave the relevant links in the X3D 4.0 Architecture governing what is required. <br>> > <br>> > I do not see this requirement given or even implied in the link you specified:<br>> > • <a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-IS.proof/Part01/fieldTypes.html" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4-IS.proof/Part01/fieldTypes.html</a><br>> > <br>> > is a comprehensive listing of the X3D Field types, with details on SFNode and MFNode therein, and on this page I don't see any mention of the ROUTE statement nor does a text search on that page discover even the terms "route" or "statement" in isolation.<br>> > <br>> > ...<br>> > <br>> > <br>> > Consistency across all file encodings and language bindings is possible.<br>> > I don't this this statement is true, or to the extent that it is true, then long - ago X3D design decisions did not treat it as of primary importance. As Michalis pointed out, in the ClassicVRML encoding the zero or more items in a single MFNode value are syntactically enclosed in square brackets. Moreover, in the ClassicVRML encoding all the field values are explicitly identified with the name of the field. However, in the X3D encoding the XML child elements are in most cases identified as belonging to an X3D field through the node type-inheritance classification; and in the few cases where that is not possible an explicit "containerField" XML attribute is used. To make the X3D encoding consistent with ClassicVRML would entail the use of wrapper XML elements around the element encoding of one node-element for an SFNode value, or the several nodes of MFNode. However, the design decision was made long ago not to use wrapper elements in the XML encoding ( see <a href="https://www.web3d.org/x3d/content/examples/Basic/development/WrapperTagsConsideredHarmful.html" target="_blank">https://www.web3d.org/x3d/content/examples/Basic/development/WrapperTagsConsideredHarmful.html</a> )<br>> > <br>> > My point is that the consistency among encodings is a useful criteria but should not automatically take precedence over other considerations. One such consideration is maintainging stability of our formal ClassicVRML grammar.<br>> > <br>> > And I think there is little additional benefit in changing the the ClassicVRML to allow ROUTE inside MFNode encodings. Doing so does allow a ROUTE to be placed adjacent to a node whose fields it modifies and you (Don) have pointed out the readability benefits that offers -- but Michalis points out that the ClassicVRML already allows that ROUTE statement to be placed inside the body of a node it modifies, even closer!<br>> > <br>> > Vince Marchetti<br>> <br>> <br>> _______________________________________________<br>> x3d-public mailing list<br>> <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br>> <a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br><br><br>_______________________________________________<br>x3d-public mailing list<br><a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br><a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><u></u><u></u></p><p class="MsoNormal"><u></u> <u></u></p></div></div>_______________________________________________<br>
x3d-public mailing list<br>
<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br>
<a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" rel="noreferrer" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br>
</blockquote></div></div>