<div dir="ltr"><div dir="ltr">On Sat, Dec 5, 2020 at 6:33 PM Don Brutzman <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> wrote:<br></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">On 12/5/2020 2:41 PM, Andreas Plesch wrote:<br>
> [...] <br>
> Assuming X3D4 completion and acceptance, in a few months when we get to revision of X3D XML Encoding 19776-1 we can consider special wording for ProtoInstance if it survives further scrutiny and consensus emerges on merit. For today, as usual, X3D Schematron is following strict interpretation of specification:<br>
> <br>
> * X3D XML encoding > 4 Concepts > 4.3.4 DEF and USE attribute syntax<br>
> <a href="https://www.web3d.org/documents/specifications/19776-1/V3.3/Part01/concepts.html#DEFAndUSEAttributeSyntax" rel="noreferrer" target="_blank">https://www.web3d.org/documents/specifications/19776-1/V3.3/Part01/concepts.html#DEFAndUSEAttributeSyntax</a> <<a href="https://www.web3d.org/documents/specifications/19776-1/V3.3/Part01/concepts.html#DEFAndUSEAttributeSyntax" rel="noreferrer" target="_blank">https://www.web3d.org/documents/specifications/19776-1/V3.3/Part01/concepts.html#DEFAndUSEAttributeSyntax</a>><br>
> <br>
> 'Nodes containing a USE="someName" attribute can include no other attributes except containerField and class. Default values for other fields shall be ignored since field definitions in the original DEF node declaration have precedence.'<br>
> <br>
> 'Nodes' seems to refer to X3D nodes but may be intended to refer to XML nodes. To avoid ambiguity, consider specifying 'XML elements' instead. I think strictly speaking attributes are also nodes in XML<br>
> <br>
> With such a change ProtoInstance would fall under that requirement.<br>
<br>
In general: 19775-1 X3D Architecture refers to X3D nodes, while 19776-2 X3D XML encoding refers to XML elements representing those same X3D nodes.<br></blockquote><div><br></div><div></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
So the quoted 'Nodes' above is X3D node and also XML element.<br></blockquote><div><br></div><div>
Yes. This is a section from the XML encoding (19776-1). In the preceding text "nodes" is used to refer to X3D nodes. The confusion, for me, comes from the fact that ProtoInstance is not a X3D node by itself.</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
I don't think we want the abstract Architecture to say anything about XML, but to continue to strive for an Architecture that has fully representable functionality in each of the subsidiary file encoding (19776-*) and programming language bindings (19777-*) standards.<br></blockquote><div><br></div><div>Agreed, this is only about the XML encoding.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
This all requires careful phrasing! In case anyone isn't wary yet, XML-speak (and DOM) often refers to XML elements as document nodes, as well.<br></blockquote><div><br></div><div>DOM language, in particular, prefers "node".</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
It is a little bit of a chore when programming a parser with ProtoInstance USE support to look up the name of the original DEF ProtoInstance, but knowing that consistency is correct in a scene is certainly helpful.<br></blockquote><div><br></div><div>And most browsers ( including x3dom, but not all ) do not require the name attribute with USE. So that is ok. The problem is only that the spec. is not clear if the name is required or not. The tooltips (and the validation tools due to technical constraints) do not require it and actually forbid it but the spec. language itself is just not conclusive. If no attribute would be allowed with USE ( as is the case with XML elements which are x3d nodes ), name cannot be required.</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><br>
And so, still thinking our current state of affairs to have XML models with a ProtoInstance USE not require a name (while clearly erroneous if an included name mismatches) seems OK and provides round-trippable correct results. This pattern also played out satisfactorily in the JSON encoding, Java X3DJSAIL and Python x3d.py without mishap.<br></blockquote><div><br></div><div>I agree. It would be reasonable that name should not be required. But the spec. currently allows browsers to require it, as far as I can tell.</div><div><br></div><div><a href="https://savage.nps.edu/X3dValidator/">https://savage.nps.edu/X3dValidator/</a> does not seem to work currently, eg. the Validate button stays greyed out ?<br></div><div> </div><div>all the best, -Andreas</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<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="http://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">http://faculty.nps.edu/brutzman</a><br>
</blockquote></div><br clear="all"><div><br></div>-- <br><div dir="ltr"><div dir="ltr"><div>Andreas Plesch<br>Waltham, MA 02453</div></div></div></div>