<alt>

<alt> 要素などが選択的である場合のいち選択肢を示す. 16.8 Alternation
モジュール linking — 16 Linking, Segmentation, and Alignment
グローバル属性の他 att.pointing (@target, @evaluate) att.typed (@type, @subtype)
targets 当該選択肢の識別子を示す.
状態 任意
データ型 2–∞ occurrences of 

<rng:ref name="data.pointer"/>
data.pointer
空白文字で区切られる
Each value specified must be the same as that specified as value for an xml:id attribute for some other element in the current document.
mode 示された選択肢の選択度を示す.
状態 推薦される
正当な値:
excl
(exclusive) 高々ひとつしか選択できない.
incl
(inclusive) 複数を選択できる.
weights 属性modeの値がexclの場合,該当する選択肢 の出現度を示す. 属性modeの値がinclの場合,該当する選択肢の 少なくとも1つが出現する場合の出現度を示す.
状態 任意
データ型 2–∞ occurrences of 

<rng:ref name="data.probability"/>
data.probability
空白文字で区切られる
a whitespace-separated list of probability values in the range from 0 to 1.
解説
属性modeの値がexclの場合,各選択肢の出 現度の合計は1になる必要がある.属性mode値が inclの場合,各出現度は,0から1の範囲である必要があ る.
当該モジュールを使用するもの
下位 空要素
宣言

<rng:element name="alt">
 <rng:ref name="att.global.attributes"/>
 <rng:ref name="att.pointing.attributes"/>
 <rng:ref name="att.typed.attributes"/>
 <rng:optional>
  <rng:attribute name="targets">
   <rng:list>
    <rng:ref name="data.pointer"/>
    <rng:ref name="data.pointer"/>
    <rng:zeroOrMore>
     <rng:ref name="data.pointer"/>
    </rng:zeroOrMore>
   </rng:list>
  </rng:attribute>
 </rng:optional>
 <rng:optional>
  <rng:attribute name="mode">
   <rng:choice>
    <rng:value>excl</rng:value>
    <rng:value>incl</rng:value>
   </rng:choice>
  </rng:attribute>
 </rng:optional>
 <rng:optional>
  <rng:attribute name="weights">
   <rng:list>
    <rng:ref name="data.probability"/>
    <rng:ref name="data.probability"/>
    <rng:zeroOrMore>
     <rng:ref name="data.probability"/>
    </rng:zeroOrMore>
   </rng:list>
  </rng:attribute>
 </rng:optional>
 <rng:empty/>
</rng:element>
element alt
{
   att.global.attributes,
   att.pointing.attributes,
   att.typed.attributes,
   attribute targets { list { data.pointer, data.pointer, data.pointer* } }?,
   attribute mode { "excl" | "incl" }?,
   attribute weights
   {
      list { data.probability, data.probability, data.probability* }
   }?,
   empty
}
Schematron

<sch:report test="@target and @targets">You may not supply both
@target and @targets</sch:report>
Schematron

<sch:report test="not(@target) and not(@targets)">You must
supply either @target or @targets</sch:report>
Schematron

<sch:assert test="contains(@target,' ')">You must supply at least two
values for @target</sch:assert>
<alt mode="excl" targets="#we.fun #we.sun" weights="0.5 0.5"/>