想象一下,我有一个这样的递归algebraic data type(Haskell语法):
data Expr = Zero
| One
| Add Expr Expr
| Mul Expr Expr
我想用XML表示这个,我想要一个XSD架构。
我已经想出如何实现这种语法:
<Expr>
<Add>
<Expr>
<Zero/>
</Expr>
<Expr>
<Mul>
<Expr>
<One/>
</Expr>
<Expr>
<Add>
<Expr>
<One/>
</Expr>
<Expr>
<One/>
</Expr>
</Add>
</Expr>
</Mul>
</Expr>
</Add>
</Expr>
使用此架构:
<xs:complexType name="Expr">
<xs:choice minOccurs="1" maxOccurs="1">
<xs:element minOccurs="1" maxOccurs="1" name="Zero" type="Zero" />
<xs:element minOccurs="1" maxOccurs="1" name="One" type="One" />
<xs:element minOccurs="1" maxOccurs="1" name="Add" type="Add" />
<xs:element minOccurs="1" maxOccurs="1" name="Mul" type="Mul" />
</xs:choice>
</xs:complexType>
<xs:complexType name="Zero">
<xs:sequence>
</xs:sequence>
</xs:complexType>
<xs:complexType name="One">
<xs:sequence>
</xs:sequence>
</xs:complexType>
<xs:complexType name="Add">
<xs:sequence>
<xs:element minOccurs="2" maxOccurs="2" name="Expr" type="Expr" />
</xs:sequence>
</xs:complexType>
<xs:complexType name="Mul">
<xs:sequence>
<xs:element minOccurs="2" maxOccurs="2" name="Expr" type="Expr" />
</xs:sequence>
</xs:complexType>
但我真正想要的是这种语法:
<Add>
<Zero/>
<Mul>
<One/>
<Add>
<One/>
<One/>
</Add>
</Mul>
</Add>
这可能吗?
谢谢!
答案 0 :(得分:3)
使用替代组:
<xs:element name="Expr" abstract="true"/>
<xs:element name="Zero" substitutionGroup="Expr">
<xs:complexType/>
</xs:element>
<xs:element name="One" substitutionGroup="Expr">
<xs:complexType/>
</xs:element>
<xs:element name="Add" substitutionGroup="Expr">
<xs:complexType>
<xs:sequence>
<xs:element minOccurs="2" maxOccurs="2" ref="Expr" />
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="Mul" substitutionGroup="Expr">
<xs:complexType>
<xs:sequence>
<xs:element minOccurs="2" maxOccurs="2" ref="Expr" />
</xs:sequence>
</xs:complexType>
</xs:element>