[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]
Subject: Re: [dita] Errata: Example Domain Constraint Will Not Work
Right - the example in the specification is correct and it works, but both the delivered 1.3 learning shells and the delivered learning constraint were wrong.
I sent my revised constraint to Eliot yesterday. It's not implemented like the sample in the spec, but it works, and I thought it was correct when I did it. Which brings me to the comment in Eliot's first note:
> However, since the coding rules are just guidelines it doesn't
> really matter—DTD syntax determines where things have to go.
I must admit this really makes my head spin. Section 2.6 of the base spec (Coding practices for DITA grammar files) runs from page 149 to 177. Those practices are rules (not guidelines) - stating factual information about how the modules have to be coded. Following these rules will get you "DITA-conforming grammar files", as defined by DITA 1.3.
If they're just guidelines, why do we devote 28 pages of the specification to defining them as normative rules?
If they're really just guidelines (and I think they're better off as guidelines!), maybe we can consider moving them out of the 2.0 spec, and into a tutorial or companion spec devoted just to interchangeable / modular grammar files?
And after lighting that fuse, I'll send my regrets in for the next two meetings ;-)
Regards, Robert D. Anderson | |
E-mail: robander@us.ibm.com Digital Services Group | |
11501 BURNET RD,, TX, 78758-3400, AUSTIN, USA | |
Hi,
Yesterday I discovered an unfortunate issue with the learningObjectMap and learningGroupMap DTDs while working on the contains / contained-by tables.
Each of these maps includes a constraint module, learningAggregationsTopicrefConstraint. Unfortunately this constraint is working in the RNG grammar files, not working in the DTD, and unclear in the XSD.
The purpose of the constraint is to say - "in any location that would normally allow <topicref> and its domain extensions, only allow keydef, mapref, and topicgroup". This means that the constraint removes the following elements:
* topicref
* From mapgroup domain: anchorref, topichead, topicset, topicsetref
I believe this works in the RNG. As a child of <learningObjectMap>, the legal topic references include the 3 expected, plus learningObject, learningGroup, learningObjectMapRef, and learningGroupMapRef. It also allows <ditavalref>, which is added as an independent domain. None of the excluded elements above are allowed.
The DTD constraint is not working - it allows everything that the RNG excludes:
* It is included in the wrong spot in the shell - so redefined entities are completely ignored
* The syntax in the constraint isn't quite right; moving it to the right spot in the shell results in a DTD that doesn't parse. It needs several changes in order to match what is done in RNG (drop topicref, add only 3 mapgroup extensions, and keep ditavalref).
I'd appreciate it if somebody could test the XSD - my test failed, not sure if it's a problem with my test or with the XSD itself.
Options moving forward:
Thanks, Robert D. Anderson | |
E-mail: robander@us.ibm.com Digital Services Group | |
11501 BURNET RD,, TX, 78758-3400, AUSTIN, USA | |
[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]