W3C

Ruby Annotation

W3C Working Draft 17 December 1999

This version:
http://www.w3.org/TR/1999/WD-ruby-19991217
(ZIP archive)
Latest version:
http://www.w3.org/TR/ruby
Previous version:
http://www.w3.org/TR/1999/WD-ruby-19990924
Editors:
Marcin Sawicki (until 10 October, 1999)
Michel Suignard, Microsoft
Masayasu Ishikawa (石川 雅康), W3C
Martin Dürst, W3C
(See Acknowledgements for additional contributors)

Abstract

"Ruby" are short runs of text alongside the base text, typically used in East Asian documents to indicate pronunciation or to provide a short annotation. This specification defines markup for ruby. The specification is written so that this markup for ruby can be included as a module of XHTML 1.1 [XHTML11].

Status of This Document

The W3C Internationalization Working Group (I18N WG) (members only), with this 17 December 1999 Last Call Working Draft, invites comment on this specification. The Last Call period begins 17 December 1999 and ends 14 January 2000.

This is a W3C Working Draft for review by W3C members and other interested parties. It is a draft document and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use W3C Working Drafts as reference material or to cite them as other than "work in progress". The W3C will not allow early implementation to constrain its ability to make changes to this specification prior to final release. A list of current W3C Recommendations and other technical documents can be found at http://www.w3.org/TR.

After last call comments have been addressed, the Working Group expects to advance this specification to Candidate Recommendation, and then to Proposed Recommendation together with XHTML 1.1, into which it will be included by reference. While the actual markup structure will not be changed at that point in the process, the I18N WG and the editors will make the necessary technical adjustments in notation if such adjustments become necessary as a consequence of changes to XHTML 1.1.

Please send comments and questions regarding this document to i18n-editor@w3.org (archived for W3C members). Comments in languages other than English, in particular Japanese, are also welcome. Public discussion on this specification may take place on the mailing list www-international@w3.org (archive).

Due to its subject matter, and to make the examples more realistic, this document includes examples using a wide range of characters. Not all user agents may be able to display all characters, changing the configuration can improve the situation. Also, great care has been taken to serve this document in various character encodings to cover a wide range of user agents and configurations.


Contents


1.  Introduction

This section is informative.

1.1  What is ruby?

"Ruby" is the commonly used name for a run of text that appears in the immediate vicinity of another run of text, referred to as the "base". Ruby serve as a pronunciation guide or a short annotation associated with the base text. Ruby are used frequently in Japan in most kinds of publications, such as books and magazines, but also in China, especially in schoolbooks. Figure 1.1.1 shows an example.

Example showing ruby above the base in horizontal Japanese text

Figure 1.1.1: Ruby giving the pronunciation of the base characters.

East Asian typography has developed various elements that do not appear in western typography. Most of these can be addressed appropriately with style sheet languages such as CSS or XSL. Ruby, however, require markup in order to define the association between the base text and the ruby text.

This specification defines such markup, designed to be usable with XHTML, in order to make ruby available on the Web without using special workarounds or graphics. This section gives some background on ruby. Section 1.2 gives an overview of the markup for ruby. Section 2 contains the formal definition of ruby markup in the context of the XHTML Modularization framework [XHTMLMOD].

The remainder of this section gives some background on the structure and use of ruby. Because presentation is part of this background, it is discussed here. However, it should be noted that this document does not specify any mechanisms for presentation/styling of ruby; this is part of the respective stylesheet languages.

The font size of ruby text is normally about half the font size of the base text (see Figure 1.1.1). The name "ruby" in fact originated from the name of the 5.5pt font size in British printing, which is about half the 10pt font size commonly used for normal text.

There are several positions where the ruby text can appear relative to its base. For horizontal layout, where text appears along horizontal lines, ruby are most frequently placed above the base text (see Figure 1.1.1), i.e. before the line containing the base text. Sometimes, especially in educational texts, ruby may appear below, i.e. after, the base text. In Chinese, it is rather common that Pinyin ruby appear after the base text.

Example of ruby below the base in horizontal mode

Figure 1.1.2: Ruby (in Latin letters) below the base text (in Japanese)

In typical vertical layout, where text appears along vertical lines starting on the right, ruby appear on the right side of (i.e. again before) the vertical line if they appear above in horizontal layout. The writing direction of the ruby text is the same as that of its base, that is vertical if the base is vertical, and horizontal if the base is horizontal.

Example showing ruby on the right side of base in vertical Japanese text

Figure 1.1.3: Ruby in vertical text (before/to the right)

Ruby text appears on the left side of the base in vertical layout if it appears below it in horizontal layout.

Example showing ruby on the left side of base in vertical Japanese text

Figure 1.1.4: Ruby in vertical text (after/to the left).

Because East Asian text may be rendered vertically as well as horizontally, the terms "before" and "after" are used in this document rather than "above" and "below" or "right side" and "left side". In this specification, the term "before" means "above" in horizontal layout / "right side" in vertical (in this context, top-to-bottom, right-to-left) layout, and the term "after" means "below" in horizontal layout / "left side" in vertical layout.

Ruby before the base text are often used to indicate pronunciation; ruby after the base text are often used to indicate meaning. In this and other cases, it can happen that ruby appear on both sides of the base text.

Example showing ruby text applied before and after the base in horizontal text

Figure 1.1.5: Ruby applied before and after a line of horizontal Japanese text

In some cases, it is desirable to give more details about which parts of the ruby base and which parts of the ruby text are associated together. Such a structure is called group ruby. This can be used for finetuning of the display or for other operations. Using fine-grained associations, and in particular showing the association with each single character of the base text, is mainly used in educational texts and other cases where the exact association is important or potentially unknown.

More coarse-grained association is used when the actual details of the association on a lower level are assumed to be known to the reader anyway, or unknown because the pronunciation or annotation only applies to the whole unit and cannot be split into pieces. Because in such cases longer spans of ruby text are set with the same spacing, better readability and more even layout may be achieved. For example, a person name can be decomposed into family name and given name. Or a kanji compound or phrase can be decomposed to show semantic subparts, as in the following example:

Example showing group ruby, with the Japanese sequences before and the English sequence after

Figure 1.1.6: Group ruby with text after spanning the group

In the above example, the ruby text before the base text is made of two sequences: the hiragana sequence p"でんわ" (denwa) for "phone", and the hiragana sequence "ばんごう" (bango) for "number"; the ruby text after the base text is a single English sequence: "Phone number". Note that the space in the base text in Figure 1.1.6 and similar figures was added to make the structure of the examples clearer; in general, no space is used between ideographs in the base text.

In the following example, the ruby text after, "University", relates to the second base sequence while the ruby texts before, "けいおうぎじゅく" and "だいがく" (keiou gijyuku daigaku; Keio University in hiragana) refer to the two base sequences.

Example showing group ruby, with the Japanese sequences before and the English sequence after only spanning the second part

Figure 1.1.7: Group ruby with text after only spanning the second part

Details of ruby formating in a Japanese print context can be found in JIS-X-4051 [JIS].

In traditional Chinese, "Bopomofo" ruby can appear along the right side of the ruby base, even in horizontal layout.

Example of Bopomofo ruby, with Bopomofo on the right side of the base texts in horizontal layout

Figure 1.1.8: "Bopomofo" ruby in traditional Chinese (ruby text shown in blue for clarity) in horizontal layout

Note that Bopomofo tone marks (in the above example shown in red for clarity) appear in a separate column (along the right side of the Bopomofo ruby) and therefore might be seen as "ruby on ruby". However, they are encoded as combining characters that are simply part of the ruby text.

Introducing ruby to the Web leads to some phenomena and problems that are not present in traditional typography where the term "ruby" is taken from. The term "ruby" in Japanese is only used for text alongside the base text, for example as shown in the various figures above. However, once structural markup for ruby is defined as done in this specification, there is no guarantee that the associations defined by this markup will always be rendered alongside the base text. There is and will be a very wide variety of current and future output devices for documents marked up with XHTML. The following are possible scenarios and reasons for different rendering:

Example showing fallback where ruby text is enclosed within parentheses after the base text in horizontal Japanese

Figure 1.1.9: Fallback for the example of Figure 1.1.1 using parentheses

Using parentheses for the fallback may lead to confusion between runs of text intended to be the ruby text and others that happen to be enclosed within parentheses. The document or style sheet author should be aware of the potential for that confusion and is advised to choose an unambiguous delimiter for the fallback, if this is a concern.

1.2  Ruby markup

This section gives an overview of the markup for ruby defined in this specification. A formal definition can be found in Section 2. The markup is written in XML [XML].

The core of the markup is the ruby element. The ruby element encloses all the text and markup necessary for defining the association between the base text and the ruby texts.

Note. The name of this enclosing element, "ruby", should be interpreted to mean that what follows is associating ruby with base text. It must not be misunderstood to mean that everything inside, including the base text, is ruby. The name of the enclosing element was choosen to compactly and clearly identify the function of the markup construct; the names for the other elements were choosen to keep the overall length short.

The ruby element serves as a container for one of the following:

In the following, these two cases are discussed in more detail.

1.2.1  Simple Ruby markup

For the simple case, the rb element contains the base text, the rt element contains the ruby text, and the optional rp elements contain the parenthesis characters used in the fallback case. rb stands for "ruby base", rt for "ruby text", and rp for "ruby parenthesis". This allows a simple association between one base text and one ruby text, and is sufficient for most cases.

For example, the following simple ruby:

Example showing ruby before the base in horizontal English text

Figure 1.2.1.1: Ruby applied to English

can be represented as follows:

<ruby>
  <rb>WWW</rb>
  <rp>(</rp><rt>World Wide Web</rt><rp>)</rp>
</ruby>

Figure 1.2.1.2: Example of simple ruby markup including rp elements for fallbacks

The rp elements and the parentheses inside them are provided for fallback only. Some user agents, which ignore unknown elements but render their contents, will render the above markup as "WWW (World Wide Web)". The rp element identifies the parentheses (or whatever else that may be used in their place) to user agents that know about the markup defined in this specification so that the parentheses can be removed. If the author is not concerned about fallbacks for user agents that neither know about ruby markup nor support CSS2 [CSS2] or XSL [XSL] style sheets, then the rp elements are not needed:

<ruby>
  <rb>WWW</rb>
  <rt>World Wide Web</rt>
</ruby>

Figure 1.2.1.3: Example of simple ruby markup without rp elements for fallbacks

In [CSS2], if necessary, the parentheses can be generated using the 'content' property ([CSS2], section 12.2) with the :before and :after pseudo-elements ([CSS2], section 12.1), as for example in the following style declaration:

rt:before { content: "(" }
rt:after { content: ")" }

Figure 1.2.1.4: CSS2 style sheets to generate parentheses around rt element

In the above example, parentheses will be automatically generated around the rt element. It is assumed that the above style rules are used together with style rules that position the ruby text inline. Generation of parentheses is straightforward with XSLT [XSLT].

1.2.2  Group Ruby markup

For more complicated cases of associations between a base text and some ruby texts, a combination of rbc and rtc elements is used. This includes associating more than one ruby texts with the same base text (typically rendered on both sides of the base text) and fine-grained associations of the base text and the ruby text (group ruby). The ruby element contains one rbc element followed by one or two rtc elements. The rbc element contains rb elements, the rtc element contains rt elements. Several rb elements inside an rbc element, combined with several rt elements inside an rtc element, are used for group ruby. The rt element may use the rbspan attribute to indicate that a single rt element spans (is associated with) multiple rb elements. This is similar to the colspan attribute of the th/td elements in tables. The rbc stands for "ruby base component", and the rtc for "ruby text component".

An example of group ruby is shown in the following figure:

Example showing a group ruby in horizontal Japanese text

Figure 1.2.2.1: Group ruby with mixed before and after ruby text

can be represented as follows:

<ruby xml:lang="ja" class="pronunciation annotation">
  <rbc>
    <rb>斎</rb>
    <rb>藤</rb>
    <rb>信</rb>
    <rb>男</rb>
  </rbc>
  <rtc class="pronunciation">
    <rt>さい</rt>
    <rt>とう</rt>
    <rt>のぶ</rt>
    <rt>お</rt>
  </rtc>
  <rtc class="annotation">
    <rt rbspan="4" xml:lang="en">W3C Associate Chairman</rt>
  </rtc>
</ruby>

Figure 1.2.2.2: Ruby markup to achieve both before and after ruby texts on the same base.

In this case, the rtc element with the class "pronunciation" should be associated with the style information that places the ruby texts before the ruby bases, and the rtc element with the class "annotation" should be associated with the style information that places the ruby texts after the ruby bases.

The rp element is not available in this representation. This has two reasons. First, the rp element is for fallback only, and it was considered that this is much more important for the more frequent simple case. Second, for the more complex cases, it is in many cases very difficult to come up with a reasonable fallback display, and constructing markup for such cases can be even more difficult if not impossible.

1.2.3  Notes on styling ruby

This specification only defines ruby markup. Formatting properties for styling ruby are under development for CSS and XSL. See "International Layout" [I18N-FORMAT] (work in progress) for more details.

Note that for non-visual rendering such as speech synthesis, rendering both the base text and the ruby text can be annoying. This is in particular the case if the ruby represent a pronunciation. In this case, a speech synthesizer may either be able to correctly pronounce the base text, in which case the same text is spoken twice, or it may not know the correct pronounciation of the text and make up a pronounciation, in which case the result may be quite confusing.

As an example, in the case of Figure 1.2.2.2, the ruby bases "", "", "", "" are less useful than the ruby texts "さい" (sai), "とう" (tou), "のぶ" (nobu), "" (o) for non-visual rendering, and it does not make sense to render both the ruby bases and the ruby texts. Because in this case, the ruby texts are used to represent pronunciation, so it is straightforward to use them for non-visual rendering. In such cases, something like the following style information may help.

@media aural {
  ruby[class~="pronunciation"] rb { speak: none }
}

Figure 1.2.3.1: CSS2 style sheet to suppress aural rendering of the ruby base

The above style sheet will suppress aural rendering of the ruby base when the rb element is a descendant element of the ruby element with the class "pronunciation". See [CSS2] for more details.

Note that ruby used as a pronunciation guide may be different from the actual pronunciation even in cases where the script used for indicating the pronunciation at first glance seems perfectly phonetic. For example, Bopomofo is associated independently for each base character; context-dependent sound or tone changes are not reflected in ruby. Similarly, in Japanese, spelling irregularities can occur, such as using "は" (ha) for the topic suffix pronounced "わ" (wa). For such cases, authors may want to supply two variants, distinguished by the value of the class attribute, or may rely on the aural rendering system being able to handle such cases correctly.

It is also important to note that not all ruby are pronunciations. Authors should distinguish ruby used for different purposes by using the class attribute, as done above by assuming class="pronunciation" for ruby used to indicate pronunciation. Also, it should be noted that somebody listening to aural rendering may be interested in accessing the skipped base text to check the characters used.


2.  Formal definition of ruby elements

This section is normative.

This section contains the formal syntax definition and the specification of the functionality of the ruby elements. Some familiarity with the XHTML Modularization framework, in particular, the "Modularization of XHTML" [XHTMLMOD] and the "Building XHTML Modules" [BUIDLING] specifications is assumed.

2.1  Abstract definition of ruby elements

The following is the abstract definition of ruby elements, which is consistent with the XHTML Modularization framework [XHTMLMOD]. Further definitions of XHTML abstract modules can be found in [XHTMLMOD].

Elements Attributes Minimal Content Model
ruby Common (rb, rp?, rt, rp?)
rbc Common rb+
rtc Common rt+
rb Common (PCDATA | Inline - ruby)*
rt Common, rbspan (CDATA) (PCDATA | Inline - ruby)*
rp Common PCDATA*

The ruby content model for XHTML 1.1 [XHTML11] is as follows:

((rb, rp?, rt, rp?) | (rbc, rtc, rtc?))

This is the maximal content model for the ruby element.

An implementation of this abstract definition as an XHTML DTD module can be found in Appendix A. An XML Schema [XMLSchema] implementation will be provided when feasible.

2.2  The ruby element

The ruby element is an inline (or text-level) element that serves as the container for either the rb, rt and optional rp elements or the rbc and rtc elements. It provides the structural association between the ruby base elements and their ruby text elements.

The ruby element has common attributes only, such as id, class or xml:lang.

In this simplest example, the ruby text "aaa" is associated with the base "AA":

<ruby><rb>AA</rb><rt>aaa</rt></ruby>

Figure 2.2.1: Simple usage of the ruby element

2.3  The rbc element

The rbc (ruby base component) element is the container for rb elements. This element is only used for group ruby. Only one rbc element may appear inside a ruby element. Examples of using the rbc element are shown in Figure 1.2.2.2 and Figure 2.4.1.

The rbc element has common attributes only.

2.4  The rtc element

The rtc (ruby text component) element is the container for rt elements. This element is only used for group ruby. One or two rtc elements may appear inside a ruby element to associate ruby texts with a single ruby base, represented by an rbc element. More than two rtc elements MUST not appear inside a ruby element.

The rtc element has common attributes only.

For example, the following markup associates two ruby texts with the same ruby base:

<ruby>
  <rbc>
    <rb>KANJI</rb>
  </rbc>
  <rtc class="before">
    <rt>kana-before</rt>
  </rtc>
  <rtc class="after">
    <rt>kana-after</rt>
  </rtc>
</ruby>

Figure 2.4.1: Ruby markup to associate two ruby texts with the same base.

Supposing that the class "before" is used to apply style information to place the ruby text before the ruby base and the class "after" is used to apply style information to place the ruby text after the ruby base, in horizontal text the markup above would be rendered like this:

kana-before
   KANJI
kana-after

Figure 2.4.2: Horizontal rendering of two ruby texts associated with a single ruby base.

Markup for a more complex example of using two ruby texts with the same ruby base is shown in Figure 1.2.2.2; the rendering of this markup is shown in Figure 1.2.2.1.

Note. Although the rendering of the ruby texts should be controlled by style sheets, in case no style information is provided by the author or the user, it is recommended that visual user agents should place the ruby text before the ruby base when only one ruby text is used. This is also the case for simple ruby. When there are two ruby texts, the first ruby text should be placed before the ruby base, and the second ruby text should be placed after the ruby base. A sample user agent default style sheet which describes this formatting will be provided by [I18N-FORMAT] or its successor document.

For non-visual rendering, in the absence of style sheet information, it is recommended that both the ruby base and the ruby text(s) should be rendered, with an indication (e.g. different voice, different pitch, ...) of the status of each.

2.5  The rb element

The rb element is the container for the text of the ruby base. For simple ruby, only one rb element may appear. An example of such simple ruby is shown in Figure 2.2.1. For group ruby, multiple rb elements may appear inside an rbc element, and each rb element may be associated with the relevant rt element, for fine-grained association. An example of such group ruby is shown in Figure 1.2.2.2.

The rb element may contain inline elements or character data as its content, but the ruby element shall not appear as its descendant element.

The rb element has common attributes only.

2.6  The rt element

The rt element is the container for the ruby text. For simple ruby, only one rt element may appear. An example of such simple ruby is shown in Figure 2.2.1. For group ruby, multiple rt elements may appear inside an rtc element, and each rt element contains the ruby text for the relevant ruby base, represented by the rb element. An example of such fine-grained association between the ruby bases and the ruby texts is shown in Figure 1.2.2.2, and that would be rendered like Figure 1.2.2.1.

The rt element may contain inline elements or character data as its content, but the ruby element shall not appear as its descendant element.

The rt element has common attributes and the rbspan attribute. In group ruby, the rbspan attribute allows an rt element to span multiple rb elements. The value shall be an integer value greater than zero ("0"). The default value of this attribute is one ("1").

In an example shown in Figure 1.2.2.2, the secondary ruby text spans four rb elements, and it will be rendered as in Figures 1.2.2.1. The rbspan attribute should not be used in simple ruby, and user agents should ignore the rbspan attribute when it appears in simple ruby.

2.7  The rp element

The rp element is intended to contain parenthesis characters in simple ruby. Parentheses are necessary to provide an acceptable fallback. The rp element is necessary especially for user agents that are unable to render ruby text alongside the ruby base. In that way, ruby will only degrade to be rendered inline and enclosed in parentheses. This is the least inappropriate rendering under the condition that only inline rendering is available. The rp element cannot be used in group ruby.

The rp element has common attributes only.

Consider the following markup:

<ruby>
  <rb>A</rb>
  <rp>(</rp><rt>aaa</rt><rp>)</rp>
</ruby>

Figure 2.7.1: Ruby markup using rp elements

A user agent that supports ruby will render it as:

aaa
 A

Figure 2.7.2: Ruby rendered by a supporting user agent (the parentheses have been removed)

A user agent that is unable to render ruby alongside the ruby base, or does not support ruby markup, will render it as:

A (aaa)

Figure 2.7.3: Ruby rendered by a non-supporting user agent (the parentheses are visible)


Appendices

A.  Ruby module for XHTML

This appendix is informative.

The following is a link to the Ruby DTD module that will be part of the XHTML 1.1 DTD modules [XHTML11].

B.  Notes on backwards compatibility

This appendix is informative.

For historical reason, some authoring tools might generate ruby markup without the start and end tags of the rb element, like:

<ruby>
  A
  <rp>(</rp><rt>aaa</rt><rp>)</rp>
</ruby>

rather than the following:

<ruby>
  <rb>A</rb>
  <rp>(</rp><rt>aaa</rt><rp>)</rp>
</ruby>

The former markup is not conforming to this specification, but user agents that care about compatibility with documents generated by such authoring tools may treat the former markup as if it were written like the latter.

C.  Glossary

This appendix is informative.

Bopomofo
37 characters and 4 tone marks used as phonetics in Chinese, especially standard Mandarin.
Group ruby
A set of ruby that uses fine-grained associations between the ruby bases and the ruby texts.
Hiragana
Subset of the Japanese writing system consisting of phonetic characters to represent Japanese words.
Kana
Syllabic subset of the Japanese system of writing that can be used exclusively for writing foreign words or in combination with kanji.
Kanji
Subset of the Japanese writing system that utilizes ideographic characters borrowed or adapted from Chinese writing.
Ruby base
Run of text that has a ruby text associated with it.
Ruby text
Run of text that appears in the immediate vicinity of another run of text (called "ruby base") and serves as an annotation or a pronunciation guide associated with the base.

D.  Changes from previous public Working Draft

This appendix is informative.

Section Change
Abstract
  • Rewritten substantially; made clear that this specification is defining a ruby module for XHTML 1.1.
Status of This Document
  • Rewritten substantially; made clear that this document is a Last Call draft.
  • Added a note on the use of wide range of characters and character encodings, and provided a link to a list of available character encodings.
1. Introduction
  • Changed above/below to before/after so that it makes sense regardless of layout flow.
  • Splitted section 1.2 into three subsections.
  • Added a note that in Chinese, Pinyin ruby commonly appears "after" the ruby base rather than "before".
  • Added an example of Bopomofo ruby, and added a note about tone marks in Bopomofo ruby.
  • Added a note on possible difference between ruby and the actual pronunciation.
  • Refined some wording.
2. Formal definition of ruby elements
  • Changed the "minimal" content model of the ruby element to (rb, rp?, rt, rp?)
  • Changed the content model of the ruby element of XHTML 1.1 to limit the number of rtc elements to no more than two in group ruby.
  • Added note on visual/non-visual rendering of ruby text.
  • Refined each definition.
Appendix A. Ruby module for XHTML
  • Rewritten Ruby module substantially for better modularity
  • Removed accompanying DTD modules, as those will be incorporated into XHTML 1.1.
Appendix B. Notes on backwards compatibility
  • Removed an appendix on ruby usage in SGML, and added notes on backwards compatibility instead.
Acknowledgements
  • Added additional contributors, and used kanji characters as well for their names when appropriate.
References
  • Removed references to HTML 4.0 and XHTML 1.0.
  • Added references to XML Schema and XSLT specifications.
  • Added references to "this version" URIs in addition to "latest version" URIs.

Acknowledgements

This section is informative.

The model presented in this specification was originally inspired by the work done by Martin Dürst [DUR97].

This specification would also not have been possible without the help from:

Murray Altheim, Mark Davis, Laurie Anna Edlund, Arye Gittelma, Hideki Hiura (樋浦 秀邪), Koji Ishii, Rick Jelliffe, Eric LeVine, Chris Lilley, Charles McCathieNevile, Shigeki Moro (師 茂邪), Chris Pratley, Nobuo Saito (斎藤 信男), Rahul Sonnad, Takao Suzuki (鈴木 孝雄), Chris Thrasher, Chris Wilson, Masafumi Yabe (家辺 勝文).

References

This section is informative.

[BUILDING]
"Building XHTML Modules", W3C Working Draft
M. Altheim, S. P. McCarron, eds., 10 September 1999
Available at: http://www.w3.org/TR/1999/WD-xhtml-building-19990910
The latest version is available at: http://www.w3.org/TR/xhtml-building
[CSS2]
"Cascading Style Sheets, level 2 (CSS2) Specification", W3C Recommendation
B. Bos, H. W. Lie, C. Lilley and I. Jacobs, eds., 12 May 1998
Available at: http://www.w3.org/TR/1998/REC-CSS2-19980512
The latest version is available at: http://www.w3.org/TR/REC-CSS2
[DUR97]
"Ruby in the Hypertext Markup Language", Internet Draft
Martin Dürst, 28 February 1997, expired
Available at: http://www.w3.org/International/draft-duerst-ruby-01
[I18N-FORMAT]
"International Layout", W3C Working Draft
M. Sawicki, ed., 10 September 1999
Available at: http://www.w3.org/TR/1999/WD-i18n-format-19990910
The latest version is available at: http://www.w3.org/TR/i18n-format
[JIS]
"Line composition rules for Japanese documents"
JIS X 4051-1995, Japanese Standards Association, 1995 (in Japanese)
[XHTML11]
"XHTML 1.1 - Module-based XHTML", W3C Working Draft
M. Altheim, S. McCarron, Eds., 10 September 1999
Available at: http://www.w3.org/TR/199/WD-xhtml11-19990910
The latest version is available at: http://www.w3.org/TR/xhtml11
[XHTMLMOD]
"Modularization of XHTML", W3C Working Draft
M. Altheim et. al., eds., 10 September 1999
Available at: http://www.w3.org/TR/1999/WD-xhtml-modularization-19990910
The latest version is available at: http://www.w3.org/TR/xhtml-modularization
[XML]
"Extensible Markup Language (XML) 1.0 Specification", W3C Recommendation
T. Bray, J. Paoli, C. M. Sperberg-McQueen, eds., 10 February 1998
Available at: http://www.w3.org/TR/1998/REC-xml-19980210
The latest version is available at: http://www.w3.org/TR/REC-xml
[XMLSchema]
"XML Schema Part 1: Structures", W3C Working Draft
H. S. Thompson, D. Beech, M. Maloney, N. Mendelsohn, eds., 5 November 1999
Available at: http://www.w3.org/TR/1999/WD-xmlschema-1-19991105
The latest version is available at: http://www.w3.org/TR/xmlschema-1
See also "XML Schema Part 2: Datatypes", available at: http://www.w3.org/TR/xmlschema-2
[XSL]
"Extensible Style Language (XSL)", W3C Working Draft
S. Deach, ed., 21 April 1999
Available at: http://www.w3.org/TR/1999/WD-xsl-19990421
The latest version is available at: http://www.w3.org/TR/WD-xsl
[XSLT]
"XSL Transformations (XSLT) Version 1.0", W3C Recommenation
J. Clark, ed., 16 November 1999
Available at: http://www.w3.org/TR/1999/REC-xslt-19991116
The latest version is available at: http://www.w3.org/TR/xslt