23 Documentation Elements
목차
This chapter describes a module which may be used for the documentation of the XML elements and element classes which make up any markup scheme, in particular that described by the TEI Guidelines, and also for the automatic generation of schemas or DTDs conforming to that documentation. It should be used also by those wishing to customize or modify these Guidelines in a conformant manner, as further described in chapters 24.3 Customization and 24.4 Conformance and may also be useful in the documentation of any other comparable encoding scheme, even though it contains some aspects which are specific to the TEI and may not be generally applicable.
An overview of the kind of processing environment envisaged for the module described by this chapter may be helpful. In the remainder of this chapter we refer to software which provides such a processing environment as an ODD processor.96 Like any other piece of XML software, an ODD processor may be instantiated in many ways: the current system uses a number of XSLT stylesheets which are freely available from the TEI, but this specification makes no particular assumptions about the tools which will be used to provide an ODD processing environment.
As the name suggests, an ODD processor uses a single XML document to generate multiple outputs. These outputs will include:
- formal reference documentation for elements, attributes, element classes, patterns, etc. such as those provided in 부록 C Elements below;
- detailed descriptive documentation, embedding some parts of the formal reference documentation, such as the tag description lists provided in this and other chapters of these Guidelines;
- declarative code for one or more XML schema languages, such as RELAX NG, W3C Schema, ISO Schematron, or DTD.
The input required to generate these outputs consists of running prose, and special purpose elements documenting the components (elements, classes, etc.) which are to be declared in the chosen schema language. All of this input is encoded in XML using elements defined in this chapter. In order to support more than one schema language, these elements constitute a comparatively high-level model which can then be mapped by an ODD processor to the specific constructs appropriate for the schema language in use. Although some modern schema languages such as RELAX NG or W3C Schema natively support self-documentary features of this kind, we have chosen to retain the ODD model, if only for reasons of compatibility with earlier versions of these Guidelines. For reasons of backwards compatibility, the ISO standard XML schema language RELAX NG (http://www.relaxng.org) may be used as a means of declaring content models and datatypes, but it is also possible to express content models using native TEI XML constructs. We also use the ISO Schematron language to define additional constraints beyond those expressed in the content model, as further discussed in 23.5.2 Additional Constraints below.
In the TEI system, a schema is built by combining element and attribute declarations, more or less as required. Each element is documented by an appropriate specification element and has an identifier unique across the whole TEI scheme. For convenience, these specifications are grouped into a number of discrete modules, which can also be combined more or less as required. Each major chapter of these Guidelines defines a distinct module. Each module declares a number of elements specific to that module, and may also populate particular classes. All classes are available globally, irrespective of the module in which they are declared; particular modules extend the meaning of a class by adding elements or attributes to it. Wherever possible, element content models are defined in terms of classes rather than in terms of specific elements. Modules can also declare particular patterns, which act as short-cuts for commonly used content models or class references.
In the present chapter, we discuss the components needed to support this system. In addition, section 23.1 Phrase Level Documentary Elements discusses some general purpose elements which may be useful in any kind of technical documentation, wherever there is need to talk about technical features of an XML encoding such as element names and attributes. Section 23.2 Modules and Schemas discusses the elements which are used to document XML modules and their high-level components. Section 23.3 Specification Elements discusses the elements which document XML elements and their attributes, element classes, and generic patterns or macros. Finally, section 23.9 Module for Documentation Elements provides a summary overview of the elements provided by this module.
TEI: Phrase Level Documentary Elements⚓︎23.1 Phrase Level Documentary Elements
TEI: Phrase Level Terms⚓︎23.1.1 Phrase Level Terms
In any kind of technical documentation, the following phrase-level elements may be found useful for marking up strings of text which need to be distinguished from the running text because they come from some formal language:
- code 프로그래밍 언어와 같은 형식 언어의 문자적 부호를 포함한다.
lang (형식 언어) 부호가 표현된 형식 언어를 식별하는 이름 - ident (확인소) 형식 언어에서 어떤 종류의 개체에 대한 확인소 또는 이름을 포함한다.
Like other phrase-level elements used to indicate the semantics of a typographically distinct string, these are members of the model.emphLike class. They are available anywhere that running prose is permitted when the module defined by this chapter is included in a schema.
If the cited phrase is a mathematical or chemical formula, the more specific formula element defined by the figures module (15.2 Formulæ and Mathematical Expressions) may be more appropriate.
A further group of similar phrase-level elements is also defined for the special case of representing parts of an XML document:
- att (속성) 현 텍스트 내에 나타나는 속성명을 포함한다.
- gi (요소명) 요소의 이름(일반적 확인소)을 포함한다.
- tag (tag) 속성 명시를 포함하나 시작 및 종료 마크업 구분 문자를 제외한, 완전한 시작 또는 종료 태그의 텍스트를 포함한다.
- val (값) 단일 속성 값을 포함한다.
These elements constitute the model.phrase.xml class, which is also a subclass of model.phrase. They are also available anywhere that running prose is permitted when the module defined by this chapter is included in a schema.
names when they appear in the text; the <gi>tag</gi> element however is used to show how a tag as
such might appear. So one might talk of an occurrence of the <gi>blort</gi> element which had been
tagged <tag>blort type='runcible'</tag>. The <att>type</att> attribute may take any name token as
value; the default value is <val>spqr</val>, in memory of its creator.</p>
Within technical documentation, it is also often necessary to provide more extended examples of usage or to present passages of markup for discussion. The following special elements are provided for these purposes:
- eg (예) 실례적 예의 유형을 포함한다.
- egXML (XML의 예) 어떤 XML 요소 또는 속성의 사용을 나타내는 정형의 단일 XML 예를 포함하며, egXML는 뿌리(최상위) 요소로 기능한다.
Like the code element, the egXML element is used to mark strings of formal code, or passages of XML markup. The eg element may be used to enclose any kind of example, which will typically be rendered as a distinct block, possibly using particular formatting conventions, when the document is processed. It is a specialized form of the more general q element provided by the TEI core module. In documents containing examples of XML markup, the egXML element should be used for preference, as further discussed below in 23.4.2 Exemplification of Components, since the content of this element can be checked for well-formedness.
These elements are added to the class model.egLike when this module is included in a schema. That class is a part of the general model.inter class, thus permitting eg or egXML elements to appear either within or between paragraph-like elements.
TEI: Element and Attribute Descriptions⚓︎23.1.2 Element and Attribute Descriptions
Within the body of a document using this module, the following elements may be used to reference parts of the specification elements discussed in section 23.3 Specification Elements, in particular the brief prose descriptions these provide for elements and attributes.
- specList (명시 목록) 기술 목록이 산문체 문서에 삽입된 위치를 표시한다.
- specDesc (명시 기술) 명시된 요소 또는 부류에 대한 기술이 문서 내 이 지점에 포함되었음을 나타낸다.
atts (속성) 기술이 부가적으로 얻어진 속성명을 제시한다.
<head>Element and Attribute Descriptions</head>
<p>Within the body of a document using this module, the following elements may be used to reference parts of the specification elements
discussed in section <ptr target="#TDcrystals"/>, in particular the brief prose descriptions these provide for elements and attributes.
<specList>
<specDesc key="specList"/>
<specDesc key="specDesc" atts="atts"/>
</specList>
</p>
<p>TEI practice recommends that a <gi>specList</gi> listing the elements under … </p>
<!-- ... -->
</div>
When formatting the ptr element in this example, an ODD processor might simply generate the section number and title of the section referred to, perhaps additionally inserting a link to the section. In a similar way, when processing the specDesc elements, an ODD processor may recover relevant details of the elements being specified (specList and specDesc in this case) from their associated declaration elements: typically, the details recovered will include a brief description of the element and its attributes. These, and other data, will be stored in a specification element elsewhere within the current document, or they may be supplied by the ODD processor in some other way, for example from a database. For this reason, the link to the required specification element is always made using a TEI-defined key rather than an XML IDREF value. The ODD processor uses this key as a means of accessing the specification element required. There is no requirement that this be performed using the XML ID/IDREF mechanism, but there is an assumption that the identifier be unique.
A specDesc generates in the documentation the identifier, and also the contents of the desc child of whatever specification element is indicated by its key attribute, as in the example above. Documentation for any attributes specified by the atts attribute will also be generated as an associated attribute list.
TEI: Modules and Schemas⚓︎23.2 Modules and Schemas
As mentioned above, the primary purpose of this module is to facilitate the documentation and creation of an XML schema derived from the TEI Guidelines. The following elements are provided for this purpose:
- schemaSpec (스키마 명시) TEI 구조 스키마 및 문서를 생성한다.
- moduleSpec (모듈 명시) 하나의 모듈에 대한 구조, 내용 및 목적을 기록한다. 즉, 선언의 이름과 외부적으로 가시적인 그룹
- moduleRef (모듈 참조) 하나의 스키마로 통합된 모듈을 참조한다.
include supplies a list of the elements which are to be copied from the specified module into the schema being defined. except supplies a list of the elements which are not to be copied from the specified module into the schema being defined. - specGrp (명시 그룹) 현 모듈 내에서 사용에 대한 명시를 다양한 방법의 그룹화를 포함한다.
- specGrpRef (명시 그룹에 대한 참조) 참조된 specGrp에 의해 포함된 선언은 이 지점에서 삽입되어야함을 나타낸다.
- attRef (속성 포인터) 속성 또는 속성의 그룹에 대한 정의를 가리킨다.
- elementRef points to the specification for some element which is to be included in a schema.
A module is a convenient way of grouping together element and other declarations, and of associating an externally-visible name with the resulting group. A specification group performs essentially the same function, but the resulting group is not accessible outside the scope of the ODD document in which it is defined, whereas a module can be accessed by name from any TEI schema specification. Elements, and their attributes, element classes, and patterns are all individually documented using further elements described in section 23.3 Specification Elements below; part of that specification includes the name of the module to which the component belongs.
<idno type="FPI">Names and Dates</idno>
<desc>Additional elements for names and dates</desc>
</moduleSpec>
namesdates
. An ODD processor encountering the moduleSpec element above can thus generate a schema fragment for the TEI namesdates module that includes declarations for all the elements (etc.) which reference it.In most realistic applications, it will be desirable to combine more than one module together to form a complete schema. A schema consists of references to one or more modules or specification groups, and may also contain explicit declarations or redeclarations of elements (see further 23.8.1 TEI customizations). Any combination of modules can be used to create a schema 97
A schema can combine references to TEI modules with references to other (non-TEI) modules using different namespaces, for example to include mathematical markup expressed using MathML in a TEI document. By default, the effect of combining modules is to allow all of the components declared by the constituent modules to coexist (where this is syntactically possible: where it is not—for example, because of name clashes—a schema cannot be generated). It is also possible to over-ride declarations contained by a module, as further discussed in section 23.8.1 TEI customizations
It is often convenient to describe and operate on sets of declarations smaller than the whole, and to document them in a specific order: such collections are called specGrps (specification groups). Individual specGrp elements are identified using the global xml:id attribute, and may then be referenced from any point in an ODD document using the specGrpRef element. This is useful if, for example, it is desired to describe particular groups of elements in a specific sequence. Note however that the order in which element declarations appear within the schema code generated from an ODD file element is not in general affected by the order of declarations within a specGrp.
<elementSpec ident="beetroot">
<!-- ... -->
</elementSpec>
<elementSpec ident="east">
<!-- ... -->
</elementSpec>
<elementSpec ident="rose">
<!-- ... -->
</elementSpec>
</specGrp> and two blue ones: <specGrp xml:id="BLUE">
<elementSpec ident="sky">
<!-- ... -->
</elementSpec>
<elementSpec ident="bayou">
<!-- ... -->
</elementSpec>
</specGrp>
</p>
<head>An overview of the imaginary module</head>
<p>The imaginary module contains declarations for coloured things: <specGrpRef target="#RED"/>
<specGrpRef target="#BLUE"/>
</p>
</div>
TEI: Specification Elements⚓︎23.3 Specification Elements
The following elements are used to specify elements, classes, patterns, and datatypes:
- elementSpec (요소 명시) 단일 요소 유형의 구조, 내용 및 목적을 기록한다.
- classSpec (부류 명시) TEI 요소 부류에 대한 참조 정보를 포함한다; 이것은 내용 모델에서 함께 나타나거나, 공통 속성을 공유하거나, 이 둘을 포괄하는
요소들의 그룹이다.
generate 모델 부류의 교체 및 일련의 인스턴스 생성이 참조될 수 있음을 나타낸다. 기본적으로 모든 변이형이 허용된다. - macroSpec (매크로 명시) 유형의 기능 및 구현을 기록한다.
- dataSpec (datatype specification) documents a datatype.
Unlike most elements in the TEI scheme, each of these ‘specification elements’ has a fairly rigid internal structure consisting of a large number of child elements which are always presented in the same order. Furthermore, since these elements all describe markup objects in broadly similar ways, they have several child elements in common. In the remainder of this chapter, we discuss first the elements which are common to all the specification elements, and then those which are specific to a particular type.
Specification elements may appear at any point in an ODD document, both between and within paragraphs as well as inside a specGrp element, but the specification element for any particular component may only appear once (except in the case where a modification is being defined; see further 23.8.1 TEI customizations). The order in which they appear will not affect the order in which they are presented within any schema module generated from the document. In documentation mode, however, an ODD processor will output the schema declarations corresponding with a specification element at the point in the text where they are encountered, provided that they are contained by a specGrp element, as discussed in the previous section. An ODD processor will also associate all declarations found with the nominated module, thus including them within the schema code generated for that module, and it will also generate a full reference description for the object concerned in a catalogue of markup objects. These latter two actions always occur irrespective of whether or not the declaration is included in a specGrp.
TEI: Common Elements⚓︎23.4 Common Elements
This section discusses the child elements common to all of the specification elements; some of these are defined in the core module (3.4.1 Terms and Glosses). These child elements are used to specify the naming, description, exemplification, and classification of the specification elements.
TEI: Description of Components⚓︎23.4.1 Description of Components
- gloss (gloss) 다른 단어나 구에 대한 해설 또는 정의를 제공할 때 사용되는 구나 단어를 표시한다.
- desc (기술) 요소, 속성, 또는 속성 값의 목적과 적용에 대한 간단한 기술을 포함한다.
- equiv (동치) 부모 요소와 동치로 고려되는 성분을 공지시 또는 외부 연결을 통해 명시한다.
uri (표준 자원 확인소(URL)) 부모가 외부 확인소를 통해서 표상하는 기저 개념을 지시한다. filter 이 요소의 실례를 표준 TEI로 변환하는 방법을 포함하는 외부 스크립트를 참조한다. name 부모가 표상하는 기저 개념에 대한 이름을 부여한다. predicate [att.predicate] the condition under which the element bearing this attribute applies, given as an XPath predicate expression. - altIdent (교체 확인소) 어떤 언어에서 요소, 부류, 속성에 대해 권고된 XML 이름을 제시한다.
- listRef (참조 목록) 현 문서 또는 그 밖의 어디든지 이 요소는 논의된 위치에 대한 중요한 참조 목록을 제공한다.
- remarks (remarks) 포함 요소 내에서 다르게 기록된 것이 없다면 요소, 속성, 부류 또는 개체의 사용 예에 관한 논평 또는 토론을 포함한다.
<valItem ident="susp">
<gloss>suspension</gloss>
<desc>the abbreviation provides the first letter(s) of the word or phrase, omitting the
remainder.</desc>
</valItem>
<valItem ident="contr">
<gloss>contraction</gloss>
<desc>the abbreviation omits some letter(s) in the middle.</desc>
</valItem>
<!--...-->
</valList>
Note that the gloss element is needed to explain the significance of the identifier for an item only when this is not apparent, for example because it is abbreviated, as in the above example. It should not be used to provide a full description of the intended meaning (this is the function of the desc element), nor to comment on equivalent values in other schemes (this is the purpose of the equiv element), nor to provide alternative versions of the ident attribute value in other languages (this is the purpose of the altIdent element).
<!--... -->
<desc xml:lang="en"
versionDate="2007-07-21">identifies a word or phrase as belonging to some
language other than that of the surrounding text. </desc>
<!--... -->
</elementSpec>
Both the gloss and desc elements (in addition to exemplum, remarks, and valDesc) are members of att.translatable, and thus carry the versionDate attributre. Where specifications are supplied in multiple languages, these elements may be repeated as often as needed. Each such element should carry both an xml:lang and a versionDate attribute to indicate the language used and the date on which the translated text was last checked against its source.
ns="http://www.example.com/ns/nonTEI">
<equiv filter="http://www.example.com/equiv-filter.xsl"
mimeType="text/xsl" name="bold"/>
<gloss>bold</gloss>
<desc>contains a sequence of characters rendered in a bold face.</desc>
<!-- ... -->
</elementSpec>
<altIdent xml:lang="de">Abkürzung</altIdent>
<!--...-->
</elementSpec>
<attList>
<attDef mode="change" ident="url">
<altIdent>href</altIdent>
</attDef>
<!-- ... -->
</attList>
</elementSpec>
By default, the altIdent of a component is identical to the value of its ident attribute.
<!--... -->
<remarks>
<p>This element is intended for use only where no other element is available to mark the phrase
or words concerned. The global <att>xml:lang</att> attribute should be used in preference to
this element where it is intended to mark the language of the whole of some text element.</p>
<p>The <gi>distinct</gi> element may be used to identify phrases belonging to sublanguages or
registers not generally regarded as true languages.</p>
</remarks>
<!--... -->
</elementSpec>
TEI: Exemplification of Components⚓︎23.4.2 Exemplification of Components
- exemplum (exemplum) 요소의 사용을 나타내는 단일 예를 포함한다. 수의적으로 논평문단과 함께 나타난다.
- eg (예) 실례적 예의 유형을 포함한다.
- egXML (XML의 예) 어떤 XML 요소 또는 속성의 사용을 나타내는 정형의 단일 XML 예를 포함하며, egXML는 뿌리(최상위) 요소로 기능한다.
valid indicates the intended validity of the example with respect to a schema. source [att.global.source] specifies the source from which some aspect of this element is drawn.
The exemplum element is used to combine a single illustrative example with an optional paragraph of commentary following or preceding it. The illustrative example itself may be marked up using either the eg or the egXML element.
When, as here, an example contains valid XML markup, the egXML element should be used. In such a case, it will clearly be necessary to distinguish the markup within the example from the markup of the document itself. In an XML environment, this is easily done by using a different name space for the content of the egXML element. For example:
<p>The <gi>term</gi> element may be used to mark any technical term, thus: <egXML xmlns="http://www.tei-c.org/ns/Examples"> This <term>recursion</term> is giving me a headache.</egXML></p>⚓
Alternatively, the XML tagging within an example may be ‘escaped’, either by using entity references to represent the opening angle bracket, or by wrapping the whole example in a CDATA marked section:
<p>The <gi>term</gi> element may be used to mark any technical term, thus: <egXML xmlns="http://www.tei-c.org/ns/Examples"> This <term>recursion</term> is giving me a headache.</egXML></p>⚓
or, equivalently:
<p>The <gi>term</gi> element may be used to mark any technical term, thus: <egXML xmlns="http://www.tei-c.org/ns/Examples"><![CDATA[ This <term>recursion</term> is giving me a headache.]]></egXML></p>⚓
However, escaping the markup in this way will make it impossible to validate, and should therefore generally be avoided.
If the XML contained in an example is not well-formed then it must either be enclosed in a CDATA marked section, or ‘escaped’ as above: this applies whether the eg or egXML is used. The valid attribute on egXML may be used to indicate the XML validity of the example with respect to some schema, as being valid, invalid, or feasibly valid.
The egXML element should not be used to tag non-XML examples: the general purpose eg or q elements should be used for such purposes.
TEI: Classification of Components⚓︎23.4.3 Classification of Components
In the TEI scheme elements are assigned to one or more classes, which may themselves have subclasses. The following elements are used to indicate class membership:
- classes (classes) 기록된 요소 또는 부류가 원소 또는 하위부류인 모든 부류를 명시한다.
- memberOf 부모 요소 또는 부류의 부류 원소 자격을 명시한다.
key 기록된 요소 또는 부류가 원소 또는 하위부류인 부류의 확인소를 명시한다.
The classes element appears within either the elementSpec or classSpec element. It specifies the classes of which the element or class concerned is a member by means of one or more memberOf child elements. Each such element references a class by means of its key attribute. Classes themselves are defined by the classSpec element described in section 23.6 Class Specifications below.
TEI: Element Specifications⚓︎23.5 Element Specifications
The elementSpec element is used to document an element type, together with its associated attributes. In addition to the elements listed above, it may contain the following subcomponents:
- content (내용 모델) 기록된 스키마에 대한 선언 텍스트를 포함한다.
autoPrefix controls whether or not pattern names generated in the corresponding RELAX NG schema source are automatically prefixed to avoid potential nameclashes. - constraintSpec (constraint on schema) contains a formal constraint, typically expressed in a rule-based
schema language, to which a construct must conform in order to be considered valid
scheme supplies the name of the language in which the constraints are defined 제안값은 다음을 포함한다: 1] schematron (ISO Schematron) - attList (attribute list) 일련의 attDef 요소로서, 이 요소와 연관된 모든 속성에 대한 기록을 포함한다.
org (조직) 목록의 모든 속성이 이용가능하거나(org="group") 그 중 하나만 이용가능한지를 명시한다. - model describes the processing intended for a specified element.
behaviour names the process or function which this processing model uses in order to produce output. 제안값은 다음을 포함한다: 1] alternate; 2] anchor; 3] block; 4] body; 5] break; 6] cell; 7] cit; 8] document; 9] figure; 10] glyph; 11] graphic; 12] heading; 13] index; 14] inline; 15] link; 16] list; 17] listItem; 18] metadata; 19] note; 20] omit; 21] paragraph; 22] row; 23] section; 24] table; 25] text; 26] title
These subcomponents are discussed in the following sections.
TEI: Defining Content Models⚓︎23.5.1 Defining Content Models
As described in Content Models: an Example and Content Model, the content of the element being defined — that is, what elements are allowed inside it, and in what order they are permitted — is described by its content model. The content model is defined by the content child of elementSpec. There are three distinctly different ways of specifying a content model:
- The content model can be described using TEI elements defined by this chapter, as discussed in 23.5.1.1 Defining Content Models: TEI immediately below. Two such TEI elements that may be used to define a content model are dataRef and valList. But because these are most often used to define attribute values, they are discussed separately near the beginning and towards the end of 23.5.3.2 Value Specification, respectively.
- Alternatively, and primarily for backwards compatibility, the content model may be expressed using a RELAX NG pattern. This is discussed in 23.5.1.2 Defining Content Models: RELAX NG, below.
- Lastly, content models may be expressed using a schema language other than TEI or RELAX NG, but no further recommendations on doing so are provided by these Guidelines.
TEI: Defining Content Models: TEI⚓︎23.5.1.1 Defining Content Models: TEI
In the simplest case, the content model of an element may be expressed using a single empty element as the only child of content. This describes the element being defined as empty, meaning a valid instance of said element can not have any content.98
- empty indicates the presence of an empty node within a content model.
More commonly, one or more of the following elements are used to define a content model:
- elementRef points to the specification for some element which is to be included in a schema.
- anyElement indicates the presence of any elements in a content model.
- classRef points to the specification for an attribute or model class which is to be included in a schema.
- macroRef points to the specification for some pattern which is to be included in a schema.
An elementRef provides the name of an element which may appear at a certain point in a content model. An anyElement also asserts that an element may appear at a certain point in a content model, but rather than providing the name of a particular element type that may appear, any element regardless of its name may appear (and may have any attributes). A classRef provides the name of a model class, members of which may appear at a certain point in content model.99 A macroRef provides the name of a predefined macro, the expansion of which is to be inserted at a certain point in a content model.
These three elements are all members of an attribute class which provides attributes that further modify their significance as follows:
- att.repeatable provides attributes for the elements which define component parts of a content model.
minOccurs (빈도의 최소 수) indicates the smallest number of times this component may occur. maxOccurs (빈도의 최대 수) indicates the largest number of times this component may occur.
- sequence indicates that the constructs referenced by its children form a sequence.
- alternate indicates that the constructs referenced by its children form an alternation.
<alternate>
<elementRef key="ptr" minOccurs="1"
maxOccurs="unbounded"/>
<elementRef key="ref" minOccurs="1"
maxOccurs="unbounded"/>
</alternate>
</content>
<alternate>
<sequence>
<elementRef key="sic"/>
<elementRef key="corr"/>
</sequence>
<sequence>
<elementRef key="orig"/>
<elementRef key="reg"/>
</sequence>
<sequence>
<elementRef key="abbr"/>
<elementRef key="expan"/>
</sequence>
</alternate>
</content>
In addition to expressing where certain elements, members of a class of elements, or constructs matching a predefined macro may occur inside an element, a content model may permit a string of zero or more Unicode characters to occur at a certain point in the content model. This is indicated by supplying the element textNode within the content element.
- textNode indicates the presence of a text node in a content model.
If nothing but a textNode element is present inside a content element, valid instances of the element being defined may contain a sequence of zero or more Unicode characters, but may not contain any elements.100
TEI: Defining Content Models: RELAX NG⚓︎23.5.1.2 Defining Content Models: RELAX NG
text
, using the RELAX NG namespace. This model will be copied unchanged to the output
when RELAX NG schemas are being generated. When an XML DTD is being generated, an
equivalent declaration (in this case (#PCDATA)
) will be output.<rng:group>
<rng:ref name="fileDesc"/>
<rng:zeroOrMore>
<rng:ref name="model.teiHeaderPart"/>
</rng:zeroOrMore>
<rng:optional>
<rng:ref name="revisionDesc"/>
</rng:optional>
</rng:group>
</content>
(fileDesc, (%model.teiHeaderPart;)*, revisionDesc?)
.The RELAX NG language does not formally distinguish element names, attribute names,
class names, or macro names: all names are patterns which are handled in the same
way, as the above example shows. Within the TEI scheme, however, different naming
conventions are used to distinguish amongst the objects being named. Unqualified names
(fileDesc
, revisionDesc
) are always element names. Names prefixed with model.
or att.
(e.g. model.teiHeaderPart and att.typed) are always class names. In DTD language, classes are represented by parameter entities
(%model.teiHeaderPart;
in the above example); see further 1 The TEI Infrastructure.
TEI_ident
rather than simply ident
. Most of the time, this behaviour is entirely transparent to the user; the one occasion
when it is not will be where a content model (expressed using RELAX NG syntax) needs
explicitly to reference either the TEI ident or the other one. In such a situation, the autoPrefix attribute on content may be used. For example, suppose that we wish to define a content model for term which permits either a TEI ident or the ident defined by some other vocabulary. A suitable content model would be generated from
the following content element:
TEI: Additional Constraints⚓︎23.5.2 Additional Constraints
In addition to the content element, a set of general constraintSpec elements can be used to express rules about the validity of an element. Like some other specification elements, they are identifiable (using the ident attribute) in order that a TEI customization may override, delete, or change them individually. Each constraintSpec can be expressed in any notation which is found useful; the notation used must be recorded using the scheme attribute.
Schematron is an ISO standard (ISO/IEC 19757-3:2006) that defines a simple XML vocabulary for an ‘assertion language’ which provides a powerful way of expressing constraints on the content of any XML document in addition to those provided by other schema languages. Such constraints can be embedded within a TEI schema specification — including a TEI customization specification — using the methods exemplified in this chapter.101 An ODD processor will typically process any constraintSpec elements in a TEI specification whose scheme attribute indicates that they are expressed in Schematron to create an ISO Schematron schema which may be used to validate document instances. The ISO Schematron schema may be a free-standing document, or may be embedded in the RELAX NG schema output of the ODD processor.
scheme="schematron">
<constraint>
<sch:rule context="tei:relation">
<sch:assert test="@ref or @key or @name">One of the attributes @name, @ref, or @key must be supplied</sch:assert>
</sch:rule>
</constraint>
</constraintSpec>
<constraintSpec ident="active-mutual"
scheme="schematron">
<constraint>
<sch:rule context="tei:relation">
<sch:report test="@active and @mutual">Only one of the attributes @active and @mutual may be supplied</sch:report>
</sch:rule>
</constraint>
</constraintSpec>
<constraintSpec ident="active-passive"
scheme="schematron">
<constraint>
<sch:rule context="tei:relation">
<sch:report test="@passive and not(@active)">the attribute @passive may be supplied only if the attribute @active is supplied</sch:report>
</sch:rule>
</constraint>
</constraintSpec>
queryBinding="xslt3">
<sch:ns prefix="tei"
uri="http://www.tei-c.org/ns/1.0"/>
<sch:ns prefix="xi"
uri="http://www.w3.org/2001/XInclude"/>
<sch:let name="edition"
value="substring-before( /*/tei:teiHeader//tei:editionStmt/tei:edition/@n, '.')"/>
<sch:let name="uses_old_encoding"
value="$edition cast as xs:integer lt 3"/>
</constraintDecl>
$uses_old_encoding
variable is set (to either true()
or false()
) so that Schematron assertions elsewhere in the TEI document can easily test whether
the edition number of the document being checked is 3 or more. (Presumably in this
project there are minor encoding differences between the older and newer editions
which do not merit an entirely different schema, but do merit the occasional different
constraint.)$uses_old_encoding
is defined as a boolean. The first example models the constraint that a TEI div must contain either no subdivisions or at least two of them, with the added complication
that larger subdivisions are provided as separate sectNN.xml files read in using XInclude:
scheme="schematron">
<constraint>
<sch:rule context="tei:div">
<sch:report test="count( tei:div | xi:include[ contains( @href, 'sect') ] ) eq 1">if it contains any
subdivisions, a division must contain at least two of them</sch:report>
</sch:rule>
</constraint>
</constraintSpec>
scheme="schematron">
<constraint>
<sch:rule context="tei:teiHeader">
<sch:assert test="tei:fileDesc/tei:titleStmt/tei:title[@type='introductory']"> an introductory component of the title is expected</sch:assert>
</sch:rule>
</constraint>
</constraintSpec>
<constraintSpec ident="maintitle"
scheme="schematron">
<constraint>
<sch:rule context="tei:teiHeader[ $uses_old_encoding ]">
<sch:assert test="tei:fileDesc/tei:titleStmt/tei:title[@type eq 'main']"> a main title must be supplied</sch:assert>
</sch:rule>
<sch:rule context="tei:teiHeader[ not( $uses_old_encoding ) ]">
<sch:assert test="tei:fileDesc/tei:titleStmt/tei:title[ not( @type eq 'sub' ) ]"> a main title must be supplied</sch:assert>
</sch:rule>
</constraint>
</constraintSpec>
scheme="schematron">
<constraint>
<sch:pattern id="altTags">
<sch:rule context="tei:figure">
<sch:assert test="tei:figDesc or tei:head"> You should provide information in a figure from
which we can construct an alt attribute in HTML </sch:assert>
</sch:rule>
</sch:pattern>
</constraint>
</constraintSpec>
scheme="schematron">
<constraint>
<sch:pattern id="Tables">
<sch:rule context="tei:table">
<sch:assert test="tei:head">A <table> should have a caption, using a <head> element</sch:assert>
<sch:report test="parent::tei:body">Do not use tables to lay out the document body</sch:report>
</sch:rule>
</sch:pattern>
</constraint>
</constraintSpec>
scheme="SPITBOL">
<constraint> (output = leq(title,author) "title and author cannot be the same") </constraint>
</constraintSpec>
TEI: Attribute List Specification⚓︎23.5.3 Attribute List Specification
The attList element is used to document information about a collection of attributes, either within an elementSpec, or within a classSpec. An attribute list can be organized either as a group of attribute definitions, all of which are understood to be available, or as a choice of attribute definitions, of which only one is understood to be available. An attribute list may thus contain nested attribute lists.
The attDef element is used to document a single attribute, using an appropriate selection from the common elements already mentioned and the following :
- attDef (속성 정의) 단일 속성 정의를 포함한다.
usage 속성 또는 요소의 수의성을 명시한다. - datatype (datatype) 선택된 스키마 언어에 의해 정의된 데이터 유형을 참조함으로써, 속성에 대한 선언된 값을 명시한다.
minOccurs (빈도의 최소 수) 정의되고 있는 속성 명시에서 발생할 수 있는 이 유형의 최소 횟수를 나타낸다. maxOccurs (빈도의 최대 수) 정의되고 있는 속성 명시에서 발생할 수 있는 이 유형의 최대 횟수를 나타낸다. - dataRef identifies the datatype of an attribute value, either by referencing an item in an externally defined datatype library, or by pointing to a TEI-defined data specification
- defaultVal (기본 값) 속성에 대한 기본 선언 값을 명시한다.
- valDesc (값 기술) 데이터 유형 요소에 의해 수행된 정보와 더불어 속성이 취할 수 있는 값에 대한 의미적 또는 통사적 제약을 명시한다.
- valList (값 목록) 하나의 속성에 대한 가능한 값을 정의하는 하나 이상의 valItem 요소를 포함한다.
- valItem 가능한 또는 필수적 항목의 목록 내에서 단일 속성 값을 기록한다.
The attList within an elementSpec is used to specify only the attributes which are specific to that particular element. Instances of the element may carry other attributes which are declared by the classes of which the element is a member. These extra attributes, which are shared by other elements, or by all elements, are specified by an attList contained within a classSpec element, as described in section 23.6 Class Specifications below.
TEI: Datatypes⚓︎23.5.3.1 Datatypes
The ‘datatype’ (i.e. the kind of value) for an attribute may be specified using the elements datatype and dataRef. A datatype may be defined in any of the following three ways:
- by reference to an existing TEI datatype definition, itself defined by a dataSpec;
- by use of its name in XML Schema Part 2: Datatypes Second Edition, the widely used datatype library maintained by the W3C as part of the definition of its schema language;
- by referencing its URI within some other datatype library.
The TEI defines a number of datatypes, each with an identifier beginning teidata.
, which are used in preference to the datatypes available natively from a target schema
such as RELAX NG or W3C Schema since the facilities provided by different schema languages
vary so widely. The TEI datatypes available are described in section 1.4.2 Datatype Specifications above. Note that each is, of necessity, mapped eventually to an externally defined
datatype such as W3C Schema's text or name, possibly combined to give more expressivity, or constrained to a particular defined
usage.
<dataFacet name="maxInclusive"
value="360.0"/>
<dataFacet name="minInclusive"
value="-360.0"/>
</dataRef>
A datatype may be used to constrain the textual content of an element, rather than the value of an attribute. But because they are intended for use in defining ranges of attribute values, datatypes may not contain elements or attributes.
<gloss xml:lang="en"
versionDate="2007-06-12">columns</gloss>
<desc versionDate="2005-01-14"
xml:lang="en">specifies the number of columns per page</desc>
<datatype minOccurs="1" maxOccurs="2">
<dataRef key="teidata.count"/>
</datatype>
<remarks xml:lang="en"
versionDate="2017-07-09">
<p>If a single number is given, all pages referenced
have this number of columns. If two numbers are given,
the number of columns per page varies between the
values supplied. Where <att>columns</att> is omitted
the number is assumed to be <val>1</val>.</p>
</remarks>
</attDef>
#a #b #c
or http://example.org http://www.tei-c.org/index.xml
may be supplied. TEI: Value Specification⚓︎23.5.3.2 Value Specification
in <title>Pollard and Redgrave</title>
</valDesc>
<desc>age in years at death</desc>
<datatype>
<dataRef key="teidata.count"/>
</datatype>
<constraintSpec ident="lessThan150"
scheme="schematron">
<constraint>
<sch:rule context="@ageAtDeath">
<sch:assert test=". le 150">age at death must be an integer less than 150</sch:assert>
</sch:rule>
</constraint>
</constraintSpec>
</attDef>
<altIdent xml:lang="fr">dou</altIdent>
<equiv name="unknown"/>
<gloss>dubious</gloss>
<desc>used when the application of this element is doubtful or uncertain</desc>
</valItem>
<valItem ident="req">
<gloss>required</gloss>
</valItem>
<valItem ident="rec">
<gloss>recommended</gloss>
</valItem>
<valItem ident="opt">
<gloss>optional</gloss>
</valItem>
</valList>
<desc versionDate="2005-01-14"
xml:lang="en">characterizes the movement, for example as an
entrance or exit.</desc>
<desc versionDate="2007-12-20"
xml:lang="ko">예를 들어 입장 또는 퇴장과 같은, 이동의 특성을 기술한다.</desc>
<datatype>
<dataRef key="teidata.enumerated"/>
</datatype>
<valList type="open">
<valItem ident="entrance">
<desc versionDate="2007-06-27"
xml:lang="en">character is entering the stage.</desc>
<desc versionDate="2007-12-20"
xml:lang="ko">등장인물이 무대에 등장하고 있다.</desc>
</valItem>
<valItem ident="exit">
<desc versionDate="2007-06-27"
xml:lang="en">character is exiting the stage.</desc>
<desc versionDate="2007-12-20"
xml:lang="ko">등장인물이 무대에서 퇴장하고 있다.</desc>
</valItem>
<valItem ident="onStage">
<desc versionDate="2007-07-04"
xml:lang="en">character moves on stage</desc>
<desc versionDate="2007-12-20"
xml:lang="ko">등장인물이 무대에서 이동한다.</desc>
</valItem>
</valList>
</attDef>
The valList or dataRef elements may also be used (as a child of the content element) to put constraints on the permitted content of an element, as noted at 23.5.1.2 Defining Content Models: RELAX NG. This use is not however supported by all schema languages, and is therefore not recommended if support for non-RELAX NG systems is a consideration.
TEI: Processing Models⚓︎23.5.4 Processing Models
As far as possible, the TEI defines elements and their attributes in a way which is entirely independent of their subsequent processing, since its intention is to maximize the reusability of encoded documents and their use in multiple contexts. Nevertheless, it can be very useful to specify one or more possible models for such processing, both to clarify the intentions of the encoder, and to provide default behaviours for a software engineer to implement when documents conforming to a particular TEI customization are processed. To that end, the following elements may be used to document one or more processing models for a given element.
- model describes the processing intended for a specified element.
- modelGrp (model group) any grouping of model or modelSequence elements with a common output method.
- modelSequence any sequence of model or modelSequence elements which is to be processed as a single set of actions.
One or more of these elements may appear directly within an element specification to define the processing anticipated for that element, more specifically how it should be processed to produce the kind of output indicated by the output attribute. Where multiple such elements appear directly within an elementSpec, they are understood to document mutually exclusive processing models, possibly for different outputs or applicable in different contexts. Alternatively, the modelGrp element may be used to group alternative model elements intended for a single kind of output. The modelSequence element is provided for the case where a sequence of models is to be processed, functioning as a single unit.
A processing model suggests how a given element may be transformed to produce one or more outputs. The model is expressed in terms of behaviours and parameters, using high-level formatting concepts familiar to software engineers and web designers, such as ‘block’ or ‘inline’. As such, it has a different purpose from existing TEI mechanisms for documenting the appearance of source materials, such as the global attributes rend, rendition and style, described in sections 2.3.4.1 Rendition and 3.3.1 What Is Highlighting?. It does not necessarily describe anything present in the original source, nor does it necessarily represent its original structure or semantics. A processing model is a template description, which may be used to simplify the task of producing or customizing the stylesheets needed by a formatting engine or any other form of processor.
TEI: The TEI processing model⚓︎23.5.4.1 The TEI processing model
The model element is used to document the processing model intended for a particular element in an abstract manner, independently of its implementation in whatever processing language is chosen. This is achieved by means of the following attributes and elements:
- model describes the processing intended for a specified element.
predicate [att.predicate] the condition under which the element bearing this attribute applies, given as an XPath predicate expression. behaviour names the process or function which this processing model uses in order to produce output. 제안값은 다음을 포함한다: 1] alternate; 2] anchor; 3] block; 4] body; 5] break; 6] cell; 7] cit; 8] document; 9] figure; 10] glyph; 11] graphic; 12] heading; 13] index; 14] inline; 15] link; 16] list; 17] listItem; 18] metadata; 19] note; 20] omit; 21] paragraph; 22] row; 23] section; 24] table; 25] text; 26] title output the intended output. 샘플 값은 다음을 포함한다 Sample values include: 1] web; 2] print; 3] plain useSourceRendition whether to obey any rendition attribute that is present. cssClass the name of a CSS class which should be associated with this element - outputRendition describes the rendering or appearance intended for all occurrences of an element
in a specified context for a specified type of output.
scope provides a way of defining ‘pseudo-elements’, that is, styling rules applicable to specific sub-portions of an element. 샘플 값은 다음을 포함한다 Sample values include: 1] first-line; 2] first-letter; 3] before; 4] after
The mandatory behaviour attribute defines in broad terms how an element should be processed, for example as a block or as an inline element. The optional predicate attribute may be used to specify a subset of contexts in which this model should be applicable: for example, an element might be treated as a block element in some contexts, but not in others. The output attribute supplies a name for the output for which this model is intended, for example for screen display, for a printed reading copy, for a scholarly publication, etc. The way in which an element should be rendered is declared independently of its behaviour, using either the attribute useSourceRendition or the element outputRendition. These Guidelines recommend that outputRendition be expressed using the W3C Cascading Stylesheet Language (CSS), but other possibilities are not excluded. The particular language used may be documented by means of the styleDefDecl element described in 2.3.5 The Default Style Definition Language Declaration.
TEI: Output Rendition ⚓︎23.5.4.2 Output Rendition
useSourceRendition="true">
<outputRendition>font-style: italic;</outputRendition>
</model>
TEI: CSS Class⚓︎23.5.4.3 CSS Class
<!-- Preserve original rendition for tables which contain @rendition hints -->
<model predicate=".//row/@rendition or .//cell/@rendition"
behaviour="table" useSourceRendition="true"/>
<!-- Use bootstrap for default table styling -->
<model behaviour="table"
useSourceRendition="true"
cssClass="table table-hover table-bordered"/>
</elementSpec>
As discussed further below, the input data available to a processing model is by default the content of the element being processed, together with its child nodes.
TEI: Model Contexts and Outputs⚓︎23.5.4.4 Model Contexts and Outputs
<model predicate="ancestor::p"
behaviour="inline">
<outputRendition>font-style: italic;</outputRendition>
</model>
<model behaviour="block">
<outputRendition>left-margin: 2em;</outputRendition>
</model>
</elementSpec>
When, as here, multiple behaviours are required for the same element, it will often be the case that the appropriate processing will depend on the context. It may however be the case that the choice of an appropriate model will be made on the basis of the intended output. For example, we might wish to define quite different behaviours when a document is to be displayed on a mobile device and when it is to be displayed on a desktop screen. Different behaviours again might be specified for a print version intended for the general reader, and for a print version aimed at the technical specialist.
<model behaviour="inline"
predicate="@rend='inline'">
<outputRendition>font-size: 7pt;</outputRendition>
</model>
<model behaviour="block"
predicate="@rend='block'">
<outputRendition>text-color: red;</outputRendition>
</model>
</modelGrp>
<modelGrp output="print">
<model behaviour="inline"
predicate="@rend='inline'">
<outputRendition>font-size: 12pt;</outputRendition>
</model>
<model behaviour="block"
useSourceRendition="true" predicate="@rend='block'">
<outputRendition>text-align: center;</outputRendition>
</model>
</modelGrp>
TEI: Behaviours and their parameters⚓︎23.5.4.5 Behaviours and their parameters
In the examples above we have used without explanation or definition two simple behaviours: inline and block, but many other behaviours are possible. A list of recommended behaviour names forms part of the specification for the element model. A processing model can specify any named behaviour, some of which have additional parameters. The parameters of a behaviour resemble the arguments of a function in many programming languages: they provide names which can be used to distinguish particular parts of the input data available to the process used to implement the behaviour in question.
The following elements are used to represent and to define parameters:
- param provides a parameter for a model behaviour by supplying its name and an XPath expression
identifying the location of its content.
name a name for the parameter being supplied. 제안값은 다음을 포함한다: 1] alternate; 2] default; 3] height; 4] id; 5] label; 6] level; 7] link; 8] place; 9] type; 10] url; 11] width - paramList list of parameter specifications.
- paramSpec supplies specification for one parameter of a model behaviour.
By default, a processor implementing the TEI processing model for a particular element has available to it as input data the content of the element itself, and all of its children. One or more param elements may be supplied within a model element to specify parameters which modify this, either by selecting particular parts of the default input data, or by selecting data which would not otherwise be available. In either case, the value supplied for the parameter is given as an XPath expression, evaluated with respect to the element node being processed. An arbitrary name (defined in the corresponding paramSpec) is also supplied to a processor to identify each parameter.
<model behaviour="link">
<param name="uri" value="@target"/>
<param name="content" value="."/>
</model>
</elementSpec>
All the parameters available for a given behaviour are defined as a part of the definition of the behaviour itself, as further discussed in section 23.5.4.8 Defining a processing model below.
<model predicate="sic and corr"
behaviour="alternate">
<param name="default" value="corr"/>
<param name="alternate" value="sic"/>
</model>
</elementSpec>
<modelGrp output="web">
<model predicate="sic and corr"
behaviour="alternate">
<param name="default"
value="corr[@cert='high']"/>
<param name="alternate" value="sic"/>
</model>
<model predicate="abbr and expan"
behaviour="alternate">
<param name="default" value="expan[1]"/>
<param name="alternate" value="abbr"/>
</model>
<model predicate="orig and reg"
behaviour="alternate">
<param name="default" value="reg"/>
<param name="alternate" value="orig"/>
</model>
</modelGrp>
</elementSpec>
If nothing matches the XPath defining the value of a particular parameter (e.g. if in the above example there is no correction with cert=high) then the default parameter has no value. It is left to implementors to determine how null-valued parameters should be processed.
TEI: Outputs⚓︎23.5.4.6 Outputs
As noted above, the output attribute is used to associate particular processing models with a specific type of output. The following example documents a range of processing intentions for the date element, intended to cope with at least the following three situations:
- there is text inside the element, and the output is print;
- there is no text inside the element but there is a when attribute, and the output is print;
- there is a when attribute, there is text inside the element, and the output is web
<modelGrp output="print">
<model predicate="text()"
behaviour="inline"/>
<model predicate="@when and not(text())"
behaviour="inline">
<param name="content" value="@when"/>
</model>
</modelGrp>
<model output="web" predicate="@when"
behaviour="alternate">
<param name="default" value="."/>
<param name="alternate" value="@when"/>
</model>
</elementSpec>
For output to print we supply two processing models, one for the simplest case where the content of the date is to be treated as an inline element, and the other for the case where there is no content and the value of the when attribute is to be used in its place. This is specified by a parameter, called content in this example. For output to web, we use the alternate behaviour discussed in the previous section to indicate that by default the content of the element will be used, while retaining access to the value of the when attribute, this time via a parameter called alternate.
TEI: Model sequence⚓︎23.5.4.7 Model sequence
The value of the parameter called place above is an XPath expression supplying an arbitrary string (‘foot’), which is therefore quoted. It is left to implementors to validate or constrain the possible values for such expressions.
TEI: Defining a processing model⚓︎23.5.4.8 Defining a processing model
<desc>create a hyperlink</desc>
<paramList>
<paramSpec ident="content">
<desc>supplies the location of some content describing the link</desc>
</paramSpec>
<paramSpec ident="uri">
<desc>supplies the location of the intended hyperlink</desc>
</paramSpec>
</paramList>
</valItem>
<desc versionDate="2015-08-21"
xml:lang="en">support display of alternative visualisations, for
example by displaying the preferred content, by displaying both in parallel, or by toggling
between the two.</desc>
<paramList>
<paramSpec ident="default">
<desc versionDate="2015-08-21"
xml:lang="en">supplies the location of the preferred
content</desc>
</paramSpec>
<paramSpec ident="alternate">
<desc versionDate="2015-08-21"
xml:lang="en">supplies the location of the alternative
content</desc>
</paramSpec>
</paramList>
</valItem>
The suggested behaviours provided by the model element are informally defined using commonly understood terminology, but specific details of how they should be implemented are left to the implementor. Such decisions may vary greatly depending on the kind of processing environment, the kind of output envisaged, etc. The intention is to reduce as far as possible any requirement for the implementor to be aware of TEI-specific rules, and to maximize the ability of the ODD to express processing intentions without fully specifying an implementation.
TEI: Implementation of Processing Models⚓︎23.5.4.9 Implementation of Processing Models
- If a model element has no child param elements, the action specified by its behaviour should be applied to the whole element node concerned, including its child nodes of whatever type. If that behaviour requires distinguishing particular parts of the input, an implementation may choose either to make those distinctions itself, or to raise an error.
- If a model element has no predicate or output attribute then it is assumed to apply to all instances of the element defined in its parent elementSpec for all outputs. Otherwise its applicability depends on these attributes.
- Only one of the models is to be applied for a particular instance of the element, except when they appear within a modelSequence
- A ‘matching’ model is one where the element to be processed satisfies the XPath in the predicate attribute of the model or modelSequence and the current output method matches the method specified in the output attribute of the model, modelSequence, or a containing modelGrp. A model or modelSequence without a predicate always matches the element to be processed. A model, modelGrp, or modelSequence without an output attribute matches any output method.
- Processing Model implementations must execute only the first matching model or modelSequence in document order.
- If there are two or more model elements provided for an elementSpec but they have different output attributes then the implementation should choose the model appropriate to the desired output.
- If there are two or more model elements provided for an elementSpec but they have different predicate attributes then the implementation should choose the model whose predicate provides the most specific context (where specific is understood in the same way as in XSLT)
predicate="parent::list">
<desc versionDate="2015-03-02"
xml:lang="en">Model for list headings</desc>
<!-- ... -->
</model>
<model behaviour="heading">
<desc versionDate="2016-03-02"
xml:lang="en">Default model for all headings.</desc>
<!-- ... -->
</model>
TEI: Class Specifications⚓︎23.6 Class Specifications
The element classSpec is used to document either an attribute class or a ‘model class’, as defined in section 1.3 The TEI Class System. A corresponding classRef element may be used to select a specific named class from those available.
- classSpec (부류 명시) TEI 요소 부류에 대한 참조 정보를 포함한다; 이것은 내용 모델에서 함께 나타나거나, 공통 속성을 공유하거나, 이 둘을 포괄하는
요소들의 그룹이다.
type 모델 부류 또는 속성 부류 여부를 나타낸다. - classRef points to the specification for an attribute or model class which is to be included
in a schema.
expand indicates how references to this class within a content model should be interpreted. - attList (attribute list) 일련의 attDef 요소로서, 이 요소와 연관된 모든 속성에 대한 기록을 포함한다.
org (조직) 목록의 모든 속성이 이용가능하거나(org="group") 그 중 하나만 이용가능한지를 명시한다.
ident="model.hiLike">
<desc>groups phrase-level elements related to highlighting that have no specific semantics </desc>
<classes>
<memberOf key="model.highlighted"/>
</classes>
</classSpec>
The function of a model class declaration is to provide another way of referring to a group of elements. It does not confer any other properties on the elements which constitute its membership.
The attribute type is used to distinguish between ‘model’ and ‘attribute’ classes. In the case of attribute classes, the attributes provided by membership in the class are documented by an attList element contained within the classSpec. In the case of model classes, no further information is needed to define the class beyond its description, its identifier, and optionally any classes of which it is a member.
When a model class is referenced in the content model of an element (i.e. by means of a classRef element within the content of an elementSpec), its meaning will depend on the value of its expand attribute.
<alternate>
<elementRef key="hi"/>
<elementRef key="it"/>
<elementRef key="bo"/>
</alternate>
</content>
( hi | it | bo )
). However, a content model of <classRef expand="sequence"/>
would be equivalent to the following explicit content model:
<sequence>
<elementRef key="hi"/>
<elementRef key="it"/>
<elementRef key="bo"/>
</sequence>
</content>
( hi, it, bo )
).An attribute class (a classSpec of type atts) contains an attList element which lists the attributes that all the members of that class inherit from it. For example, the class att.interpLike defines a small set of attributes common to all elements which are members of that class: those attributes are listed by the attList element contained by the classSpec for att.interpLike. When processing the documentation elements for elements which are members of that class, an ODD processor is required to extend the attList (or equivalent) for such elements to include any attributes defined by the classSpec elements concerned. There is a single global attribute class, att.global, to which some modules contribute additional attributes when they are included in a schema.
TEI: Macro Specifications⚓︎23.7 Macro Specifications
The macroSpec element is used to declare and document predefined strings or patterns not otherwise documented by the elements described in this section. A corresponding macroRef element may be used to select a specific named pattern from those available. Patterns are used as a shorthand chiefly to describe common content models and datatypes, but may be used for any purpose. The following elements are used to represent patterns:
TEI: Building a TEI Schema⚓︎23.8 Building a TEI Schema
The specification elements, and some of their children, are all members of the att.identified class, from which they inherit the following attributes:
- att.identified key 속성에 의해 참조될 수 있는 요소의 속성을 제시한다.
ident 이 요소가 참조된 확인소를 제공한다. predeclare tei 하부구조 모듈에서 이 대상이 미리 선언되어야 하는지를 설명한다. module 이 대상이 정의되어야 하는 모듈명을 제시한다.
This attribute class is a subclass of the att.combinable class from which it (and some other elements) inherits the following attribute:
- att.combinable provides attributes indicating how multiple references to the same object in a schema
should be combined.
mode 그 부모 모듈에 이 선언의 효과를 명시한다.
This attribute class, in turn, is a subclass of the att.deprecated class, from which it inherits the following attribute:
- att.deprecated provides attributes indicating how a deprecated feature will be treated in future
releases.
validUntil provides a date before which the construct being defined will not be removed.
The validUntil attribute may be used to signal an intent to remove a construct from future versions of the schema being specified.
The elementSpec, attDef and schemaSpec specification elements also have an attribute which determines which namespace to which the object being created will belong. In the case of schemaSpec, this namespace is inherited by all the elements created in the schema, unless they have their own ns.
- att.namespaceable provides attributes indicating the target namespace for an object being created.
These attributes are used by an ODD processor to determine how declarations are to be combined to form a schema or DTD, as further discussed in this section.
TEI: TEI customizations⚓︎23.8.1 TEI customizations
As noted above, a TEI schema is defined by a schemaSpec element containing an arbitrary mixture of explicit declarations for objects (i.e. elements, classes, patterns, or macro specifications) and references to other objects containing such declarations (i.e. references to specification groups, or to modules). A major purpose of this mechanism is to simplify the process of defining user customizations, by providing a formal method for the user to combine new declarations with existing ones, or to modify particular parts of existing declarations.
The value specified for the source attribute, when it is supplied as a URL, specifies any convenient location from which
the relevant ODD files may be obtained. For the current release of the TEI Guidelines,
a URL in the form http://www.tei-c.org/Vault/P5/x.y.z/xml/tei/odd/p5subset.xml
may be used, where x.y.z
represents the P5 version number, e.g. 1.3.0
. Alternatively, if the ODD files are locally installed, it may be more convenient
to supply a value such as ../ODDs/p5subset.xml".
The value for the source attribute may be any form of URI. A set of TEI-conformant specifications in a form directly usable by an ODD processor must be available at the location indicated. When no source value is supplied, an ODD processor may either raise an error or assume that the location of the current release of the TEI Guidelines is intended.
If the source is specified in the form of a private URI, the form recommended is aaa:x.y.z
, where aaa
is a prefix indicating the markup language in use, and x.y.z
indicates the version number. For example, tei:1.2.1
should be used to reference release 1.2.1 of the current TEI Guidelines. When such
a URI is used, it will usually be necessary to translate it before such a file can
be used in blind interchange.
<moduleRef key="core"
except="add del orig reg"/>
<moduleRef key="linking"
include="linkGrp link"/>
</schemaSpec>
<moduleRef key="tei"/>
<!-- ... -->
<classRef key="att.global.linking"
include="corresp"/>
<!-- ... -->
</schemaSpec>
<moduleRef key="header"/>
<moduleRef key="verse"/>
<elementSpec ident="soundClip">
<classes>
<memberOf key="model.pPart.data"/>
</classes>
</elementSpec>
</schemaSpec>
<moduleRef key="header"/>
<moduleRef key="verse"/>
<elementSpec ident="soundClip">
<classes>
<memberOf key="model.pPart.data"/>
</classes>
<attList>
<attRef class="att.global.source"
name="source"/>
</attList>
</elementSpec>
</schemaSpec>
<moduleRef key="header"/>
<moduleRef key="teistructure"/>
<elementSpec ident="head" mode="change">
<content>
<macroRef key="macro.xtext"/>
</content>
</elementSpec>
</schemaSpec>
mode="change"
has the effect of over-riding only those children elements of the elementSpec which appear both in the original specification and in the new specification supplied
above: content in this example. Note that if the value for mode were replace, the effect would be to replace all children elements of the original specification
with the the children elements of the new specification, and thus (in this example)
to delete all of them except content.A schema may not contain more than two declarations for any given component. The value of the mode attribute is used to determine exactly how the second declaration (and its constituents) should be combined with the first. The following table summarizes how a processor should resolve duplicate declarations; the term identifiable refers to those elements which can have a mode attribute:
mode value | existing declaration | effect |
add | no | add new declaration to schema; process its children in add mode |
add | yes | raise error |
replace | no | raise error |
replace | yes | retain existing declaration; process new children in replace mode; ignore existing children |
change | no | raise error |
change | yes | process identifiable children according to their modes; process unidentifiable children in replace mode; retain existing children where no replacement or change is provided |
delete | no | raise error |
delete | yes | ignore existing declaration and its children |
TEI: Combining TEI and Non-TEI Modules⚓︎23.8.2 Combining TEI and Non-TEI Modules
This states that when the declarations from the svg11.rng module are combined with those from the other modules, the declaration for the model class model.graphicLike in the TEI module should be extended to include the element <svg:svg> as an alternative. This has the effect that elements in the TEI scheme which define their content model in terms of that element class (notably figure) can now include it. A RELAX NG schema generated from such a specification can be used to validate documents in which the TEI figure element contains any valid SVG representation of a graphic, embedded within an <svg:svg> element.
TEI: Linking Schemas to XML Documents⚓︎23.8.3 Linking Schemas to XML Documents
Schemas can be linked to XML documents by means of the <?xml-model?> processing instruction described in the W3C Working Group Note Associating Schemas with XML documents (https://www.w3.org/TR/xml-model/). <?xml-model?> can be used for any type of schema, and may be used for multiple schemas:
<?xml-model href="tei_tite.rng" type="application/xml" ?> <?xml-model href="checkLinks.sch" type="application/xml" schematypens="http://purl.oclc.org/dsdl/schematron" ?> <?xml-model href="tei_tite.odd" type="application/tei+xml" schematypens="http://www.tei-c.org/ns/1.0" ?>⚓
This example includes a standard RELAX NG schema, a Schematron schema which might be used for checking that all pointing attributes point at existing targets, and also a link to the TEI ODD file from which the RELAX NG schema was generated. See also 2.3.10 The Schema Specification for details of another method of linking an ODD specification into your file by including a schemaSpec element in encodingDesc.
TEI: Module for Documentation Elements⚓︎23.9 Module for Documentation Elements
The module described in this chapter makes available the following components:
- 모듈 tagdocs: Documentation of TEI and other XML markup languages
-
- 정의 요소: altIdent alternate anyElement att attDef attList attRef classRef classSpec classes code constraint constraintDecl constraintSpec content dataFacet dataRef dataSpec datatype defaultVal eg egXML elementRef elementSpec empty equiv exemplum gi ident listRef macroRef macroSpec memberOf model modelGrp modelSequence moduleRef moduleSpec outputRendition param paramList paramSpec remarks schemaSpec sequence specDesc specGrp specGrpRef specList tag textNode val valDesc valItem valList
- 정의 부류: att.combinable att.deprecated att.identified att.namespaceable att.predicate att.repeatable att.translatable model.contentPart
The selection and combination of modules to form a TEI schema is described in 1.2 Defining a TEI Schema.
The elements described in this chapter are all members of one of three classes: model.oddDecl, model.oddRef, or model.phrase.xml, with the exceptions of schemaSpec (a member of model.divPart) and both eg and egXML (members of model.common and model.egLike). All of these classes are declared along with the other general TEI classes, in the basic structure module documented in 1 The TEI Infrastructure.
In addition, some elements are members of the att.identified class, which is documented in 23.8.1 TEI customizations above.