<relation>
| <relation> (relation) décrit tout type de relation ou de lien à l'intérieur d'un groupe donné de participants. [13.3.2.3 Personal Relationships] | |||||||||||||||||||||||||||||||||
| Module | namesdates — Names, Dates, People, and Places | ||||||||||||||||||||||||||||||||
| Attributs | att.global (@xml:id, @n, @xml:lang, @rend, @style, @rendition, @xml:base, @xml:space)  (att.global.linking (@corresp, @synch, @sameAs, @copyOf, @next, @prev, @exclude, @select))  (att.global.analytic (@ana))  (att.global.facs (@facs))  (att.global.change (@change)) att.datable (@calendar, @period)  (att.datable.w3c (@when, @notBefore, @notAfter, @from, @to))  (att.datable.iso (@when-iso, @notBefore-iso, @notAfter-iso, @from-iso, @to-iso))  (att.datable.custom (@when-custom, @notBefore-custom, @notAfter-custom, @from-custom, @to-custom, @datingPoint, @datingMethod)) att.editLike (@evidence, @instant)  (att.dimensions (@unit, @quantity, @extent, @precision, @scope) (att.ranging (@atLeast, @atMost, @min, @max, @confidence)) )  (att.responsibility (@cert, @resp) (att.source (@source)) ) att.canonical (@key, @ref) att.sortable (@sortKey) 
 | ||||||||||||||||||||||||||||||||
| Membre du | |||||||||||||||||||||||||||||||||
| Contenu dans | namesdates: listEvent listNym listOrg listPerson listPlace listRelation relationGrp | ||||||||||||||||||||||||||||||||
| Peut contenir | core: desc | ||||||||||||||||||||||||||||||||
| Declaration | 
 element relation { att.global.attributes, att.global.linking.attributes, att.global.analytic.attributes, att.global.facs.attributes, att.global.change.attributes, att.datable.attributes, att.datable.w3c.attributes, att.datable.iso.attributes, att.datable.custom.attributes, att.editLike.attributes, att.dimensions.attributes, att.ranging.attributes, att.responsibility.attributes, att.source.attributes, att.canonical.attributes, att.sortable.attributes, attribute type { "social" | "personal" | "other" | xsd:Name }?, attribute name { data.enumerated }?, ( attribute active { list { data.pointer+ } }? | attribute mutual { list { data.pointer+ } }? ), attribute passive { list { data.pointer+ } }?, desc? } | ||||||||||||||||||||||||||||||||
| Schematron | <s:assert test="@ref or @key or @name">One of the attributes 'name', 'ref' or 'key' must be supplied</s:assert> | ||||||||||||||||||||||||||||||||
| Schematron | <s:report test="@active and @mutual">Only one of the attributes @active and @mutual may be supplied</s:report> | ||||||||||||||||||||||||||||||||
| Schematron | <s:report test="@passive and not(@active)">the attribute 'passive' may be supplied only if the attribute 'active' is supplied</s:report> | ||||||||||||||||||||||||||||||||
| Exemple | <relation type="social" name="supervisor" active="#fr_p1" passive="#p2 #p3 #p4"/> Cela indique que la personne avec l'identifiant p1 est le superviseur des personnes p2, p3 et p4. | ||||||||||||||||||||||||||||||||
| Exemple | <relation type="personal" name="friends" mutual="#fr_p2 #fr_p3 #fr_p4"/> Cela indique que p2, p3 et p4 sont tous amis. | ||||||||||||||||||||||||||||||||
| Note | Un seul des attributs active et mutual peut être fourni ; l'attribut passive ne peut être utilisé que si l'attribut active est fourni. Tous les langages de schéma ne sont pas capables d'exprimer la totalité de ces contraintes. | ||||||||||||||||||||||||||||||||
