<div dir="auto">I would like to validate the contents of a JSON document against the profile without translating to XML.   Thus profile to components or profile to node information is required, but may be derived from what you suggest when it will appear in the object model.<div dir="auto"><br></div><div dir="auto">Please plan to provide this in the object model.   I believe it exists somewhat in the XML schema.</div><div dir="auto"><br></div><div dir="auto">John<br><div dir="auto"><br></div><div dir="auto"><br></div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Aug 22, 2017 11:19 PM, "Don Brutzman" <<a href="mailto:brutzman@nps.edu">brutzman@nps.edu</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">OK but sorry, not fully understanding.<br>
<br>
Each node and each component can appear in multiple profiles.<br>
<br>
Meanwhile each node is in one unique component.<br>
<br>
So to help understand what is blocking you, wondering what is the goal or use case that you are trying to accomplish.  Please advise.<br>
<br>
For example, for a given profile, are you trying to determine what are the corresponding components/levels and thus nodes/fields?  Rules for such profile requirements can be found in X3D Schematron, and might get added programmatically to X3DJSAIL, but I don't think we've declaratively codified profile capabilities anywhere else.<br>
<br>
To describe those relationships, we'd have to add either<br>
<br>
a. explicit list of allowed nodes in each profile, or<br>
<br>
b. decorate each node with the profiles that it appears in.<br>
<br>
Both are rather complex... Further complicating such an elaboration is the fact that multiple levels are defined among fields, nodes, component and profile requirements.  Further, most profiles are strict supersets of each other - but some are not (e.g. CADInterchange, Medical).  So these profile/component/level/node/f<wbr>ield relationships are not a very straightforward data structure to declare or maintain.<br>
<br>
So is that what you want?  If so, sounds like a somewhat difficult but worthy challenge.<br>
<br>
<br>
On 8/22/2017 3:46 PM, John Carlson wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
As I’ve told Roy, the real thing blocking me is the lack of profile to component or node information in the object model.<br>
<br>
John<br>
<br>
Sent from Mail <<a href="https://go.microsoft.com/fwlink/?LinkId=550986" rel="noreferrer" target="_blank">https://go.microsoft.com/fwli<wbr>nk/?LinkId=550986</a>> for Windows 10<br>
<br>
*From: *Don Brutzman <mailto:<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>><br>
*Sent: *Tuesday, August 22, 2017 12:37 PM<br>
*To: *John Carlson <mailto:<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>>; Roy Walmsley <mailto:<a href="mailto:roy.walmsley@ntlworld.com" target="_blank">roy.walmsley@ntlworld.<wbr>com</a>><br>
*Subject: *Re: Fwd: Re: More Object Model Work: indicating default component andlevel in X3DJSAIL<br>
<br>
it is available in X3D Validator now... and I'm sure it is possible in X3DJSAIL.<br>
<br>
I'll work on that code pattern further when I add per-field validation of unique level requirements, as recently described for Inline load field.<br>
<br>
Thanks John.<br>
<br>
On 8/21/2017 12:04 PM, John Carlson wrote:<br>
<br>
> Specifically, is it possible to add X3DObject.isValidForProfile()?<wbr>  Why or why not?<br>
<br>
><br>
<br>
> On Aug 21, 2017 1:56 PM, "John Carlson" <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a> <mailto:<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>>> wrote:<br>
<br>
><br>
<br>
>     I am more interested in profiles.   How we can support validation of profiles with the object model.   Thus we need profile -> node info and profile -> statement info.   If this is achievable through component and level, fine, tell me how to do it.<br>
<br>
>     ---------- Forwarded message ----------<br>
<br>
>     From: "Don Brutzman" <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a> <mailto:<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>>><br>
<br>
>     Date: Aug 21, 2017 10:55 AM<br>
<br>
>     Subject: Re: More Object Model Work: indicating default component and level in X3DJSAIL<br>
<br>
>     To: "John Carlson" <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a> <mailto:<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>>><br>
<br>
>     Cc: "X3D Graphics public mailing list" <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a> <mailto:<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>>><wbr>, "Roy Walmsley" <<a href="mailto:roy.walmsley@ntlworld.com" target="_blank">roy.walmsley@ntlworld.com</a> <mailto:<a href="mailto:roy.walmsley@ntlworld.com" target="_blank">roy.walmsley@ntlworld.<wbr>com</a>>><br>
<br>
><br>
<br>
>         Component and level information from object model and schema are now included and exposed in X3DJSAIL elements.<br>
<br>
><br>
<br>
>                  X3D Java Scene Access Interface Library (X3DJSAIL)<br>
<br>
> <a href="http://www.web3d.org/specifications/java/X3DJSAIL.html" rel="noreferrer" target="_blank">http://www.web3d.org/specifica<wbr>tions/java/X3DJSAIL.html</a> <<a href="http://www.web3d.org/specifications/java/X3DJSAIL.html" rel="noreferrer" target="_blank">http://www.web3d.org/specific<wbr>ations/java/X3DJSAIL.html</a>><br>
<br>
><br>
<br>
>         On 8/21/2017 4:10 AM, John Carlson wrote:<br>
<br>
><br>
<br>
>             Levels should be able to be handled by generating alternative source code, if levels define what attributes are implemented.   We may want to support all attributes, since a level is just the minimal support.<br>
<br>
><br>
<br>
><br>
<br>
>         On 8/20/2017 8:33 PM, Don Brutzman wrote:<br>
<br>
><br>
<br>
>             Lots of good thinking on future possibilities here.<br>
<br>
>             [...]<br>
<br>
>             Meanwhile each node definition in object model includes component and baseline level information.  Example excerpt:<br>
<br>
><br>
<br>
>                     <ConcreteNode name="Anchor"><br>
<br>
> <InterfaceDefinition specificationUrl="<a href="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/components/networking.html#Anchor" rel="noreferrer" target="_blank">http://www.w<wbr>eb3d.org/documents/specificati<wbr>ons/19775-1/V3.3/Part01/<wbr>components/networking.html#<wbr>Anchor</a> <<a href="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/components/networking.html#Anchor" rel="noreferrer" target="_blank">http://www.web3d.org/document<wbr>s/specifications/19775-1/V3.3/<wbr>Part01/components/networking.<wbr>html#Anchor</a>>"><br>
<br>
> <componentInfo name="Networking" level="2"/><br>
<br>
>             [...]<br>
<br>
><br>
<br>
>             TODO:<br>
<br>
>             a. The component info should get added as a convenience in X3DJSAIL.  Example: final String AnchorObject.COMPONENT = "Networking";<br>
<br>
><br>
<br>
><br>
<br>
>         Included COMPONENT constant, also a convenience method getComponent()<br>
<br>
><br>
<br>
>             b. The level info is a bit trickier, since different attributes can be at different levels.  Needs more thought.  Level listed as above makes sense; level on a per-attribute basis seems overly complex.<br>
<br>
><br>
<br>
><br>
<br>
>         Have gone ahead and added LEVEL and getComponentLevel() to expose the available information in the object model.<br>
<br>
><br>
<br>
>             c. Path to deciding on how to best handle level is to make such level checking on non-default attribute values part of node self-validation.<br>
<br>
><br>
<br>
><br>
<br>
>         Example: Inline node.  Most capabilities supported at level 2, except 'load' field which is level 3.<br>
<br>
><br>
<br>
>                  Table 9.3 — Networking component support levels<br>
<br>
> <a href="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/components/networking.html#t-supportlevels" rel="noreferrer" target="_blank">http://www.web3d.org/documents<wbr>/specifications/19775-1/V3.3/<wbr>Part01/components/networking.<wbr>html#t-supportlevels</a> <<a href="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/components/networking.html#t-supportlevels" rel="noreferrer" target="_blank">http://www.web3d.org/document<wbr>s/specifications/19775-1/V3.3/<wbr>Part01/components/networking.<wbr>html#t-supportlevels</a>><br>
<br>
><br>
<br>
>         Object model information indicates lower level:<br>
<br>
><br>
<br>
>         <ConcreteNode name="Inline"><br>
<br>
>             <InterfaceDefinition specificationUrl="<a href="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/components/networking.html#Inline" rel="noreferrer" target="_blank">http://www.w<wbr>eb3d.org/documents/specificati<wbr>ons/19775-1/V3.3/Part01/<wbr>components/networking.html#<wbr>Inline</a> <<a href="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/components/networking.html#Inline" rel="noreferrer" target="_blank">http://www.web3d.org/document<wbr>s/specifications/19775-1/V3.3/<wbr>Part01/components/networking.<wbr>html#Inline</a>>"><br>
<br>
>                    <componentInfo name="Networking" level="2"/><br>
<br>
><br>
<br>
>         Nevertheless the 'load' field does include the additional information:<br>
<br>
><br>
<br>
>         <field type="SFBool"<br>
<br>
>             accessType="inputOutput"<br>
<br>
>             name="load"<br>
<br>
>             default="true"><br>
<br>
>             <componentInfo name="Networking" level="3"/><br>
<br>
>         </field><br>
<br>
><br>
<br>
>         This is primarily an issue for validation testing, as an alert to authors, since an X3D player implementation may well choose to support the load field at the lower primary Networking level 2.<br>
<br>
><br>
<br>
>         Refined TODO for X3DJSAIL: add this test for per-field level checking to validate() methods wherever such deviations occur.<br>
<br>
><br>
<br>
>         all the best, Don<br>
<br>
>         --<br>
<br>
>         Don Brutzman  Naval Postgraduate School, Code USW/Br <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a> <mailto:<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>><br>
<br>
>         Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA <a href="tel:%2B1.831.656.2149" value="+18316562149" target="_blank">+1.831.656.2149</a> <tel:%2B1.831.656.2149><br>
<br>
>         X3D graphics, virtual worlds, navy robotics <a href="http://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">http://faculty.nps.edu/brutzma<wbr>n</a> <<a href="http://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">http://faculty.nps.edu/brutzm<wbr>an</a>><br>
<br>
><br>
<br>
all the best, Don<br>
<br>
-- <br>
<br>
Don Brutzman  Naval Postgraduate School, Code USW/Br       <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a><br>
<br>
Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA   <a href="tel:%2B1.831.656.2149" value="+18316562149" target="_blank">+1.831.656.2149</a><br>
<br>
X3D graphics, virtual worlds, navy robotics <a href="http://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">http://faculty.nps.edu/brutzma<wbr>n</a><br>
<br>
</blockquote>
<br>
</blockquote></div></div>