この文書はRFC4234の日本語訳(和訳)です。 この文書の翻訳内容の正確さは保障できないため、 正確な知識や情報を求める方は原文を参照してください。 翻訳者はこの文書によって読者が被り得る如何なる損害の責任をも負いません。 この翻訳内容に誤りがある場合、訂正版の公開や、誤りの指摘は適切です。 この文書の配布は元のRFC同様に無制限です。


Network Working Group                                    D. Crocker, Ed.
Request for Comments: 4234                   Brandenburg InternetWorking
Obsoletes: 2234                                               P. Overell
Category: Standards Track                                      THUS plc.
                                                            October 2005


             Augmented BNF for Syntax Specifications: ABNF
                構文のための拡張BNF仕様:ABNF

Status of This Memo
このメモの状況

   This document specifies an Internet standards track protocol for the
   Internet community, and requests discussion and suggestions for
   improvements.  Please refer to the current edition of the "Internet
   Official Protocol Standards" (STD 1) for the standardization state
   and status of this protocol.  Distribution of this memo is unlimited.
   この文書はインターネット共同体のためのインターネット標準化中プロトコ
   ルを指定し、改良のために議論と提案を求めます。標準化状態とこのプロト
   コルの状態については「インターネット公式プロトコル標準」(STD1)
   の最新版を参照してください。このメモの配布は無制限です。

Copyright Notice
著作権表示

   Copyright (C) The Internet Society (2005).

Abstract
要約

   Internet technical specifications often need to define a formal
   syntax.  Over the years, a modified version of Backus-Naur Form
   (BNF), called Augmented BNF (ABNF), has been popular among many
   Internet specifications.  The current specification documents ABNF.
   It balances compactness and simplicity, with reasonable
   representational power.  The differences between standard BNF and
   ABNF involve naming rules, repetition, alternatives, order-
   independence, and value ranges.  This specification also supplies
   additional rule definitions and encoding for a core lexical analyzer
   of the type common to several Internet specifications.
   インターネット技術仕様書がしばしば正式の構文を定義する必要があります。
   これまで、拡張BNF(ABNF)と呼ばれる、バッカス・ナウア記法(BN
   F)の修正版、多くのインターネット仕様書の間で人気でした。この仕様書は
   ABNFを文書化します。これは、妥当な具象力で、小ささと単純さのバラン
   スをとります。標準BNFとABNFの相違は命名規則、反復、選択肢、順序
   独立と値範囲を含みます。この仕様書はいくつかのインターネット仕様書に共
   通の種類の核心となる語彙分析のための追加の規則定義とコーディングを供給
   します。


Table of Contents
目次

   1.  INTRODUCTION
   1.  はじめに
   2.  RULE DEFINITION
   2.  規則定義
      2.1.  Rule Naming
      2.1.  命名規則
      2.2.  Rule Form
      2.2.  規則形式
      2.3.  Terminal Values
      2.3.  終端値
      2.4.  External Encodings
      2.4.  外部コーディング
   3.  OPERATORS
   3.  演算子
      3.1.  Concatenation:  Rule1 Rule2
      3.1.  結合:規則1 規則2
      3.2.  Alternatives:  Rule1 / Rule2
      3.2.  選択:規則1/規則2
      3.3.  Incremental Alternatives: Rule1 =/ Rule2
      3.3.  逐次選択:規則1=/規則2
      3.4.  Value Range Alternatives:  %c##-##
      3.4.  価範囲選択:%c##-##
      3.5.  Sequence Group:  (Rule1 Rule2)
      3.5.  順序グループ:(規則1 規則2)
      3.6.  Variable Repetition:  *Rule
      3.6.  可変繰返:*規則
      3.7.  Specific Repetition:  nRule
      3.7.  特定繰返し:n規則
      3.8.  Optional Sequence:  [RULE]
      3.8.  任意順序:[規則]
      3.9.  Comment:  ; Comment
      3.9.  コメント:;コメント
      3.10.  Operator Precedence
      3.10.  演算子優先度
   4.  ABNF DEFINITION OF ABNF
   4.  ABNFのABNFでの定義
   5.  SECURITY CONSIDERATIONS
   5.  セキュリティの考慮
   6.  References
   6.  参考文献
      6.1.  Normative References
      6.1.  参照する参考文献

      6.2.  Informative References
      6.2.  有益な参考文献
   Appendix A.  ACKNOWLEDGEMENTS
   付録A.謝辞
   Appendix B.  APPENDIX - CORE ABNF OF ABNF
   付録B.付録-ABNFの核ABNF
      B.1.  Core Rules
      B.1.  核規則
      B.2.  Common Encoding
      B.2.  共通コーディング


1.  INTRODUCTION
1.  はじめに

   Internet technical specifications often need to define a formal
   syntax and are free to employ whatever notation their authors deem
   useful.  Over the years, a modified version of Backus-Naur Form
   (BNF), called Augmented BNF (ABNF), has been popular among many
   Internet specifications.  It balances compactness and simplicity,
   with reasonable representational power.  In the early days of the
   Arpanet, each specification contained its own definition of ABNF.
   This included the email specifications, [RFC733] and then [RFC822],
   which came to be the common citations for defining ABNF.  The current
   document separates those definitions to permit selective reference.
   Predictably, it also provides some modifications and enhancements.
   技術的なインターネット仕様書がしばしば正式の構文を定義する必要があり、
   それらの著者が有用であるとみなす任意の表記法を使用できます。何年もの
   間、拡張BNF(ABNF)と呼ばれる、バッカス・ナウア記法(BNF)
   の修正版が、多くのインターネット仕様書の間で人気でした。これは、妥当
   な具象力で、小ささと単純さのバランスをとります。アーパーネットの初期
   には、それぞれの仕様書がそれ自身のABNFの定義を含んでいました。こ
   れは電子メール仕様書、[RFC733]とその後の[RFC822]を含み、そしてこれは
   ABNFを定義する際の共通の引用になりました。現在の文書は選択的な参
   照を認めるためにそれらの定義を切り離します。予想どおり、これはある修
   正と拡張を供給します。

   The differences between standard BNF and ABNF involve naming rules,
   repetition, alternatives, order-independence, and value ranges.
   Appendix B supplies rule definitions and encoding for a core lexical
   analyzer of the type common to several Internet specifications.  It
   is provided as a convenience and is otherwise separate from the meta
   language defined in the body of this document, and separate from its
   formal status.
   標準BNFとABNFの相違は命名規則、反復、選択肢、順序独立と値範囲
   を含みます。この仕様書はいくつかのインターネット仕様書に共通の種類の
   核心となる語彙分析のための追加の規則定義とコーディングを供給します。
   付録Bがいくつかのインターネット仕様書に共通の種類の核心の語彙分析の
   ために規則定義とコーディングを供給します。これは便利な道具として供給
   され、そしてこの文書の本体で定義されたメタ言語とは独立で、正式の状態
   とは独立です。

   Changes since [RFC2234]:
   [RFC2234]からの変更:

      In Section 3.7, the phrase: "That is, exactly <N> occurrences of
      <element>." was corrected to: "That is, exactly <n> occurrences of
      <element>."
      セクション3.7で、句「それは、<element>の正確に<N>の事象です。」
      は「それは、<element>の正確に<n>の事象です。」に修正されます。

      Some continuation comment lines needed to be corrected to begin
      with comment character (";").
      ある継続コメント行がコメント文字(";")で始まるように修正されました。

2.  RULE DEFINITION
2.  規則定義

2.1.  Rule Naming
2.1.  命名規則

   The name of a rule is simply the name itself; that is, a sequence of
   characters, beginning with an alphabetic character, and followed by a
   combination of alphabetics, digits, and hyphens (dashes).
   規則の名前はただ名前自身であす;すなわち、アルファベット文字から始ま
   り、アルファベット文字と数字文字とハイフン(ダッシュ)が続く列です。

   NOTE:
   重要性:

      Rule names are case-insensitive
      規則名は大文字小文字の違いを無視します。

   The names <rulename>, <Rulename>, <RULENAME>, and <rUlENamE> all
   refer to the same rule.
   名前<rulename>と<Rulename>と<RULENAME>と<rUlENamE>はすべては同じ規則
   を示します。

   Unlike original BNF, angle brackets ("<", ">") are not required.
   However, angle brackets may be used around a rule name whenever their
   presence facilitates in discerning the use of a rule name.  This is
   typically restricted to rule name references in free-form prose, or
   to distinguish partial rules that combine into a string not separated
   by white space, such as shown in the discussion about repetition,
   below.
   オリジナルのBNFと違い、山括弧("<", ">")は必要ありません。しかし
   ながら、山括弧があることで規則名の使用の認識を容易にする時はいつでも、
   規則名の周囲で使われるかもしれません。これは一般に、下記の反復の議論
   で示されるように、自由形式や空白スペースで分割されていない文字列に結
   合された部分規則の区別での引用での規則名の参照を制限します。

2.2.  Rule Form
2.2.  規則形式

   A rule is defined by the following sequence:
   規則が次の列で定義されます:

         name =  elements crlf

   where <name> is the name of the rule, <elements> is one or more rule
   names or terminal specifications, and <crlf> is the end-of-line
   indicator (carriage return followed by line feed).  The equal sign
   separates the name from the definition of the rule.  The elements
   form a sequence of one or more rule names and/or value definitions,
   combined according to the various operators defined in this document,
   such as alternative and repetition.
   <name>が規則の名前で、<elements>は1つ以上の規則名か終端で、<crlf>は
   「行末」表示(キャリッジリターンに続くラインフィード)です。等号は名
   前を規則の定義から分離します。要素は、この文書で定義された選択や繰返
   しの様な種々な演算子で結合された、1つ以上の規則名や値定義の列です。

   For visual ease, rule definitions are left aligned.  When a rule
   requires multiple lines, the continuation lines are indented.  The
   left alignment and indentation are relative to the first lines of the
   ABNF rules and need not match the left margin of the document.
   見易さのため、規則定義は左詰めされています。規則が多数の行を必要とす
   る時、継続行は字下げして書かれます。左積めと字下げは、ABNF規則の最
   初の行と関係があり、文書の左端に合う必要がありません。

2.3.  Terminal Values
2.3.  終端値

   Rules resolve into a string of terminal values, sometimes called
   characters.  In ABNF, a character is merely a non-negative integer.
   In certain contexts, a specific mapping (encoding) of values into a
   character set (such as ASCII) will be specified.
   規則は、文字と呼ばれる、最終値の列に変換されます。ABNFで文字は単純に
   非負整数です。ある特定の状況で、値から(ASCIIのような)文字集合
   への特定の対応付け(コーディング)が指定されるでしょう。

   Terminals are specified by one or more numeric characters, with the
   base interpretation of those characters indicated explicitly.  The
   following bases are currently defined:
   終端は、明示的に示した文字の解釈ベースで、1つ以上の数字文字で指定さ
   れます。次のベースが現在定義されます:

         b           =  binary
                        2進数

         d           =  decimal
                        10進数

         x           =  hexadecimal
                        16進数

   Hence:
   つまり:

         CR          =  %d13

         CR          =  %x0D

   respectively specify the decimal and hexadecimal representation of
   [US-ASCII] for carriage return.
   それぞれキャリッジリターンの10進数と16進数の[US-ASCII]での表現の
   指定です。

   A concatenated string of such values is specified compactly, using a
   period (".") to indicate a separation of characters within that
   value.  Hence:
   このような値の連結文字列が、ピリオド(".")を値を示す文字列の区切りに
   使って、小さく指定できます。それ故:

         CRLF        =  %d13.10

   ABNF permits the specification of literal text strings directly,
   enclosed in quotation-marks.  Hence:
   ABNFは、引用符で括った、直接のリテラルテキスト文字列を認めます。
   それ故:

         command     =  "command string"

   Literal text strings are interpreted as a concatenated set of
   printable characters.
   リテラルテキスト文字列がプリント可能な文字の連結集合と解釈されます。

   NOTE:
   重要:

      ABNF strings are case-insensitive and the character set for these
      strings is us-ascii.
      ANF文字列は大文字小文字の違いを無視します、そしてこれらの文字列
      の文字集合はus-asciiです。

   Hence:
   それ故:

         rulename = "abc"

   and:
   と:

         rulename = "aBc"

   will match "abc", "Abc", "aBc", "abC", "ABc", "aBC", "AbC", and
   "ABC".
   は"abc"や"Abc"や"aBc"や"abC"や"ABc"や"aBC"や"AbC"や"ABC"と一致します。

      To specify a rule that IS case SENSITIVE, specify the characters
      individually.
      大文字小文字の違いを識別する規則を指定するためには、個々に文字を
      指定してください。

   For example:
   例えば:

         rulename    =  %d97 %d98 %d99

   or
   または

         rulename    =  %d97.98.99

   will match only the string that comprises only the lowercased
   characters, abc.
   は小文字のabcだけを含む文字列にだけ一致するでしょう。

2.4.  External Encodings
2.4.  外部コーディング

   External representations of terminal value characters will vary
   according to constraints in the storage or transmission environment.
   Hence, the same ABNF-based grammar may have multiple external
   encodings, such as one for a 7-bit US-ASCII environment, another for
   a binary octet environment, and still a different one when 16-bit
   Unicode is used.  Encoding details are beyond the scope of ABNF,
   although Appendix A (Core) provides definitions for a 7-bit US-ASCII
   environment as has been common to much of the Internet.
   最終値文字の外部表現が記憶装置あるいは送信環境での制約に従って変化す
   るでしょう。それ故、同じABNFベースの文法は複数の外部コーディング
   をもつかもしれません、例えば、7ビット合衆国ASCII環境のコーディ
   ング、バイナリオクテット環境のコーディング、16ビットユニコードが使
   われる場合です。付録A(核)が、インターネットの多くに共通の7ビット
   の合衆国ASCII環境の定義を提供しますが、コーディングの細部はAB
   NFの範囲外です。

   By separating external encoding from the syntax, it is intended that
   alternate encoding environments can be used for the same syntax.
   外部のコーディングを構文から分離することによって、別のコーディング環
   境で同じ構文を使うことができるようにします。

3.  OPERATORS
3.  演算子

3.1.  Concatenation:  Rule1 Rule2
3.1.  結合:規則1 規則2

   A rule can define a simple, ordered string of values (i.e., a
   concatenation of contiguous characters) by listing a sequence of rule
   names.  For example:
   規則は単純で、規則名の列ことによって順序付の値列(すなわち、文字列の
   結合)を定義することができます。例えば:

         foo         =  %x61           ; a

         bar         =  %x62           ; b

         mumble      =  foo bar foo

   So that the rule <mumble> matches the lowercase string "aba".
   この場合、規則<mumble>は小文字文字列"aba"に一致します。

   LINEAR WHITE SPACE: Concatenation is at the core of the ABNF parsing
   model.  A string of contiguous characters (values) is parsed
   according to the rules defined in ABNF.  For Internet specifications,
   there is some history of permitting linear white space (space and
   horizontal tab) to be freely and implicitly interspersed around major
   constructs, such as delimiting special characters or atomic strings.
   線形空白スペース:結合がABNF解析モデルの核にあります。文字(値)の
   連続の文字列が、ABNFで定義された規則で解析されます。インターネッ
   ト仕様のために、特別な区切り文字や元始文字列などの主要な構成物の前後
   に、自由にそして暗黙に分散して、空白スペース(空白か水平タブ)を許す
   ある歴史があります。

   NOTE:
   重要:

      This specification for ABNF does not provide for implicit
      specification of linear white space.
      このABNF仕様は空白スペースの暗黙の仕様を供給しません。

   Any grammar that wishes to permit linear white space around
   delimiters or string segments must specify it explicitly.  It is
   often useful to provide for such white space in "core" rules that are
   then used variously among higher-level rules.  The "core" rules might
   be formed into a lexical analyzer or simply be part of the main

   ruleset.
   区切文字や文字列部分の前後に空白スペースを認めることを望む文法は明示
   的に存在を指定しなくてはなりません。高レベルの規則でしばしば使われる
   ので、「核心」規則でこのような空白スペースを備えることはしばしば有用
   です。「核心」規則は語彙の分析者の中に形成されるか、あるいはただ主な
   規則集合のの一部かもしれません。

3.2.  Alternatives:  Rule1 / Rule2
3.2.  選択:規則1/規則2

   Elements separated by a forward slash ("/") are alternatives.
   Therefore,
   フォワードスラッシュ("/")で分割された要素は選択肢です。
   それ故に、

         foo / bar

   will accept <foo> or <bar>.
   は<foo>か<bar>を受け入れるでしょう。

   NOTE:
   重要:

      A quoted string containing alphabetic characters is a special form
      for specifying alternative characters and is interpreted as a
      non-terminal representing the set of combinatorial strings with
      the contained characters, in the specified order but with any
      mixture of upper and lower case.
      アルファベット文字を含む引用文字列は選択文字を指定することに対する
      特別な形式で、指定された順の、任意の大文字小文字の組み合の、文字か
      らなる組合せ文字列集合を示す非終端と解釈されます。

3.3.  Incremental Alternatives: Rule1 =/ Rule2
3.3.  逐次選択:規則1=/規則2

   It is sometimes convenient to specify a list of alternatives in
   fragments.  That is, an initial rule may match one or more
   alternatives, with later rule definitions adding to the set of
   alternatives.  This is particularly useful for otherwise, independent
   specifications that derive from the same parent rule set, such as
   often occurs with parameter lists.  ABNF permits this incremental
   definition through the construct:
   選択肢の断片のリストを指定することはしばしば都合が良いです。すなわち、
   最初の規則がいくつかの選択肢に一致し、後の規則定義が選択を付け加える
   ものです。これは特に、共通の親規則集合から生じる独立の仕様で役立ち、
   これはパラメータリストでしばしば起こります。ABNFは概念としてこの
   逐次的定義を認めます:

         oldrule     =/ additional-alternatives

   So that the rule set
   規則集合

         ruleset     =  alt1 / alt2

         ruleset     =/ alt3

         ruleset     =/ alt4 / alt5

   is the same as specifying
   は以下の指定と同じす。

         ruleset     =  alt1 / alt2 / alt3 / alt4 / alt5

3.4.  Value Range Alternatives:  %c##-##
3.4.  価範囲選択:%c##-##

   A range of alternative numeric values can be specified compactly,
   using dash ("-") to indicate the range of alternative values.  Hence:
   ダッシュを選択数値範囲として選択数値の範囲を簡単に指定できます。それ
   故:

         DIGIT       =  %x30-39

   is equivalent to:
   は以下と同等です:

         DIGIT       =  "0" / "1" / "2" / "3" / "4" / "5" / "6" /

                        "7" / "8" / "9"

   Concatenated numeric values and numeric value ranges cannot be
   specified in the same string.  A numeric value may use the dotted
   notation for concatenation or it may use the dash notation to specify
   one value range.  Hence, to specify one printable character between
   end of line sequences, the specification could be:
   連結された数値と数価範囲が同じ文字列で指定できません。数値の結合のた
   めにドット表記法を使うかもしれません、あるいは1つの数値範囲を指定す
   るためにダッシュ表記を使うかもしれません。それ故、行の終わりの間の印
   刷可能文字を指定する仕様は以下であり得ます:

         char-line = %x0D.0A %x20-7E %x0D.0A

3.5.  Sequence Group:  (Rule1 Rule2)
3.5.  順序グループ:(規則1 規則2)

   Elements enclosed in parentheses are treated as a single element,
   whose contents are STRICTLY ORDERED.  Thus,
   括弧に囲まれた要素は、中身が厳密に順序付の、単一要素として取り扱われ
   ます。それで、

         elem (foo / bar) blat

   matches (elem foo blat) or (elem bar blat), and
   は(elem foo blat)あるいは(elem bar blat)に一致します、そして

         elem foo / bar blat

   matches (elem foo) or (bar blat).
   は(elem foo)あるいは(bar blat)に一致します。

   NOTE:
   重要:

      It is strongly advised that grouping notation be used, rather than
      relying on the proper reading of "bare" alternations, when
      alternatives consist of multiple rule names or literals.
      選択肢が多数の規則名あるいはリテラルから成り立つ時、「露出」選択肢に
      対する適切な読み方に頼るより、グループ表記を使われることが強く推奨
      されます。

   Hence, it is recommended that the following form be used:
   それ故、次の書式が使われることが勧められます:

        (elem foo) / (bar blat)

   It will avoid misinterpretation by casual readers.
   それは何気ない読者による誤解を避けるでしょう。

   The sequence group notation is also used within free text to set off
   an element sequence from the prose.
   順序グループ表記はフリーテキストでも使われ、散文からの要素列を引き起こ
   すはずです。

3.6.  Variable Repetition:  *Rule
3.6.  可変繰返:*規則

   The operator "*" preceding an element indicates repetition.  The full
   form is:
   要素より先にある演算子"*"は反復を示します。完全形式は以下です:

         <a>*<b>element

   where <a> and <b> are optional decimal values, indicating at least
   <a> and at most <b> occurrences of the element.
   少なくとも<a>と<b>は任意指定の10進数値で、少なくとも<a>で最大<a>の
   要素の存在を示します。

   Default values are 0 and infinity so that *<element> allows any
   number, including zero; 1*<element> requires at least one;
   3*3<element> allows exactly 3 and 1*2<element> allows one or two.
   デフォルト値が0と無限で、*<element>はゼロを含む任意の数になります;
   1*<element>は最小1つです;3*3<element>は正確に3を許し、ます、
   1*2<element>は1か2を許します。

3.7.  Specific Repetition:  nRule
3.7.  特定繰返し:n規則

   A rule of the form:
   形式の規則:

         <n>element

   is equivalent to
   は以下と同等です。

         <n>*<n>element

   That is, exactly <n> occurrences of <element>.  Thus, 2DIGIT is a 2-
   digit number, and 3ALPHA is a string of three alphabetic characters.
   これは、正確に<n>の<element>の存在です。それで2DIGITは2桁の数で、
   3ALPHAは3つのアルファベット文字列です。

3.8.  Optional Sequence:  [RULE]
3.8.  任意順序:[規則]

   Square brackets enclose an optional element sequence:
   任意の要素の連続を角括弧で囲みます:

         [foo bar]

   is equivalent to
   は以下と同等です。

         *1(foo bar).

3.9.  Comment:  ; Comment
3.9.  コメント:;コメント

   A semi-colon starts a comment that continues to the end of line.
   This is a simple way of including useful notes in parallel with the
   specifications.
   セミコロンから行の終わりまでがコメントです。これは仕様書と並列に有用
   なメモを書く単純な方法です。

3.10.  Operator Precedence
3.10.  演算子優先度

   The various mechanisms described above have the following precedence,
   from highest (binding tightest) at the top, to lowest (loosest) at
   the bottom:
   上に記述された種々のメカニズムは次の優先度を持ちます、上が優先(結合
   が強い)で、下が非優先(緩い)です:

         Strings, Names formation
         文字列、名前生成

         Comment
         コメント

         Value range
         値範囲

         Repetition
         繰り返し

         Grouping, Optional
         グループ、任意

         Concatenation
         結合

         Alternative
         選択

   Use of the alternative operator, freely mixed with concatenations,
   can be confusing.
   選択演算子の使用は、結合と入り混じると、紛らわしくなり得ます。

      Again, it is recommended that the grouping operator be used to
      make explicit concatenation groups.
      再び、明示的な結合のグループ化のためにグループ演算子を使うことが
      勧められます。

4.  ABNF DEFINITION OF ABNF
4.  ABNFのABNFでの定義

   NOTES:
   メモ:

      1. This syntax requires a formatting of rules that is relatively
         strict.  Hence, the version of a ruleset included in a
         specification might need preprocessing to ensure that it can be
         interpreted by an ABNF parser.
      1. この構文は比較的厳密な規則のフォーマット化を必要とします。それ
         故、仕様書に含められた規則集合の版は、ABNF解析機が翻訳でき
         ることを保証するため、事前処理にかける必要があるかもしれません。

      2. This syntax uses the rules provided in Appendix B (Core).
      2. この構文は付録B(核)で供給された規則を使います。

         rulelist       =  1*( rule / (*c-wsp c-nl) )

         rule           =  rulename defined-as elements c-nl
                                 ; continues if next line starts
                                 ;  with white space
                                ; もし次の行が空白スペースから始まる
                                ; なら、継続します。

         rulename       =  ALPHA *(ALPHA / DIGIT / "-")

         defined-as     =  *c-wsp ("=" / "=/") *c-wsp
                                 ; basic rules definition and
                                 ;  incremental alternatives
                                ; 基本的な規則定義と逐次的選択。

         elements       =  alternation *c-wsp

         c-wsp          =  WSP / (c-nl WSP)

         c-nl           =  comment / CRLF
                                 ; comment or newline
                                ; コメントか改行

         comment        =  ";" *(WSP / VCHAR) CRLF

         alternation    =  concatenation
                           *(*c-wsp "/" *c-wsp concatenation)

         concatenation  =  repetition *(1*c-wsp repetition)

         repetition     =  [repeat] element

         repeat         =  1*DIGIT / (*DIGIT "*" *DIGIT)

         element        =  rulename / group / option /
                           char-val / num-val / prose-val

         group          =  "(" *c-wsp alternation *c-wsp ")"

         option         =  "[" *c-wsp alternation *c-wsp "]"

         char-val       =  DQUOTE *(%x20-21 / %x23-7E) DQUOTE
                                 ; quoted string of SP and VCHAR
                                 ;  without DQUOTE
                                ; DQUOTE無しのSPとVCHARの引用文字列

         num-val        =  "%" (bin-val / dec-val / hex-val)

         bin-val        =  "b" 1*BIT
                           [ 1*("." 1*BIT) / ("-" 1*BIT) ]
                                 ; series of concatenated bit values
                                 ;  or single ONEOF range
                                ; 連結ビット値の列、あるいはひとつの
                                ; ONEOF範囲。

         dec-val        =  "d" 1*DIGIT
                           [ 1*("." 1*DIGIT) / ("-" 1*DIGIT) ]

         hex-val        =  "x" 1*HEXDIG
                           [ 1*("." 1*HEXDIG) / ("-" 1*HEXDIG) ]

         prose-val      =  "<" *(%x20-3D / %x3F-7E) ">"
                                 ; bracketed string of SP and VCHAR
                                 ;  without angles
                                 ; prose description, to be used as
                                 ;  last resort
                                ; SPとVCHARの文字列の、角なしの、括弧。
                                ; 散文記述、最後の頼みの綱として用いられる。

5.  SECURITY CONSIDERATIONS
5.  セキュリティの考慮

   Security is truly believed to be irrelevant to this document.
   セキュリティがこの文書に関係がないと信ます。

6.  References
6.  参考文献

6.1.  Normative References
6.1.  参照する参考文献


   [US-ASCII] American National Standards Institute, "Coded Character
              Set -- 7-bit American Standard Code for Information
              Interchange", ANSI X3.4, 1986.

6.2.  Informative References
6.2.  有益な参考文献

   [RFC2234]  Crocker, D. and P. Overell, "Augmented BNF for Syntax
              Specifications: ABNF", RFC 2234, November 1997.

   [RFC733]   Crocker, D., Vittal, J., Pogran, K., and D. Henderson,
              "Standard for the format of ARPA network text messages",
              RFC 733, November 1977.

   [RFC822]   Crocker, D., "Standard for the format of ARPA Internet
              text messages", STD 11, RFC 822, August 1982.


Appendix A.  ACKNOWLEDGEMENTS
付録A.謝辞

   The syntax for ABNF was originally specified in RFC 733.  Ken L.
   Harrenstien, of SRI International, was responsible for re-coding the
   BNF into an augmented BNF that makes the representation smaller and
   easier to understand.
   ABNFの構文は元々RFC 733で指定されました。SRIインターナショナ
   ルのKen L. HarrenstienはBNFを、小さくて理解しやすい拡張BNFに再
   コード化の責任がありました。

   This recent project began as a simple effort to cull out the portion
   of RFC 822 that has been repeatedly cited by non-email specification
   writers, namely the description of augmented BNF.  Rather than simply
   and blindly converting the existing text into a separate document,
   the working group chose to give careful consideration to the
   deficiencies, as well as benefits, of the existing specification and
   related specifications made available over the last 15 years, and
   therefore to pursue enhancement.  This turned the project into
   something rather more ambitious than was first intended.
   Interestingly, the result is not massively different from that
   original, although decisions, such as removing the list notation,
   came as a surprise.
   この最近のプロジェクトは、、非電子メールの仕様書の著者が繰り返したRF
   C822の一部、すなわち拡張BNFで記述したものを、切り出す単純な努
   力として始まりました。ただ、そしてやみくもに既存のテキストを別の文書
   に変換するより、作業班はこれまでの15年にわたる既存の仕様書と関連し
   た仕様書の、利点と欠点に注意深い考慮をする事を選択し、それ故に拡張を
   追跡しました。これはプロジェクトを最初の意図より何か意欲的なものに変
   えました。興味深い事に、リスト注釈を取り去るような決定はあっても、結
   果は元の仕様と大きくは異ならず、驚きました。

   This "separated" version of the specification was part of the DRUMS
   working group, with significant contributions from Jerome Abela,
   Harald Alvestrand, Robert Elz, Roger Fajman, Aviva Garrett, Tom
   Harsch, Dan Kohn, Bill McQuillan, Keith Moore, Chris Newman, Pete
   Resnick, and Henning Schulzrinne.
   この仕様書の「切り離された」版はDRUMS作業班の仕事で、Jerome Abelaと
   Harald AlvestrandとRobert ElzとRoger FajmanとAviva Garrettと
   Tom HarschとDan KohnとBill McQuillanとKeith MooreとChris Newman
   とPete ResnickとHenning Schulzrinneから重要な貢献を得ました。

   Julian Reschke warrants a special thanks for converting the Draft
   Standard version to XML source form.
   ドラフト標準版を XML情報源形式に変換することに対して、
   Julian Reschkeに特別な感謝をします。

Appendix B.  APPENDIX - CORE ABNF OF ABNF
付録B.付録-ABNFの核ABNF

   This Appendix is provided as a convenient core for specific grammars.
   The definitions may be used as a core set of rules.
   この付録は便利な核として特定の文法に提供されます。定義は規則の核集合
   心として用いられるかもしれません。

B.1.  Core Rules
B.1.  核規則

   Certain basic rules are in uppercase, such as SP, HTAB, CRLF, DIGIT,
   ALPHA, etc.
   ある特定の基本的な規則がSP、HTAB、CRLF、DIGIT、ALPHA などのように大
   文字です。

         ALPHA          =  %x41-5A / %x61-7A   ; A-Z / a-z

         BIT            =  "0" / "1"

         CHAR           =  %x01-7F
                                 ; any 7-bit US-ASCII character,
                                ;  excluding NUL
                                ; NULを除く任意の7ビットASCII文字

         CR             =  %x0D
                                 ; carriage return
                                ; キャリッジリターン

         CRLF           =  CR LF
                                 ; Internet standard newline
                                ; インターネット標準改行

         CTL            =  %x00-1F / %x7F
                                 ; controls
                                ; 制御文字

         DIGIT          =  %x30-39
                                 ; 0-9
                                ; 0~9

         DQUOTE         =  %x22
                                 ; " (Double Quote)
                                ; " (ダブルクォート)

         HEXDIG         =  DIGIT / "A" / "B" / "C" / "D" / "E" / "F"

         HTAB           =  %x09
                                 ; horizontal tab
                                ; 水平タブ

         LF             =  %x0A
                                 ; linefeed
                                ; ラインフィード

         LWSP           =  *(WSP / CRLF WSP)
                                 ; linear white space (past newline)
                                ; 連続空白スペース(過去の改行)。

         OCTET          =  %x00-FF
                                 ; 8 bits of data
                                ; 8ビットデータ

         SP             =  %x20

         VCHAR          =  %x21-7E
                                 ; visible (printing) characters
                                ; 可視(印刷可能)文字

         WSP            =  SP / HTAB
                                 ; white space
                                ; 空白スペース

B.2.  Common Encoding
B.2.  共通コーディング

   Externally, data are represented as "network virtual ASCII" (namely,
   7-bit US-ASCII in an 8-bit field), with the high (8th) bit set to
   zero.  A string of values is in "network byte order", in which the
   higher-valued bytes are represented on the left-hand side and are
   sent over the network first.
   外部的に、「ネットワーク仮想ASCII」(8ビットフィールド内の7ビッ
   ト合衆国ASCII)として描かれ、上位(第8)ビットはゼロが設定され
   ます。値列は「ネットワークバイト順」で、上位バイトが左側で表され、そ
   して最初にネットワークに送られます。


Authors' Addresses
著者のアドレス

   Dave Crocker (editor)
   Brandenburg InternetWorking
   675 Spruce Dr.
   Sunnyvale, CA  94086
   US

   Phone: +1.408.246.8253
   EMail: dcrocker@bbiw.net


   Paul Overell
   THUS plc.
   1/2 Berkeley Square
   99 Berkeley Street
   Glasgow
   G3 7HR
   UK

   EMail: paul.overell@thus.net


Full Copyright Statement
著作権表示全文

   Copyright (C) The Internet Society (2005).
   著作権(C)インターネット学会(2005)。

   This document is subject to the rights, licenses and restrictions
   contained in BCP 78, and except as set forth therein, the authors
   retain all their rights.
   この文書はBCP78に含まれる権利と許可と制限の適用を受け、そして
   この中に明らかにされる以外は著者がすべての権利を維持します。

   This document and the information contained herein are provided on an
   "AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE REPRESENTS
   OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY AND THE INTERNET
   ENGINEERING TASK FORCE DISCLAIM ALL WARRANTIES, EXPRESS OR IMPLIED,
   INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE
   INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED
   WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
   この文書とここに含まれる情報はあるがままに供給されます、貢献者と貢献
   者が代表するか貢献者を後援する組織(もしあれば)とインターネット学会
   とインターネット技術標準化タスクフォースは、明確にも暗黙にも、この情
   報の使用が権利の侵害しないことや商業利用や特別の目的への利用に適当で
   ある事の保障を含め、全ての保証を拒否します。

Intellectual Property
知的所有権

   The IETF takes no position regarding the validity or scope of any
   Intellectual Property Rights or other rights that might be claimed to
   pertain to the implementation or use of the technology described in
   this document or the extent to which any license under such rights
   might or might not be available; nor does it represent that it has
   made any independent effort to identify any such rights.  Information
   on the procedures with respect to rights in RFC documents can be
   found in BCP 78 and BCP 79.
   この文書に記述された実装や技術に関して主張される知的財産権や他の権利の
   正当性や範囲について、この様な権利の元でライセンスが利用可能か利用不
   可能かの範囲について、IETFは何の立場もとりません;この様な権利を
   認識する独立の調査をしたとは述べません。RFC文書の権利に関する手続
   きの情報はBCP78とBCP79を見てください。

   Copies of IPR disclosures made to the IETF Secretariat and any
   assurances of licenses to be made available, or the result of an
   attempt made to obtain a general license or permission for the use of
   such proprietary rights by implementers or users of this
   specification can be obtained from the IETF on-line IPR repository at
   http://www.ietf.org/ipr.
   IETF事務局に公開されたIPRの写しと、利用可能な許可証と、仕様書
   の実装者や利用者によってされた一般的な許可書や許可を得るためにされた
   試みの結果は、http://www.ietf.org/iprにあるIETFオンラインIPR
   貯蔵庫で得られます。

   The IETF invites any interested party to bring to its attention any
   copyrights, patents or patent applications, or other proprietary
   rights that may cover technology that may be required to implement
   this standard.  Please address the information to the IETF at ietf-
   ipr@ietf.org.
   IETFは興味を持った誰からでもこの標準を実行するのに必要な技術をカ
   バーする著作権や特許や特許出願や他の所有権の注意を持ってくるように求
   めます。どうかietf-ipr@ietf.orgのIETFに情報を伝えてください。

Acknowledgement
謝辞

   Funding for the RFC Editor function is currently provided by the
   Internet Society.
   RFCエディタ機能のための資金供給が現在インターネット学会によって
   供給されます。

Japanese translation by Ishida So