Movatterモバイル変換


[0]ホーム

URL:


Internet-Draftxml2rfc FAQFebruary 2019
RussoExpires 23 August 2019[Page]
Published:
Intended Status:
Informational
Expires:
Author:
A. Russo
RFC Production Center

xml2rfc Frequently Asked Questions

Abstract

This is a list of frequently asked questions regarding xml2rfc. Please send questions or corrections to thexml2rfc mailing list.

Note: this FAQ is for version 3 of xml2rfc; the vocabulary has been changed significantly from version 2. For guidance on version 2, please see theFAQ for xml2rfc v2.

Status of This Memo

This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.

Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is athttps://datatracker.ietf.org/drafts/current/.

Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."

This Internet-Draft will expire on 5 August 2019.

Copyright Notice

Copyright (c) 2019 IETF Trust and the persons identified as the document authors. All rights reserved.

This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Code Components extracted from this document must include Simplified BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Simplified BSD License.

Table of Contents

1. The Basics

1.1. What is xml2rfc?

xml2rfc is a tool that lets you convert an XML source file into a text, HTML,nroff, or expanded XML file. It is available fromxml2rfc.ietf.org [xml2rfc] asa web-based service or for download. Version 3 of the tool adds newfeatures and will be used by the RFC Editor to create RFCs. Thecurrent version is here:

1.2. Why should I use xml2rfc?

It's an easy way to create an Internet-Draft in the properformat. It handles boilerplate text and reference text. The HTMLand PDF output formats have new features (such as including SVG figures and non-ASCIIcharacters), and the source file can be used for metadataextraction. Also, the RFC Editor will make use of your source file.(For background, see theRFC Format FAQ.)

1.3. How much XML do I need to know?

You need the essentials. XML uses start and end tags, which are nested and matching, and they are case-sensitive. Seethe section "XML basics" of[Writing I-Ds and RFCs using XML (revised)] formore details.

1.4. Where can I get more information?

2. Creating a Draft

2.1. What's the recommended setup?

not yet updated--AR

You have several choices when getting started with xml2rfc, such as:

2.2. Where can I get a template?

not yet updated--AR

Several templates are availablefromhttp://tools.ietf.org/tools/templates [templates]. Theyinclude templates for a generic draft (e.g., draft-davies-template-bare.xml), as well as for a draftcontaining a MIB (e.g., mib-doc-template-xml.txt).

2.3. Can I do it without a template?

not yet updated--AR

Sure. We recommend copying the front matter from a template or the XML source of an existing document, thengoing from there. Put <t> tags around paragraphs, and<figure><artwork> tags around figures. Use <![CDATA[ ... ]]> for blocks ofcode or figures that contain <. (SeeWhat is CDATA for? for more information.)

For references, replace [RFC2119] with <xref/>.For cross-references to sections, replace Section 9 with<xref/> (if Section 9 has anchor="sec_cons"). SeeUsing References for more information.

2.4. How do I use therfc element to create an Internet-Draft?

Use thecategory attribute to indicate the intended category of your draft, wherestd is Standards Track,info is Informational,exp is Experimental,bcp is Best Current Practice, andhistoric is Historic.

Use thesubmissionType attribute to indicate the intendeddocument stream, where the value can beIETF,IAB,IRTF, orindependent.

SeeSection A.1 of [RFC7991]

Use the docName attribute to indicate the filename.

If the document potentially updates or obsoletes any RFCs, use theupdates and obsoletes attributes to indicate the relevant RFCnumbers. For Internet-Drafts, this information will be displayed inthe header, followed by "(if approved)".

For example, putting it together:

<rfc   category="info"   submissionType="IETF"   ipr="trust200902"   docName="draft-ietf-wgname-topic-00"    updates="1234, 1235"    obsoletes="1236"   sortRefs="true">

Note: The attributes number and seriesNo will be added by the RFC Editor if your draft is approved for publication as an RFC.

Note: Some features that used to be processing instructions (in v2) are now attributes of the rfc element (in v3) -- for example,sortRefs andsymRefs.

2.5. Why is xml2rfc giving me errors?

not yet updated--AR

At the top, if there is the PI <?rfc strict="yes"?>, then xml2rfc istrying to enforce I-D nits and DTD validity.

If you are getting "This file does not begin with an XML declaration",have you entered the filename correctly? It can indicate a problem withthe first line (<?xml version="1.0">) or it can mean "File notfound". Also, check the permissions on the file.

One common error is caused by mismatched tags. For example, whenthere is a missing </t>, the error might appear as follows:

end tag "section" does not match open element "t" around line 65

Using Bill's xml2rfc validator can provide more precise error messages.

3. Using References

3.1. How do I put in a reference?

not yet updated--AR

A set of online citation libraries are maintained onxml2rfc.ietf.org [xml2rfc].They include citations for RFCs, Internet-Drafts, and documentsproduced by the W3C and 3GPP, amongothers.

To make use of the citation libraries, there are 2 methods:

  1. define an ENTITY at the top:

    <!ENTITY RFC2119 SYSTEM "https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml">

    and use &RFC2119; in the references section

  2. Note: As long as they match, the name you use in the ENTITY definition and the &name; in the references section are your choice, and may be uppercase or lowercase (i.e., rfc2119 or RFC2119 or keywords). We suggest choosing uppercase (i.e., to match the anchor of the reference) in order to make it easier to be consistent.
  3. use an include in the references section

    <?rfc include="reference.RFC.2119.xml"?>

    For an Internet-Draft, the citation file uses the draft string. For example:

    <?rfc include="reference.I-D.ietf-wgname-topic.xml"?>

Preferably, use the citation libraries when possible. However,another option is to include the complete reference element (seeSection 3.2). Here's a template of areference element:

    <reference anchor="">        <front>            <title></title>            <author initials="" surname="" fullname="">                <organization />            </author>            <date month="" year="" />        </front>        <seriesInfo name="" value="" />    </reference>

All are cited textually in the same manner -- by using xref elementswhere the target corresponds to the anchor of the reference element,e.g., <xref />. The anchors for RFCs are "RFCNNNN" (4 digits, using leading zeros) and the anchors for Internet-Drafts are "I-D.<name without "draft-ietf-" or the version number>".

3.2. How do I insert the full reference?

There are several ways to insert the full reference element from thecitation library:

  1. Keep a local copy of the citation libraries. They are available fromhttps://xml2rfc.ietf.org [xml2rfc].
  2. Use a browser to look it up online, e.g.,https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml, andcopy the page source.
  3. Run xml2rfc with output mode set to XML. The output will include the complete reference elements for any entities and includes.

3.3. How do I make the reference tag [RFC2119] instead of [1]?

In therfc element, set the attributesymRefs="yes" forsymbolic references. This makes reference tags be the same as the anchor (e.g., [RFC2119]), instead of numerical (e.g., [1]).

symrefs="yes" is the default, starting with v1.33 of xml2rfc.

3.4. How do I make the reference tag [IKEv2] instead of [RFC4306]?

Use thedisplayreference element and set theto attribute tothe nickname. Tip: place it before thereferences element. For example:

<displayreference to="IKEv2"/><references>[...]<xi:include    href="https://xml2rfc.ietf.org/public/rfc/bibxml/reference.RFC.7296.xml"/>

yields:

[IKEv2]
Kaufman, C., Hoffman, P., Nir, Y., Eronen, P., and T. Kivinen, "Internet Key Exchange Protocol Version 2 (IKEv2)", STD 79, RFC 7296, DOI 10.17487/RFC7296, October 2014, <https://www.rfc-editor.org/info/rfc7296>.

3.5. How do I get the references listed in alphabetical order?

In the rfc element, set the attributesortRefs="yes". Note that sortRefs only has an effect ifsymRefs="yes".

3.6. How do I reference a URL?

The eref element for an external reference creates a link in the HTML output. For example:

<eref>

yieldshttps://www.w3.org.

<eref>W3C Home Page</eref>

yieldsW3C Home Page.

Another option is using xref and creating a reference that uses the target attribute for the URL. For example:

    <reference anchor="W3C">        <front>            <title>World Wide Web Consortium (W3C)</title>            <author/>        </front>    </reference>

yields

[W3C]     "World Wide Web Consortium (W3C)", <https://www.w3.org/>.

3.7. How do I get two sections of references: Normative and Informative References?

Use the name element (child of the references element) as follows:

    <back>      <references>        <name>Normative References</name>        ...      </references>      <references>        <name>Informative References</name>        ...      </references>    </back>

3.8. How do I make a cross-reference to another section?

not yet updated--AR

Make sure the section you want to reference has an anchor attribute.For example:

  <section title="Security Considerations" anchor="sec_cons">

Then, refer to it with an xref element:

  See <xref />.

which yields the text output:

See Section 9.

(where the number of that section is determined dynamically).

3.9. What about referring to a section in another document? or How do I link to a section in another RFC?

not fully updated--AR

Use relref. Examples below are from draft-v3-features. SetdisplayFormat to various options.

"of": SeeSection 1 of [RFC7991]

"comma": See[RFC7991],Section 2.2

"parens": See[RFC7991] (Section A)

"bare": SeeSection B

(default): SeeSection 1 of [RFC7991]

With text content: SeeSection 2 of [the wonderful Section 2 of RFC 7991]

3.10. How do I get 'See Sections 9 and 10' instead of 'See Section 9 and Section 10'?

Use the format attribute. For example, assuming the anchorattributes for the relevant sections have the values "sec_cons" and "IANA_cons":

See Sections <xref format="counter" /> and<xref format="counter" />.

yields the text output:

See Sections 9 and 10.

Note: The format attribute can have the value "title", which displays the title of thesection. For example,

See the <xref format="title" />.

yields the text output:

See the Security Considerations.

4. Using Lists

4.1. How do I get different kinds of lists?

For bulleted lists, use the <ul> element.

For an empty list (indentation only), use the <ul> element withempty="true".

For definition lists (a.k.a. hanging lists in xml2rfc v2), use the <dl> element. SeeSection 4.4.

For numbers or letters, use the type attribute of the <ol> element; examples below.

For full details, seeSection 2.34.5 of [RFC7991]

4.2. How do I get a list like (1), (2), (3) or (a), (b), (c)?

(1)(2)    is   <ol type="(%d)">(3)(a)(b)    is   <ol type="(%c)">(c)REQ1:REQ2:  is   <ol type="REQ%d:">REQ3:

4.3. How do I get continuous numbering in a list that is split bytext (or across sections)?

Set the group attribute of the <ol> element. For example:

  1. apples
  2. blueberries
  3. cherries

Here is some text in between.

  1. dragonfruit
  2. elderberry
  3. fig

4.4. How do I get indentation? or How do I use definition lists?

Use a <dl> element (definition list), where each <dt> (term) inhas a corresponding <dd> (description).

For example:

<dl>  <dt>Unassigned:</dt>  <dd>Unused and available for assignment via  documented procedures.</dd>    <dt>Reserved:</dt>  <dd>Not to be assigned.  Reserved values are  held for special uses, such as to extend the namespace  when it become exhausted.  Reserved values are not  available for general assignment.</dd></dl>

yields:

Unassigned:
Unused and available for assignment via documented procedures.
Reserved:
Not to be assigned. Reserved values are held for special uses, such as to extend the namespace when it become exhausted. Reserved values are not available for general assignment.

Note: The appearance is slightly different in the text output.

Usenewline="true" to get a linebreak after the term. For example:

<dl newline="true">  <dt>Unassigned:</dt>  <dd>Unused and available for assignment via  documented procedures.</dd>    <dt>Reserved:</dt>  <dd>Not to be assigned.  Reserved values are  held for special uses, such as to extend the namespace  when it become exhausted.  Reserved values are not  available for general assignment.</dd></dl>

yields:

Unassigned:
Unused and available for assignment via documented procedures.
Reserved:
Not to be assigned. Reserved values are held for special uses, such as to extend the namespace when it become exhausted. Reserved values are not available for general assignment.

5. The Finer Points

5.1. What is CDATA for?

A CDATA block is left alone by xml2rfc. It does not try to parse XMLinside of a CDATA block. (For example, if a figure contains "<", you don'thave to use &lt;) So it is especially good for when there are XMLexamples in the document.

5.2. How do I get an unnumbered figure?

not yet updated--AR

Remove the anchor attribute for that figure. Figure elements without anchor attributeswill not be automatically numbered (i.e., "Figure 1").

5.3. What are the entities used for special characters?

To prevent these characters from being parsed as XML, use

&amp; for &&lt; for <&gt; for >

In addition, the following entities are defined:

&apos; for '&quot; for "&nbsp; for non-breaking space&nbhy; for non-breaking hyphen

5.4. How do I put a line break into the title of the document?

Insert &nbsp; (non-breaking space) between words that you want to keeptogether on a line.

5.5. How do I indicate the editor of the document?

Use the role attribute of the author element. For example:

<author initials="J" surname="Doe" fullname="John Doe" role="editor">

5.6. How do I insert questions for my coauthors?

You can use comments <!-- --> or <cref> elements. Comments are only visible in the XML source file.

Example of using comments:

<!-- [JD] This point needs revision.-->

<cref> will show up in the output when the attribute display="true" (which is the default).

Example of using <cref>:

<cref anchor="Q1" source="JD">This point needs revision.</cref>

yields

            [[This point needs revision.--JD]]

6. Miscellaneous

6.1. How do I know if my XML is valid?

xml2rfc validates it.Also, you can run rfclint:https://pypi.org/project/rfclint/.

6.2. Can I get a different kind of HTML output?

not yet updated--AR

Yes, rfc2629.xslt by Julian Reschke provides a different kind ofHTML output than the HTML output mode ofxml2rfc. It is available for download fromhttp://greenbytes.de/tech/webdav/rfc2629xslt.zip. See"Transforming RFC2629-formatted XML through XSLT" for more information.

6.3. Is there a tool that will turn my text file into an XML file (i.e., id2xml)?

Yes, id2xml is available here:https://pypi.org/project/id2xml/. It is available as a webservice onhttps://xml2rfc.ietf.org/.

7. New with v3

7.1. How do I convert my XML file from v2 to v3 so I can make use of the new features?

On the command line:xml2rfc --v2v3 inputfile.xml

Using the web service (https://xml2rfc.tools.ietf.org/experimental.html), select "Output format: convert v2 to v3 XML".

7.2. What are the new features with v3?

Some highlights are including UTF-8 characters, text formatting, and SVG diagrams. For complete details, seeSection 1.3 of [RFC7991]

7.3. How do I insert non-ASCII characters?

Withencoding="utf-8" in your XML file, you can insert thecharacters directly into the file in the following locations:

  • body of the document
  • author name and organization (fullname, initials, and surname attributes;organization element)
  • author's postal address (street, city, region, code, and country elements)
  • author's email address

Each of these elements has anascii attribute to holdthe ASCII equivalent, which will also appear in the output format. Forthe author element, the attributes are named asciiFullname,asciiInitials, andasciiSurnames.

For background, see[RFC7997].

7.4. How do I insert a table?

For example:

<table anchor="table_ex">  <name>IETF Meetings in 2005</name>  <thead>    <tr>      <th align='center'>IETF #</th>      <th align='center'>City</th>      <th align='center'># of Attendees</th>    </tr>  </thead>  <tbody>    <tr>      <td align="center">62</td>      <td align="center">Minneapolis</td>      <td align="center">1133</td>    </tr>    <tr>       <td align="center">63</td>      <td align="center">Paris</td>      <td align="center">1450</td>    </tr>    <tr>      <td align="center">64</td>      <td align="center">Vancouver</td>      <td align="center">1240</td>    </tr>  </tbody></table>

yields:

Table 1:IETF Meetings in 2005
IETF #City# of Attendees
62Minneapolis1133
63Paris1450
64Vancouver1240

Data fromhttps://www.ietf.org/how/meetings/past/.

For full details, seeSection 2.54 of [RFC7991]

7.5. How do I generate SVG that will be accepted in an RFC?

You can check your SVG file against the SVG Tiny 1.2spec on the experimental page (https://xml2rfc.tools.ietf.org/experimental.html),and a script calledsvgcheck is available here:https://pypi.org/project/svgcheck/.

For more information, see[RFC7996] andTipson creating SVGfiles.

7.6. How do I include SVG in my document?

There are at least five ways to include SVG in artwork in Internet-Drafts:

  • Inline, by including all of the SVG in the content of the element, such as: <artwork type="svg"><svg xmlns="http://www.w3.org/2000/ svg...">
  • Inline, but using XInclude (see Appendix B.1), such as: <artwork type="svg"><xi:include href=...>
  • As a data: URI, such as: <artwork type="svg" src="data:image/ svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3...">
  • As a URI to an external entity, such as: <artwork type="svg" src="http://www.example.com/...">
  • As a local file, such as: <artwork type="svg" src="diagram12.svg">

7.7. How do I get bold, italics, or a fixed-width font?

Use

  • <em> foritalics,
  • <strong> forbold, and
  • <tt> forfixed-width font.

Note: in the text output, <em> yields underscores, <strong> yieldsasterisks around the text, and <tt> yields quotation marks.

7.8. How do I get subscript and superscript?

Use <sub> for subscript, and <sup> for superscript.

Example (from RFC 6330):

  • x0 = (y + i) mod 28
  • x1 = (floor(y / 28) + i) mod 28
  • x2 = (floor(y / 216) + i) mod 28
  • x3 = (floor(y / 224) + i) mod 28

7.9. What are the possible values for the type of the sourcecode element?

abnf, asn.1, bash, c++, c, cbor, dtd, java, javascript, json, mib,perl, pseudocode, python, rnc, xml, andyang.

Ths list is subject to change; for details, seeSection 2.48.4 of [RFC7991]

7.10. Do I have to use the bcp14 element each time a keyword (e.g., "MUST") appears in my document?

It is not aMUST, but it makes the usage moreclear.

SHOULD without the <bcp14> element,SHOULD with it.

7.11. What is the best way to print a hardcopy?

Print the PDF.

7.12. How do I download the XML source files for all RFCs?

The source files of RFCs have changed over time. Most RFCs haveNROFF source files; sometimes an XML filehas been archived. You can request an XML source filedirectly from rfc-editor@rfc-editor.org. After RFC TBD, the XML fileswill be available for downloadhttps://www.rfc-editor.org/retrieve/bulk.

7.13. What has been deprecated from xml2rfc v2?

SeeSection 1.3.3 of [RFC7991]

8. Acknowledgments

This FAQ was made possible by the tools, documentation, and test filescreated by Henrik Levkowetz, Julian Reschke, and Sandy Ginoza.

9. Informative References

[howto]
Rose, M.,"Writing I-Ds and RFCs using XML (revised)",, <https://xml2rfc.ietf.org/authoring/draft-mrose-writing-rfcs.html>.
[IKEv2]
Kaufman, C., Hoffman, P., Nir, Y., Eronen, P., and T. Kivinen,"Internet Key Exchange Protocol Version 2 (IKEv2)",STD 79,RFC 7296,DOI 10.17487/RFC7296,, <https://www.rfc-editor.org/info/rfc7296>.
[readme]
Rose, M., Fenner, B., and C. Levert,"xml2rfc v1.33",, <https://xml2rfc.ietf.org/authoring/README.html>.
[RFC7991]
Hoffman, P.,"The "xml2rfc" Version 3 Vocabulary",RFC 7991,DOI 10.17487/RFC7991,, <https://www.rfc-editor.org/info/rfc7991>.
[RFC7996]
Brownlee, N.,"SVG Drawings for RFCs: SVG 1.2 RFC",RFC 7996,DOI 10.17487/RFC7996,, <https://www.rfc-editor.org/info/rfc7996>.
[RFC7997]
Flanagan, H., Ed.,"The Use of Non-ASCII Characters in RFCs",RFC 7997,DOI 10.17487/RFC7997,, <https://www.rfc-editor.org/info/rfc7997>.
[templates]
"Templates directory",, <https://tools.ietf.org/tools/templates/>.
[W3C]
"World Wide Web Consortium (W3C)", <https://www.w3.org/>.
[xml2rfc]
"xml2rfc",, <https://xml2rfc.ietf.org/>.

Author's Address

Alice Russo
RFC Production Center
Email:arusso@amsl.com

[8]ページ先頭

©2009-2026 Movatter.jp