<div dir="ltr"><div><div><div><div><div><div><div>I opened a github repository with first results of some work on a simple case conversion tool:<br><br><a href="https://github.com/andreasplesch/X3DCaseFixer">https://github.com/andreasplesch/X3DCaseFixer</a><br><br></div>As envisioned it currently is a simple sed script which takes advantage of the fact that gnu sed has an option to be case insensitive when matching patterns ("I"). It makes a couple of assumption on how to identify elements and attributes but should work hopefully pretty well.<br><br></div>I could figure out how to construct an XPath to exclude xs:element elements in xs:appinfo elements and updated the xslt stylesheet accordingly: It seems to work as intended but I am unsure of it.<br><br>Instead<br><br> select="//xs:element[string-length(@name) > 0]"<br><br></div>I use<br><br><span class="">select</span>=<span class=""><span class="">"</span>//xs:element[string-length(@name) > 0]/parent::*[name()!='xs:appinfo']/xs:element<span class="">"<br><br></span></span></div><span class=""><span class="">Does that look right ?<br><br></span></span></div><span class=""><span class="">It would be interesting to run the script in a couple of x3dom examples and I may try that.<br><br></span></span></div><span class=""><span class="">Any input appreciated,<br><br></span></span></div><span class=""><span class="">Andreas<br></span></span><div><div><div><span class=""><span class=""><br></span></span><div><div><br><div><br><div><br></div></div></div></div></div></div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Nov 4, 2015 at 4:23 PM, Andreas Plesch <span dir="ltr"><<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>After I got with xmlsh a working xslt v.2 processor (xsltproc only supports v.1), I could reproduce the<br>table <a href="http://www.web3d.org/x3d/stylesheets/X3dElementsAttributesLowerCaseTable.txt" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dElementsAttributesLowerCaseTable.txt</a> using Don's stylesheet and the x3d 3.3 schema . Looking at the table more closely, it has entries for lowercase elements such as appearance or material (in the second column). The source of these entries are some <xs:appinfo> elements in the schema, for example for the Shape element, which list these elements with a lowercase name attribute:<br><br><a href="http://www.web3d.org/specifications/X3dSchemaDocumentation3.3/x3d-3.3_Shape.html#Link184" target="_blank">http://www.web3d.org/specifications/X3dSchemaDocumentation3.3/x3d-3.3_Shape.html#Link184</a><br><br></div><div>(scroll to annotation) (or grep name="appearance" in the schema file)<br><br></div>These xs:appinfo within xs:annotation are there presumably only for documentation purposes and not for validation purposes ? As such they may have flown under the radar ?<br><div><br></div><div>Or perhaps xs:appinfo has some requirement to list elements with the name in lowercase ?<br><br></div><div>So I would like to exclude those element matches in the xslt style sheet. Currently they are selected by<br><br> select="//xs:element[string-length(@name) > 0]"<br></div><div><br></div><div>but now I would like to modify the XPath to exclude matches if the parent element is xs:appinfo.<br><br></div><div>Apologies if this is a trivial XPath question but any hint is appreciated.<br><br></div><div>-Andreas<br></div><div><br><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Nov 3, 2015 at 4:57 PM, Andreas Plesch <span dir="ltr"><<a href="mailto:andreasplesch@gmail.com" target="_blank">andreasplesch@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div><div><div>Thanks for the lower case table stylesheet at <a href="http://www.web3d.org/x3d/stylesheets/X3dElementsAttributesLowerCaseTableConstruction.xslt" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dElementsAttributesLowerCaseTableConstruction.xslt</a><br><br></div><div>It is more manageable for a xslt language novice. I think the idea would be to use it as a basis to come up with a lowercase/anycase to x3d camelCase xslt replacement rule style sheet.<br></div><div><br></div><div>I think I would try first to generate separate lists for elements and attributes which the style sheet effectively already does, in sequence.<br><br></div><div>I have xstlproc installed: <a href="http://xmlsoft.org/XSLT/xsltproc2.html" target="_blank">http://xmlsoft.org/XSLT/xsltproc2.html</a> . Let's see how it works. What other processors are recommended ?<br></div><div><br>The use case for me is that it required quite a bit of repetitive effort to get x3d output generated by the <a href="http://vrmath2.net" target="_blank">vrmath2.net</a> editor such as<br><br><a href="https://vrmath2.net/embed/?url=/sites/default/files/user/u342/x3d/helical_gears_smooth_opt.x3d" target="_blank">https://vrmath2.net/embed/?url=/sites/default/files/user/u342/x3d/helical_gears_smooth_opt.x3d</a><br><br></div>into a conforming format so that use of x3d-edit and xj3d would start to make more sense. A lot of that effort was just to get the case correct. Most of the remaining effort was to get rid of the nonconforming attributes such as id. (Perhaps there is way to keep nonconforming attributes around as comments). <br><br></div><div>So I was just envisioning a long, generated sed script with expressions such as s/<elementname *>/<Elementname>/ or such and similar for closing and empty tags, as well as attributes.<br><br></div><div>I think this would go a long way to reformat a nonconforming x3d document towards conforming.<br></div><div><br></div>I may also give xmlsh at <a href="http://www.xmlsh.org/HomePage" target="_blank">http://www.xmlsh.org/HomePage</a> a try. It seems appealing to me. (I just saw that it has some json support). Any experience with it ?<br><br></div>Since html5 is (in general?) not case sensitive, prose on x3d vocabulary within a html5 context would presumably be about what the recommended, case-sensitive form is for reasons of validation, compatibility with xml and other contexts, and general readability versus what the presumably accepted but discouraged case-insensitive form is. Or is it something else it should address ?<br><br></div>Andreas<br><div><br><br><div><div><br><div><br></div></div></div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Nov 3, 2015 at 2:10 PM, Don Brutzman <span dir="ltr"><<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Thanks for the good thinking.<br>
<br>
Some time ago, when first looking at HTML lower-case elements and X3DOM integration, there was good dialog on the mail lists. No doubt available in the archives.<br>
<br>
It would appear that both forms (CamelCase and lowercase/miXedcAsE) are desirable for X3D authors depending on their html publication context.<br>
<br>
At that stage I created a stylesheet that creates a table for producing lower-case version of X3D element names and attributes. It walks the X3D schema in a manner similar to what you are suggesting.<br>
<br>
<a href="http://www.web3d.org/x3d/stylesheets/" rel="noreferrer" target="_blank">http://www.web3d.org/x3d/stylesheets/</a><br>
<a href="http://www.web3d.org/x3d/stylesheets/X3dElementsLowerCaseTable.html" rel="noreferrer" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dElementsLowerCaseTable.html</a><br>
<a href="http://www.web3d.org/x3d/stylesheets/X3dAttributesLowerCaseTable.html" rel="noreferrer" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dAttributesLowerCaseTable.html</a><br>
<a href="http://www.web3d.org/x3d/stylesheets/X3dElementsAttributesLowerCaseTable.txt" rel="noreferrer" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dElementsAttributesLowerCaseTable.txt</a><br>
<a href="http://www.web3d.org/x3d/stylesheets/X3dElementsAttributesLowerCaseTableConstruction.xslt" rel="noreferrer" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dElementsAttributesLowerCaseTableConstruction.xslt</a><br>
<br>
Just tuned them up a little. Might need more precise filtering to avoid duplicates, etc.<br>
<br>
Hopefully this is useful.<br>
<br>
As you point out, the X3D Tidy stylesheet looks at this task too.<br>
<br>
<a href="http://www.web3d.org/x3d/stylesheets/X3dTidy.html" rel="noreferrer" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dTidy.html</a><br>
<a href="http://www.web3d.org/x3d/stylesheets/X3dTidy.xslt" rel="noreferrer" target="_blank">http://www.web3d.org/x3d/stylesheets/X3dTidy.xslt</a><br>
<br>
At this point, it might be good to articulate any use cases and the relevant HTML5 prose on case sensitivity.<br>
<br>
Open source. All suggestions, improvements or additions welcome.<br>
<br>
<br>
On 11/3/2015 9:34 AM, Andreas Plesch wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Since the idea of having a x3d document which is conforming as much as possible is attractive, I am thinking of a tool which corrects element names and attribute names to their correct case sensitive spelling. Is there such a tool ?<br>
<br>
In principle I think it could work by:<br>
1) extract all element and attribute names from the .dtd and/or schema<br>
2) go through all elements (recursively) in (nonconforming) x3d document<br>
2a) normalize element name to lower-case and see if there is a corresponding normalized node name in dtd<br>
2b) if there is replace with correct, case sensitive element name<br>
if not flag as unknown (or ignore, optionally eliminate)<br>
2c) do the same for all used attribute names<br>
<br>
This would work for most if not all names since they can all (most?) be distinguished in a case insensitive manner.<br>
<br>
The tool of choice would be a xsl style sheet which may have to be generated by another stylesheet which processes the .dtd/schema. What would be other strategies (going through json) ? How would one go about this in more detail ? Perhaps the x3d-tidy.xsl style sheet is a starting point ? It looks daunting.<br>
<br>
However, I would probably start much more straightforwardly by looking at<br>
<a href="http://www.web3d.org/specifications/X3dDoctypeDocumentation3.3.html" rel="noreferrer" target="_blank">http://www.web3d.org/specifications/X3dDoctypeDocumentation3.3.html</a> and<br>
<a href="http://www.web3d.org/specifications/X3dSchemaDocumentation3.3/x3d-3.3.html" rel="noreferrer" target="_blank">http://www.web3d.org/specifications/X3dSchemaDocumentation3.3/x3d-3.3.html</a><br>
to assemble a list and then use unix tools such as sed/awk and such<br>
to transform the x3d. What is used to generate the above documentation from the .dtd/xsd ?<br>
<br>
Any input much appreciated,<br>
<br>
Andreas<br>
<br>
<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" rel="noreferrer" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br>
<br>
</blockquote>
<br>
<br>
all the best, Don<span><font color="#888888"><span><font color="#888888"><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 <a href="tel:%2B1.831.656.2149" value="+18316562149" target="_blank">+1.831.656.2149</a><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>
</font></span></font></span></blockquote></div><span><font color="#888888"><br><br clear="all"><span class="HOEnZb"><font color="#888888"><br>-- <br><div>Andreas Plesch<br>39 Barbara Rd.<br>Waltham, MA 02453</div>
</font></span></font></span></div><span class="HOEnZb"><font color="#888888">
</font></span></blockquote></div><span class="HOEnZb"><font color="#888888"><br><br clear="all"><br>-- <br><div>Andreas Plesch<br>39 Barbara Rd.<br>Waltham, MA 02453</div>
</font></span></div>
</blockquote></div><br><br clear="all"><br>-- <br><div class="gmail_signature">Andreas Plesch<br>39 Barbara Rd.<br>Waltham, MA 02453</div>
</div>