1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270
|
<?xml version="1.0" encoding="utf-8"?>
<!--
The DocBook Schema Version 5.2
OASIS Standard
06 February 2024
Copyright (c) OASIS Open 2024. All Rights Reserved.
Source: https://docs.oasis-open.org/docbook/docbook/v5.2/os/sch/
Link to latest version of specification: https://docs.oasis-open.org/docbook/docbook/v5.2/docbook-v5.2.html
-->
<s:schema xmlns:db="http://docbook.org/ns/docbook"
xmlns:rng="http://relaxng.org/ns/structure/1.0"
xmlns:s="http://purl.oclc.org/dsdl/schematron"
queryBinding="xslt2">
<s:ns prefix="db" uri="http://docbook.org/ns/docbook"/>
<s:ns prefix="xlink" uri="http://www.w3.org/1999/xlink"/>
<s:ns prefix="trans" uri="http://docbook.org/ns/transclusion"/>
<s:pattern>
<s:title>Callout cross reference constraint</s:title>
<s:rule context="db:callout[@arearefs]">
<s:assert test="every $id in tokenize(current()/@arearefs) satisfies (every $ar in //*[@xml:id = $id] satisfies (local-name($ar) = ('areaset', 'area', 'co') and namespace-uri($ar) = 'http://docbook.org/ns/docbook'))">@arearefs on callout must point to a areaset, area, or co.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Cardinality of segments and titles</s:title>
<s:rule context="db:seglistitem">
<s:assert test="count(db:seg) = count(../db:segtitle)">The number of seg elements must be the same as the number of segtitle elements in the parent segmentedlist</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Constraint cross reference constraint</s:title>
<s:rule context="db:constraint[@linkend]">
<s:assert test="local-name(//*[@xml:id=current()/@linkend]) = 'constraintdef' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'">@linkend on constraint must point to a constraintdef.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Element exclusion</s:title>
<s:rule context="db:annotation">
<s:assert test="not(.//db:annotation)">annotation must not occur among the children or descendants of annotation</s:assert>
</s:rule>
<s:rule context="db:caution">
<s:assert test="not(.//db:caution)">caution must not occur among the children or descendants of caution</s:assert>
<s:assert test="not(.//db:danger)">danger must not occur among the children or descendants of caution</s:assert>
<s:assert test="not(.//db:important)">important must not occur among the children or descendants of caution</s:assert>
<s:assert test="not(.//db:note)">note must not occur among the children or descendants of caution</s:assert>
<s:assert test="not(.//db:tip)">tip must not occur among the children or descendants of caution</s:assert>
<s:assert test="not(.//db:warning)">warning must not occur among the children or descendants of caution</s:assert>
</s:rule>
<s:rule context="db:danger">
<s:assert test="not(.//db:caution)">caution must not occur among the children or descendants of danger</s:assert>
<s:assert test="not(.//db:danger)">danger must not occur among the children or descendants of danger</s:assert>
<s:assert test="not(.//db:important)">important must not occur among the children or descendants of danger</s:assert>
<s:assert test="not(.//db:note)">note must not occur among the children or descendants of danger</s:assert>
<s:assert test="not(.//db:tip)">tip must not occur among the children or descendants of danger</s:assert>
<s:assert test="not(.//db:warning)">warning must not occur among the children or descendants of danger</s:assert>
</s:rule>
<s:rule context="db:important">
<s:assert test="not(.//db:caution)">caution must not occur among the children or descendants of important</s:assert>
<s:assert test="not(.//db:danger)">danger must not occur among the children or descendants of important</s:assert>
<s:assert test="not(.//db:important)">important must not occur among the children or descendants of important</s:assert>
<s:assert test="not(.//db:note)">note must not occur among the children or descendants of important</s:assert>
<s:assert test="not(.//db:tip)">tip must not occur among the children or descendants of important</s:assert>
<s:assert test="not(.//db:warning)">warning must not occur among the children or descendants of important</s:assert>
</s:rule>
<s:rule context="db:note">
<s:assert test="not(.//db:caution)">caution must not occur among the children or descendants of note</s:assert>
<s:assert test="not(.//db:danger)">danger must not occur among the children or descendants of note</s:assert>
<s:assert test="not(.//db:important)">important must not occur among the children or descendants of note</s:assert>
<s:assert test="not(.//db:note)">note must not occur among the children or descendants of note</s:assert>
<s:assert test="not(.//db:tip)">tip must not occur among the children or descendants of note</s:assert>
<s:assert test="not(.//db:warning)">warning must not occur among the children or descendants of note</s:assert>
</s:rule>
<s:rule context="db:tip">
<s:assert test="not(.//db:caution)">caution must not occur among the children or descendants of tip</s:assert>
<s:assert test="not(.//db:danger)">danger must not occur among the children or descendants of tip</s:assert>
<s:assert test="not(.//db:important)">important must not occur among the children or descendants of tip</s:assert>
<s:assert test="not(.//db:note)">note must not occur among the children or descendants of tip</s:assert>
<s:assert test="not(.//db:tip)">tip must not occur among the children or descendants of tip</s:assert>
<s:assert test="not(.//db:warning)">warning must not occur among the children or descendants of tip</s:assert>
</s:rule>
<s:rule context="db:warning">
<s:assert test="not(.//db:caution)">caution must not occur among the children or descendants of warning</s:assert>
<s:assert test="not(.//db:danger)">danger must not occur among the children or descendants of warning</s:assert>
<s:assert test="not(.//db:important)">important must not occur among the children or descendants of warning</s:assert>
<s:assert test="not(.//db:note)">note must not occur among the children or descendants of warning</s:assert>
<s:assert test="not(.//db:tip)">tip must not occur among the children or descendants of warning</s:assert>
<s:assert test="not(.//db:warning)">warning must not occur among the children or descendants of warning</s:assert>
</s:rule>
<s:rule context="db:caption">
<s:assert test="not(.//db:caution)">caution must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:danger)">danger must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:equation)">equation must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:example)">example must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:figure)">figure must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:important)">important must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:note)">note must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:sidebar)">sidebar must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:table)">table must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:task)">task must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:tip)">tip must not occur among the children or descendants of caption</s:assert>
<s:assert test="not(.//db:warning)">warning must not occur among the children or descendants of caption</s:assert>
</s:rule>
<s:rule context="db:equation">
<s:assert test="not(.//db:equation)">equation must not occur among the children or descendants of equation</s:assert>
<s:assert test="not(.//db:example)">example must not occur among the children or descendants of equation</s:assert>
<s:assert test="not(.//db:figure)">figure must not occur among the children or descendants of equation</s:assert>
<s:assert test="not(.//db:table)">table must not occur among the children or descendants of equation</s:assert>
</s:rule>
<s:rule context="db:example">
<s:assert test="not(.//db:equation)">equation must not occur among the children or descendants of example</s:assert>
<s:assert test="not(.//db:example)">example must not occur among the children or descendants of example</s:assert>
<s:assert test="not(.//db:figure)">figure must not occur among the children or descendants of example</s:assert>
<s:assert test="not(.//db:table)">table must not occur among the children or descendants of example</s:assert>
</s:rule>
<s:rule context="db:figure">
<s:assert test="not(.//db:equation)">equation must not occur among the children or descendants of figure</s:assert>
<s:assert test="not(.//db:example)">example must not occur among the children or descendants of figure</s:assert>
<s:assert test="not(.//db:figure)">figure must not occur among the children or descendants of figure</s:assert>
<s:assert test="not(.//db:table)">table must not occur among the children or descendants of figure</s:assert>
</s:rule>
<s:rule context="db:table">
<s:assert test="not(.//db:equation)">equation must not occur among the children or descendants of table</s:assert>
<s:assert test="not(.//db:example)">example must not occur among the children or descendants of table</s:assert>
<s:assert test="not(.//db:figure)">figure must not occur among the children or descendants of table</s:assert>
</s:rule>
<s:rule context="db:footnote">
<s:assert test="not(.//db:caution)">caution must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:danger)">danger must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:epigraph)">epigraph must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:equation)">equation must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:example)">example must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:figure)">figure must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:footnote)">footnote must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:important)">important must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:note)">note must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:sidebar)">sidebar must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:table)">table must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:task)">task must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:tip)">tip must not occur among the children or descendants of footnote</s:assert>
<s:assert test="not(.//db:warning)">warning must not occur among the children or descendants of footnote</s:assert>
</s:rule>
<s:rule context="db:sidebar">
<s:assert test="not(.//db:sidebar)">sidebar must not occur among the children or descendants of sidebar</s:assert>
</s:rule>
<s:rule context="db:entry">
<s:assert test="not(.//db:informaltable)">informaltable must not occur among the children or descendants of entry</s:assert>
<s:assert test="not(.//db:table)">table must not occur among the children or descendants of entry</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Footnote reference type constraint</s:title>
<s:rule context="db:footnoteref">
<s:assert test="local-name(//*[@xml:id=current()/@linkend]) = 'footnote' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'">@linkend on footnoteref must point to a footnote.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Glossary 'firstterm' type constraint</s:title>
<s:rule context="db:firstterm[@linkend]">
<s:assert test="local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'">@linkend on firstterm must point to a glossentry.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Glossary 'glossterm' type constraint</s:title>
<s:rule context="db:glossterm[@linkend]">
<s:assert test="local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'">@linkend on glossterm must point to a glossentry.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Glossary 'seealso' type constraint</s:title>
<s:rule context="db:glossseealso[@otherterm]">
<s:assert test="local-name(//*[@xml:id=current()/@otherterm]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@otherterm]) = 'http://docbook.org/ns/docbook'">@otherterm on glossseealso must point to a glossentry.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Glossary term definition constraint</s:title>
<s:rule context="db:termdef">
<s:assert test="count(db:firstterm) = 1">A termdef must contain exactly one firstterm</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Glosssary 'see' type constraint</s:title>
<s:rule context="db:glosssee[@otherterm]">
<s:assert test="local-name(//*[@xml:id=current()/@otherterm]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@otherterm]) = 'http://docbook.org/ns/docbook'">@otherterm on glosssee must point to a glossentry.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Indexterm 'startref' type constraint</s:title>
<s:rule context="db:indexterm[@startref]">
<s:assert test="//*[@xml:id=current()/@startref]/@class='startofrange'">@startref on indexterm must point to a startofrange indexterm.</s:assert>
<s:assert test="local-name(//*[@xml:id=current()/@startref]) = 'indexterm' and namespace-uri(//*[@xml:id=current()/@startref]) = 'http://docbook.org/ns/docbook'">@startref on indexterm must point to an indexterm.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Production recap cross reference constraint</s:title>
<s:rule context="db:productionrecap[@linkend]">
<s:assert test="local-name(//*[@xml:id=current()/@linkend]) = 'production' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'">@linkend on productionrecap must point to a production.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Root must have version</s:title>
<s:rule context="/db:assembly">
<s:assert test="@version">If this element is the root element, it must have a version attribute.</s:assert>
</s:rule>
<s:rule context="/db:resources">
<s:assert test="@version">If this element is the root element, it must have a version attribute.</s:assert>
</s:rule>
<s:rule context="/db:structure">
<s:assert test="@version">If this element is the root element, it must have a version attribute.</s:assert>
</s:rule>
<s:rule context="/db:module">
<s:assert test="@version">If this element is the root element, it must have a version attribute.</s:assert>
</s:rule>
<s:rule context="/db:relationships">
<s:assert test="@version">If this element is the root element, it must have a version attribute.</s:assert>
</s:rule>
<s:rule context="/db:transforms">
<s:assert test="@version">If this element is the root element, it must have a version attribute.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Specification of renderas</s:title>
<s:rule context="db:structure">
<s:assert test="not(@renderas and db:output/@renderas)">The renderas attribute can be specified on either the structure or output, but not both.</s:assert>
</s:rule>
<s:rule context="db:module">
<s:assert test="not(@renderas and db:output/@renderas)">The renderas attribute can be specified on either the structure or output, but not both.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Suffix fixup must be specified</s:title>
<s:rule context="db:*[@trans:suffix]">
<s:assert test="@trans:idfixup = 'suffix'">If a suffix is specified, suffix ID fixup must also be specified.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>Synopsis fragment type constraint</s:title>
<s:rule context="db:synopfragmentref">
<s:assert test="local-name(//*[@xml:id=current()/@linkend]) = 'synopfragment' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'">@linkend on synopfragmentref must point to a synopfragment.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>XLink arc placement</s:title>
<s:rule context="*[@xlink:type='arc']">
<s:assert test="parent::*[@xlink:type='extended']">An XLink arc type element must occur as the direct child of an XLink extended type element.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>XLink extended placement</s:title>
<s:rule context="*[@xlink:type='extended']">
<s:assert test="not(parent::*[@xlink:type='extended'])">An XLink extended type element may not occur as the direct child of an XLink extended type element.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>XLink locator placement</s:title>
<s:rule context="*[@xlink:type='locator']">
<s:assert test="parent::*[@xlink:type='extended']">An XLink locator type element must occur as the direct child of an XLink extended type element.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>XLink resource placement</s:title>
<s:rule context="*[@xlink:type='resource']">
<s:assert test="parent::*[@xlink:type='extended']">An XLink resource type element must occur as the direct child of an XLink extended type element.</s:assert>
</s:rule>
</s:pattern>
<s:pattern>
<s:title>XLink title placement</s:title>
<s:rule context="*[@xlink:type='title']">
<s:assert test="parent::*[@xlink:type='extended'] or parent::*[@xlink:type='locator'] or parent::*[@xlink:type='arc']">An XLink title type element must occur as the direct child of an XLink extended, locator, or arc type element.</s:assert>
</s:rule>
</s:pattern>
</s:schema>
|