ABNF(Augmented Backus–Naur form)は、バッカス・ナウア記法 (BNF) の拡張の一種。構文規則や生成規則はBNFとは異なる。通信プロトコルなどの言語の形式体系を記述するメタ言語として開発された。RFC 5234 で文書化されており、IETF が通信プロトコルを定義する際によく使っている。拡張バッカス・ナウア記法とも呼ばれるが、EBNF(Extended Backus-Naur Form)も同じ訳語となるため、区別するためあえて ABNF としている。RFC 5234 は、RFC 4234およびRFC 2234 に存在した問題を修正し置換したものである。ABNFの記述は以下のような生成規則群からなる。ここで、rule は大文字小文字が区別される非終端記号、definition はその rule を定義する記号列、comment は文書化のためのコメントである。最後尾には必ず CR と LF による改行コードが付属する。規則名は大文字小文字を区別しない。codice_1 も codice_2 も codice_3 も同じ規則を参照している。規則名はいわゆるアルファベット文字で始まり、その後にアルファベット、数字、ハイフンが続く。山括弧(codice_4とcodice_5)は規則名を囲むのに必要とはされていない。しかし、規則名を識別しやすいように山括弧で囲むことが多い。ABNF は 7ビットASCIIで符号化され、最上位の8ビット目はゼロに設定される。終端記号は1つ以上の文字コードで表される。文字コードは、パーセント記号“codice_6”とそれに続く基数を表す文字(b = 2進、d = 10進、x = 16進)、さらに値で示される。文字列は値を “codice_7”で連結することで表される。例えば、復帰コードは codice_8 または codice_9 で示される。復帰コードの後に改行コードが続く場合、連結を使って codice_10 などと表される。リテラルテキストは引用符 (codice_11) で囲まれた文字列を使って表される。これら文字列は大文字小文字が区別されず、文字セットとしては US-ASCII が使われる。従って、“abc”という文字列は、“abc”、“Abc”、“aBc”、“abC”、“ABc”、“AbC”、“aBC”、“ABC”とマッチする。大文字小文字を区別したい場合、文字コードを上述の記法で指定するかRFC 7405で導入された“%s”プレフィクスを使用するかする必要がある。“aBc”という大文字小文字の組合せを表したい場合、codice_12あるいはcodice_13 とする。空白は定義内の各要素を区切るのに使われる。規則名を並べることで規則が定義される。“aba”にマッチする文字列を定義するには、次のような規則群を使用する。規則名を斜線 (“codice_19”) で区切って並べることで選択肢型の規則が定義される。規則
出典:wikipedia
LINEスタンプ制作に興味がある場合は、
下記よりスタンプファクトリーのホームページをご覧ください。