[oXygen-user] About oXygen XML Editor

About oXygen XML Editor
Thu May 21 23:35:53 CDT 2015


About oXygen XML Editor

///////////////////////////////////////////
Schematron Checks to help Technical Writing

Posted: 21 May 2015 03:56 AM PDT
http://feedproxy.google.com/~r/AboutOxygenXmlEditor/~3/eQSoXbR5Vjg/schematron-checks-to-help-technical.html?utm_source=feedburner&utm_medium=email

   The Oxygen XML Editor User's Manual is written in DITA. In an older post  
I described in more detail  how we collaborate internally on our        
User's Guide Project. And we also made available a copy of our User's  
Manual as a project on         GitHub.   During these years on working on  
it, we progressively developed a set of simple rules which    were  
originally kept in a plain text document. The problem is that nobody can  
really remember all    these rules when actually writing. So recently we  
started to migrate these rules to Schematron    and have them reported  
automatically has validation warnings and errors while editing the  
topics.    And with the release of Oxygen 17 we can now also add quick  
fixes for each of these problems.   So below I will try to tell you what  
each rule imposes and what it's Schematron implementation    looks like. If  
you want to quickly test these rules on your side, you can add them to  
the    Schematron file which is used by default to validate DITA topics  
located in:      
OXYGEN_INSTALL_DIR/frameworks/dita/resources/dita-1.2-for-xslt2-mandatory.sch.       
Try as much as possible to add at least an indexterm element in  
each         topic. This is useful when the Index page is created for the  
PDF output or the           Index tab is created for the WebHelp output. As  
this is not a requirement, we         wanted to report this issue as an  
error. The end result looks like this:

  And the Schematron pattern looks like         this:<pattern  
xmlns:sqf="http://www.schematron-quickfix.com/validator/process">
  <rule context="/*">
   <assert test="prolog/metadata/keywords/indexterm" role="warn"  
sqf:fix="addFragment">
       It is recommended to add an 'indexterm' in the current '<name/>'  
element.
   </assert>
   <!-- Quick fix to add the indexterm element element and its parents -->
   <sqf:fix id="addFragment">
       <sqf:description>
           <sqf:title>Add the 'indexterm' element</sqf:title>
       </sqf:description>
       <sqf:add match="(title | titlealts | abstract | shortdesc)[last()]"  
position="after" use-when="not(prolog)">
          <prolog xmlns=""><metadata><keywords><indexterm>  
</indexterm></keywords> </metadata></prolog>
       </sqf:add>
   </sqf:fix>
  </rule>
</pattern>    The ID of each topic must be equal to the file name (minus  
the extension). One of the outputs         we produce (I think CHM) had a  
limitation when building the context mapping between help IDs         and  
actual HTML content so this was an important rule for us, thus an error is  
reported on         this. Also a quick fix is added to auto-correct the  
topic ID based on the file name. The end         result looks like this:

and the Schematron pattern         is:<!-- Topic ID must be equal to file  
name -->
<sch:pattern>
  <sch:rule context="/*[1][contains(@class, ' topic/topic ')]">
   <sch:let name="reqId"  
value="replace(tokenize(document-uri(/), '/')[last()], '\.dita', '')"/>
   <sch:assert test="@id = $reqId" sqf:fix="setId">
    Topic ID must be equal to file name.
   </sch:assert>
   <sqf:fix id="setId">
    <sqf:description>
     <sqf:title>Set "<sch:value-of select="$reqId"/>" as a topic  
ID</sqf:title>
     <sqf:p>The topic ID must be equal to the file name.</sqf:p>
    </sqf:description>
    <sqf:replace match="@id" node-type="attribute" target="id"  
select="$reqId"/>
   </sqf:fix>
  </sch:rule>
</sch:pattern>    Report when plain links or related links to web resources  
have the same text inside them as         the value of the @href attribute.  
We had cases in which writers would input web links         like          
this:<xref href="http://www.google.com" format="html"  
scope="external">http://www.google.com</xref>which         is redundant  
because when you set no text to the link, the publishing uses the  
@href        attribute value as the link text. So we wanted to report such  
cases as warnings and to have         a quick fix which removes the link  
text:

The Schematron pattern looks like         this:<sch:pattern>
  <sch:rule context="*[contains(@class, ' topic/xref ') or  
contains(@class, ' topic/link ')]">
   <sch:report test="@scope='external' and @href=text()"  
sqf:fix="removeText">
    Link text is same as @href attribute value. Please remove.
   </sch:report>
   <sqf:fix id="removeText">
    <sqf:description>
     <sqf:title>Remove redundant link text, text is same as @href  
value.</sqf:title>
    </sqf:description>
    <sqf:delete match="text()"/>
   </sqf:fix>
  </sch:rule>
</sch:pattern>    Avoid using the @scale attribute on images. We wanted to  
smooth scale images in an     external image editor so it was prohibited to  
use the @scale attribute on images. The     Schematron pattern for      
this:<pattern>
  <rule context="*[contains(@class, ' topic/image ')]">
   <assert test="not(@scale)">
    Dynamically scaled images are not properly displayed, you
    should scale the image with an image tool and keep it within
    the recommended with and height limits.
   </assert>
  </rule>
</pattern>      We have an upcoming webinar dedicated to Schematron Quick  
Fixes. There is a W3C working group for XML Quick Fixes and you calso read  
the SQF Quick Fix specification if you want to become more       familiar  
with the technology.
We also have a GitHub project which tries to combine the notion of a        
style guide for writing documentation inside a company with a very simple  
manner of defining       checks which can be applied to impose the  
styleguide rules.      I would be interested in your feedback, especially  
if you have checks that you perform right       now on your content and you  
consider that they might benefit others.

--
You are subscribed to email updates from "About oXygen XML Editor."
To stop receiving these emails, you may unsubscribe now:  
https://feedburner.google.com/fb/a/mailunsubscribe?k=y_tRXtumvTurKTedh51JnlYsGXw

Email delivery powered by Google.
Google Inc., 1600 Amphitheatre Parkway, Mountain View, CA 94043, United  
States

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.oxygenxml.com/pipermail/oxygen-user/attachments/20150522/915a4e1d/attachment.html>


More information about the oXygen-user mailing list