]> granicus.if.org Git - docbook-dsssl/commitdiff
Make olink errors/warnings overridable in customizations.
authorAlexey Neyman <stilor@att.net>
Wed, 25 Sep 2013 22:38:32 +0000 (22:38 +0000)
committerAlexey Neyman <stilor@att.net>
Wed, 25 Sep 2013 22:38:32 +0000 (22:38 +0000)
xsl/common/olink.xsl
xsl/fo/xref.xsl
xsl/html/chunk-common.xsl
xsl/html/xref.xsl
xsl/website/olink.xsl

index 83698d0304a4f6c2d6e8298c26e3dacab382fdec..d9301b1d8dfe3254347cdd78d35197290ee8cdc7 100644 (file)
          use="concat(ancestor::document/@targetdoc, '/',
                      @targetptr, '/', ancestor::document/@lang)" />
 
+<!-- Customize this template if you want olink errors to be fatal -->
+<xsl:template name="olink.error">
+  <xsl:param name="message"/>
+
+  <xsl:message>
+    <xsl:text>Olink error: </xsl:text>
+    <xsl:value-of select="$message"/>
+  </xsl:message>
+</xsl:template>
+
+<!-- Customize this template if you want olink warnings to be fatal -->
+<xsl:template name="olink.warning">
+  <xsl:param name="message"/>
+
+  <xsl:message>
+    <xsl:text>Olink warning: </xsl:text>
+    <xsl:value-of select="$message"/>
+  </xsl:message>
+</xsl:template>
+
+<!-- Customize this template if you want unresolved olink pointers to be fatal -->
+<xsl:template name="olink.unresolved">
+  <xsl:param name="targetdoc.att"/>
+  <xsl:param name="targetptr.att"/>
+
+  <xsl:message>
+    <xsl:text>Error: unresolved olink: targetdoc/targetptr = '</xsl:text>
+    <xsl:value-of select="$targetdoc.att"/>
+    <xsl:text>/</xsl:text>
+    <xsl:value-of select="$targetptr.att"/>
+    <xsl:text>'.</xsl:text>
+  </xsl:message>
+</xsl:template>
+
 <!-- Return filename of database -->
 <xsl:template name="select.target.database">
   <xsl:param name="targetdoc.att" select="''"/>
   <xsl:choose>
     <!-- Was the database document parameter not set? -->
     <xsl:when test="$target.database.document = ''">
-      <xsl:message>
-        <xsl:text>Olinks not processed: must specify a </xsl:text>
-        <xsl:text>$target.database.document parameter&#10;</xsl:text>
-        <xsl:text>when using olinks with targetdoc </xsl:text>
-        <xsl:text>and targetptr attributes.</xsl:text>
-      </xsl:message>
+      <xsl:call-template name="olink.error">
+        <xsl:with-param name="message">
+          <xsl:text>olinks not processed: must specify a </xsl:text>
+          <xsl:text>$target.database.document parameter&#10;</xsl:text>
+          <xsl:text>when using olinks with targetdoc </xsl:text>
+          <xsl:text>and targetptr attributes.</xsl:text>
+        </xsl:with-param>
+      </xsl:call-template>
     </xsl:when>
     <xsl:when test="namespace-uri($target.database/*) != ''">
-      <xsl:message>
-        <xsl:text>Olink error: the targetset element and children in '</xsl:text>
-        <xsl:value-of select="$target.database.document"/>
-        <xsl:text>' should not be in any namespace.</xsl:text>
-      </xsl:message>
+      <xsl:call-template name="olink.error">
+        <xsl:with-param name="message">
+          <xsl:text>the targetset element and children in '</xsl:text>
+          <xsl:value-of select="$target.database.document"/>
+          <xsl:text>' should not be in any namespace.</xsl:text>
+        </xsl:with-param>
+      </xsl:call-template>
     </xsl:when>
     <!-- Did it not open? Should be a targetset element -->
     <xsl:when test="not($target.database/*)">
-      <xsl:message>
-        <xsl:text>Olink error: could not open target database '</xsl:text>
-        <xsl:value-of select="$target.database.filename"/>
-        <xsl:text>'.</xsl:text>
-      </xsl:message>
+      <xsl:call-template name="olink.error">
+        <xsl:with-param name="message">
+          <xsl:text>could not open target database '</xsl:text>
+          <xsl:value-of select="$target.database.filename"/>
+          <xsl:text>'.</xsl:text>
+        </xsl:with-param>
+      </xsl:call-template>
     </xsl:when>
     <xsl:otherwise>
       <xsl:value-of select="$target.database.filename"/>
                           select="key('targetdoc-key', $current.docid)[1]/parent::dir"/>
                       <xsl:with-param name="targetdoc" select="$targetdoc"/>
                     </xsl:call-template>
-                  </xsl:for-each >
+                  </xsl:for-each>
                 </xsl:when>
                 <xsl:otherwise>
-                  <xsl:message>
-                    <xsl:text>Olink error: cannot compute relative </xsl:text>
-                    <xsl:text>sitemap path because $current.docid '</xsl:text>
-                    <xsl:value-of select="$current.docid"/>
-                    <xsl:text>' not found in target database.</xsl:text>
-                  </xsl:message>
+                  <xsl:call-template name="olink.error">
+                    <xsl:with-param name="message">
+                      <xsl:text>cannot compute relative </xsl:text>
+                      <xsl:text>sitemap path because $current.docid '</xsl:text>
+                      <xsl:value-of select="$current.docid"/>
+                      <xsl:text>' not found in target database.</xsl:text>
+                    </xsl:with-param>
+                  </xsl:call-template>
                 </xsl:otherwise>
               </xsl:choose>
             </xsl:when>
             <xsl:otherwise>
-              <xsl:message>
-                <xsl:text>Olink warning: cannot compute relative </xsl:text>
-                <xsl:text>sitemap path without $current.docid parameter</xsl:text>
-              </xsl:message>
+              <xsl:call-template name="olink.error">
+                <xsl:with-param name="message">
+                  <xsl:text>cannot compute relative </xsl:text>
+                  <xsl:text>sitemap path without $current.docid parameter</xsl:text>
+                </xsl:with-param>
+              </xsl:call-template>
             </xsl:otherwise>
           </xsl:choose> 
           <!-- In either case, add baseuri from its document entry-->
                     <xsl:value-of 
                             select="$xref-number-and-title-context"/>
                     <xsl:if test="$olink.debug">
-                      <xsl:message>
-                        <xsl:text>Olink error: no gentext template</xsl:text>
-                        <xsl:text> exists for xrefstyle '</xsl:text>
-                        <xsl:value-of select="$xrefstyle"/>
-                        <xsl:text>' for element '</xsl:text>
-                        <xsl:value-of select="$target.elem"/>
-                        <xsl:text>' in language '</xsl:text>
-                        <xsl:value-of select="$lang"/>
-                        <xsl:text>' in context 'xref-number-and-title</xsl:text>
-                        <xsl:text>'. Using template without @style.</xsl:text>
-                      </xsl:message>
+                      <xsl:call-template name="olink.warning">
+                        <xsl:with-param name="message">
+                          <xsl:text>no gentext template</xsl:text>
+                          <xsl:text> exists for xrefstyle '</xsl:text>
+                          <xsl:value-of select="$xrefstyle"/>
+                          <xsl:text>' for element '</xsl:text>
+                          <xsl:value-of select="$target.elem"/>
+                          <xsl:text>' in language '</xsl:text>
+                          <xsl:value-of select="$lang"/>
+                          <xsl:text>' in context 'xref-number-and-title</xsl:text>
+                          <xsl:text>'. Using template without @style.</xsl:text>
+                        </xsl:with-param>
+                      </xsl:call-template>
                     </xsl:if>
                   </xsl:when>
                   <xsl:when test="$xref-number-context != '' and
                                  $xref.number != ''">
                     <xsl:value-of select="$xref-number-context"/>
                     <xsl:if test="$olink.debug">
-                      <xsl:message>
-                        <xsl:text>Olink error: no gentext template</xsl:text>
-                        <xsl:text> exists for xrefstyle '</xsl:text>
-                        <xsl:value-of select="$xrefstyle"/>
-                        <xsl:text>' for element '</xsl:text>
-                        <xsl:value-of select="$target.elem"/>
-                        <xsl:text>' in language '</xsl:text>
-                        <xsl:value-of select="$lang"/>
-                        <xsl:text>' in context 'xref-number</xsl:text>
-                        <xsl:text>'. Using template without @style.</xsl:text>
-                      </xsl:message>
+                      <xsl:call-template name="olink.warning">
+                        <xsl:with-param name="message">
+                          <xsl:text>no gentext template</xsl:text>
+                          <xsl:text> exists for xrefstyle '</xsl:text>
+                          <xsl:value-of select="$xrefstyle"/>
+                          <xsl:text>' for element '</xsl:text>
+                          <xsl:value-of select="$target.elem"/>
+                          <xsl:text>' in language '</xsl:text>
+                          <xsl:value-of select="$lang"/>
+                          <xsl:text>' in context 'xref-number</xsl:text>
+                          <xsl:text>'. Using template without @style.</xsl:text>
+                        </xsl:with-param>
+                      </xsl:call-template>
                     </xsl:if>
                   </xsl:when>
                   <xsl:when test="$xref-context != ''">
                     <xsl:value-of select="$xref-context"/>
                     <xsl:if test="$olink.debug">
-                      <xsl:message>
-                        <xsl:text>Olink error: no gentext template</xsl:text>
+                      <xsl:call-template name="olink.warning">
+                        <xsl:with-param name="message">
+                          <xsl:text>no gentext template</xsl:text>
+                          <xsl:text> exists for xrefstyle '</xsl:text>
+                          <xsl:value-of select="$xrefstyle"/>
+                          <xsl:text>' for element '</xsl:text>
+                          <xsl:value-of select="$target.elem"/>
+                          <xsl:text>' in language '</xsl:text>
+                          <xsl:value-of select="$lang"/>
+                          <xsl:text>' in context 'xref</xsl:text>
+                          <xsl:text>'. Using template without @style.</xsl:text>
+                        </xsl:with-param>
+                      </xsl:call-template>
+                    </xsl:if>
+                  </xsl:when>
+                  <xsl:otherwise>
+                    <xsl:call-template name="olink.warning">
+                      <xsl:with-param name="message">
+                        <xsl:text>no gentext template</xsl:text>
                         <xsl:text> exists for xrefstyle '</xsl:text>
                         <xsl:value-of select="$xrefstyle"/>
                         <xsl:text>' for element '</xsl:text>
                         <xsl:value-of select="$target.elem"/>
                         <xsl:text>' in language '</xsl:text>
                         <xsl:value-of select="$lang"/>
-                        <xsl:text>' in context 'xref</xsl:text>
-                        <xsl:text>'. Using template without @style.</xsl:text>
-                      </xsl:message>
-                    </xsl:if>
-                  </xsl:when>
-                  <xsl:otherwise>
-                    <xsl:message>
-                      <xsl:text>Olink error: no gentext template</xsl:text>
-                      <xsl:text> exists for xrefstyle '</xsl:text>
-                      <xsl:value-of select="$xrefstyle"/>
-                      <xsl:text>' for element '</xsl:text>
-                      <xsl:value-of select="$target.elem"/>
-                      <xsl:text>' in language '</xsl:text>
-                      <xsl:value-of select="$lang"/>
-                      <xsl:text>'. Trying '%t'.</xsl:text>
-                    </xsl:message>
+                        <xsl:text>'. Trying '%t'.</xsl:text>
+                      </xsl:with-param>
+                    </xsl:call-template>
                     <xsl:value-of select="'%t'"/>
                   </xsl:otherwise>
                 </xsl:choose>
           <xsl:copy-of select="$xref.text"/>
         </xsl:when>
         <xsl:otherwise>
-          <xsl:message>
-            <xsl:text>Olink error: no generated text for </xsl:text>
-            <xsl:text>targetdoc/targetptr/lang = '</xsl:text>
-            <xsl:value-of select="$olink.key"/>
-            <xsl:text>'.</xsl:text>
-          </xsl:message>
+          <xsl:call-template name="olink.error">
+            <xsl:with-param name="message">
+              <xsl:text>no generated text for targetdoc/targetptr/lang = '</xsl:text>
+              <xsl:value-of select="$olink.key"/>
+              <xsl:text>'.</xsl:text>
+            </xsl:with-param>
+          </xsl:call-template>
           <xsl:text>????</xsl:text>
         </xsl:otherwise>
       </xsl:choose>
     </xsl:when>
     <xsl:otherwise>
       <xsl:if test="$olink.key != ''">
-        <xsl:message>
-          <xsl:text>Olink error: no generated text for </xsl:text>
-          <xsl:text>targetdoc/targetptr/lang = '</xsl:text>
-          <xsl:value-of select="$olink.key"/>
-          <xsl:text>'.</xsl:text>
-        </xsl:message>
+        <xsl:call-template name="olink.error">
+          <xsl:with-param name="message">
+            <xsl:text>no generated text for targetdoc/targetptr/lang = '</xsl:text>
+            <xsl:value-of select="$olink.key"/>
+            <xsl:text>'.</xsl:text>
+          </xsl:with-param>
+        </xsl:call-template>
       </xsl:if>
       <xsl:text>????</xsl:text>
     </xsl:otherwise>
     </xsl:when>
     <!-- Have we reached the top without a match? -->
     <xsl:when test="local-name($dirnode) != 'dir'" >
-        <xsl:message>Olink error: cannot locate targetdoc <xsl:value-of select="$targetdoc"/> in sitemap</xsl:message>
+      <xsl:call-template name="olink.error">
+        <xsl:with-param name="message">
+          <xsl:text>cannot locate targetdoc </xsl:text>
+          <xsl:value-of select="$targetdoc"/>
+          <xsl:text> in sitemap</xsl:text>
+        </xsl:with-param>
+      </xsl:call-template>
     </xsl:when>
     <!-- Is the target in a descendant? -->
     <xsl:when test="$dirnode/descendant::document/@targetdoc = $targetdoc">
index 93fdfa68bc7908e5929595276cbba7e665d75636..7d2faa0213a541d1c67c0ff6b7d5018f2bd88a3f 100644 (file)
       </xsl:variable>
     
       <xsl:if test="string-length($olink.key) = 0">
-        <xsl:message>
-          <xsl:text>Error: unresolved olink: </xsl:text>
-          <xsl:text>targetdoc/targetptr = '</xsl:text>
-          <xsl:value-of select="$targetdoc.att"/>
-          <xsl:text>/</xsl:text>
-          <xsl:value-of select="$targetptr.att"/>
-          <xsl:text>'.</xsl:text>
-        </xsl:message>
+        <xsl:call-template name="olink.unresolved">
+          <xsl:with-param name="targetdoc.att" select="$targetdoc.att"/>
+          <xsl:with-param name="targetptr.att" select="$targetptr.att"/>
+        </xsl:call-template>
       </xsl:if>
 
       <xsl:variable name="href">
       <fo:page-number-citation ref-id="{$linkend}"/>
     </xsl:when>
     <xsl:otherwise>
-      <xsl:message>
-        <xsl:text>Olink error: no page number linkend for local olink '</xsl:text>
-        <xsl:value-of select="$olink.key"/>
-        <xsl:text>'</xsl:text>
-      </xsl:message>
+      <xsl:call-template name="olink.error">
+        <xsl:with-param name="message">
+          <xsl:text>no page number linkend for local olink '</xsl:text>
+          <xsl:value-of select="$olink.key"/>
+          <xsl:text>'</xsl:text>
+        </xsl:with-param>
+      </xsl:call-template>
     </xsl:otherwise>
   </xsl:choose>
 </xsl:template>
index 3963505bbfe723764bfabd05fe9de4f5da4cdcd2..9dc17185d4738ce19deb8267120341da3e73c5ea 100644 (file)
                           select="key('targetdoc-key', $current.docid)[1]/parent::dir"/>
                       <xsl:with-param name="targetdoc" select="$targetdoc"/>
                     </xsl:call-template>
-                  </xsl:for-each >
+                  </xsl:for-each>
                 </xsl:when>
                 <xsl:otherwise>
-                  <xsl:message>
-                    <xsl:text>Olink error: cannot compute relative </xsl:text>
-                    <xsl:text>sitemap path because $current.docid '</xsl:text>
-                    <xsl:value-of select="$current.docid"/>
-                    <xsl:text>' not found in target database.</xsl:text>
-                  </xsl:message>
+                  <xsl:call-template name="olink.error">
+                    <xsl:with-param name="message">
+                      <xsl:text>cannot compute relative </xsl:text>
+                      <xsl:text>sitemap path because $current.docid '</xsl:text>
+                      <xsl:value-of select="$current.docid"/>
+                      <xsl:text>' not found in target database.</xsl:text>
+                    </xsl:with-param>
+                  </xsl:call-template>
                 </xsl:otherwise>
               </xsl:choose>
             </xsl:when>
             <xsl:otherwise>
-              <xsl:message>
-                <xsl:text>Olink warning: cannot compute relative </xsl:text>
-                <xsl:text>sitemap path without $current.docid parameter</xsl:text>
-              </xsl:message>
+              <xsl:call-template name="olink.error">
+                <xsl:with-param name="message">
+                  <xsl:text>cannot compute relative </xsl:text>
+                  <xsl:text>sitemap path without $current.docid parameter</xsl:text>
+                </xsl:with-param>
+              </xsl:call-template>
             </xsl:otherwise>
           </xsl:choose> 
           <!-- In either case, add baseuri from its document entry-->
index ffb34c48c6812e10f76ca75d4ab67fe575f91cc5..de33ae5a9c037bf290a8234e26cf453dac5b6602 100644 (file)
       </xsl:variable>
     
       <xsl:if test="string-length($olink.key) = 0">
-        <xsl:message>
-          <xsl:text>Error: unresolved olink: </xsl:text>
-          <xsl:text>targetdoc/targetptr = '</xsl:text>
-          <xsl:value-of select="$targetdoc.att"/>
-          <xsl:text>/</xsl:text>
-          <xsl:value-of select="$targetptr.att"/>
-          <xsl:text>'.</xsl:text>
-        </xsl:message>
+        <xsl:call-template name="olink.unresolved">
+          <xsl:with-param name="targetdoc.att" select="$targetdoc.att"/>
+          <xsl:with-param name="targetptr.att" select="$targetptr.att"/>
+        </xsl:call-template>
       </xsl:if>
 
       <xsl:variable name="href">
index 6766bdd3986e6bd0ce35cfd333dd06a5fa0b4fc4..ce1590e1bd72694ac6898b3c866404e365cc7d1f 100644 (file)
                           select="key('targetdoc-key', $current.docid)/parent::dir"/>
                       <xsl:with-param name="targetdoc" select="$targetdoc"/>
                     </xsl:call-template>
-                  </xsl:for-each >
+                  </xsl:for-each>
                 </xsl:when>
                 <xsl:otherwise>
-                  <xsl:message>
-                    <xsl:text>Olink error: cannot compute relative </xsl:text>
-                    <xsl:text>sitemap path because $current.docid '</xsl:text>
-                    <xsl:value-of select="$current.docid"/>
-                    <xsl:text>' not found in target database.</xsl:text>
-                  </xsl:message>
+                  <xsl:call-template name="olink.error">
+                    <xsl:with-param name="message">
+                      <xsl:text>cannot compute relative </xsl:text>
+                      <xsl:text>sitemap path because $current.docid '</xsl:text>
+                      <xsl:value-of select="$current.docid"/>
+                      <xsl:text>' not found in target database.</xsl:text>
+                    </xsl:with-param>
+                  </xsl:call-template>
                 </xsl:otherwise>
               </xsl:choose>
             </xsl:when>
             <xsl:otherwise>
-              <xsl:message>
-                <xsl:text>Olink warning: cannot compute relative </xsl:text>
-                <xsl:text>sitemap path without $current.docid parameter</xsl:text>
-              </xsl:message>
+              <xsl:call-template name="olink.error">
+                <xsl:with-param name="message">
+                  <xsl:text>cannot compute relative </xsl:text>
+                  <xsl:text>sitemap path without $current.docid parameter</xsl:text>
+                </xsl:with-param>
+              </xsl:call-template>
             </xsl:otherwise>
           </xsl:choose> 
           <!-- In either case, add baseuri from its document entry-->