"stringprep" --- インターネットのための文字列調製
*************************************************

**ソースコード:** Lib/stringprep.py

======================================================================

(ホスト名のような) インターネット上にある存在に識別名をつける際、しば
しば識別名間の "等価性" 比較を行う必要があります。厳密には、例えば大小
文字の区別をするかしないかいったように、比較をどのように行うかはアプリ
ケーションの領域に依存します。また、例えば "印字可能な" 文字で構成され
た識別名だけを許可するといったように、可能な識別名を制限することも必要
となるかもしれません。

**RFC 3454** では、インターネットプロトコル上で Unicode 文字列を "調製
(prepare)" するためのプロシジャを定義しています。文字列は通信路に載せ
られる前に調製プロシジャで処理され、その結果ある正規化された形式になり
ます。RFC ではあるテーブルの集合を定義しており、それらはプロファイルに
まとめられています。各プロファイルでは、どのテーブルを使い、
"stringprep" プロシジャのどのオプション部分がプロファイルの一部になっ
ているかを定義しています。 "stringprep" プロファイルの一つの例は
"nameprep" で、国際化されたドメイン名に使われます。

"stringprep" は **RFC 3454** のテーブルを公開しているに過ぎません。こ
れらのテーブルは辞書やリストとして表現するにはバリエーションが大きすぎ
るので、このモジュールでは Unicode 文字データベースを内部的に利用して
います。モジュールソースコード自体は "mkstringprep.py" ユーティリティ
を使って生成されました。

その結果、これらのテーブルはデータ構造体ではなく、関数として公開されて
います。RFC には 2 種類のテーブル: 集合およびマップ、が存在します。集
合については、 "stringprep" は "特性関数 (characteristic function)" 、
すなわち引数が集合の一部である場合に "True" を返す関数を提供します。マ
ッピングについては、マップ関数: キーが与えられると、それに関連付けられ
た値を返す関数を提供します。以下はこのモジュールで利用可能な全ての関数
を列挙したものです。

stringprep.in_table_a1(code)

   *code* がテーブル A.1 (Unicode 3.2 における未割り当てコードポイント
   : unassigned code point) かどうか判定します。

stringprep.in_table_b1(code)

   *code* がテーブル B.1 (一般には何にも対応付けられていない: commonly
   mapped to nothing) かどうか判定します。

stringprep.map_table_b2(code)

   テーブル B.2 (NFKC で用いられる大小文字の対応付け) に従って、*code*
   に対応付けられた値を返します。

stringprep.map_table_b3(code)

   テーブル B.3 (正規化を伴わない大小文字の対応付け) に従って、*code*
   に対応付けられた値を返します。

stringprep.in_table_c11(code)

   *code* がテーブル C.1.1 (ASCII スペース文字) かどうか判定します。

stringprep.in_table_c12(code)

   *code* がテーブル C.1.2 (非 ASCII スペース文字) かどうか判定します
   。

stringprep.in_table_c11_c12(code)

   *code* がテーブル C.1  (スペース文字、C.1.1 および C.1.2 の和集合)
   かどうか判定します。

stringprep.in_table_c21(code)

   *code* がテーブル C.2.1 (ASCII 制御文字) かどうか判定します。

stringprep.in_table_c22(code)

   *code* がテーブル C.2.2 (非 ASCII 制御文字) かどうか判定します。

stringprep.in_table_c21_c22(code)

   *code* がテーブル C.2  (制御文字、C.2.1 および C.2.2 の和集合) かど
   うか判定します。

stringprep.in_table_c3(code)

   *code* がテーブル C.3 (プライベート利用) かどうか判定します。

stringprep.in_table_c4(code)

   *code* がテーブル C.4 (非文字コードポイント: non-character code
   points) かどうか判定します。

stringprep.in_table_c5(code)

   *code* がテーブル C.5 (サロゲーションコード) かどうか判定します。

stringprep.in_table_c6(code)

   *code* がテーブル C.6 (平文:plain text として不適切) かどうか判定し
   ます。

stringprep.in_table_c7(code)

   *code* がテーブル C.7 (標準表現:canonical representation  として不
   適切) かどうか判定します。

stringprep.in_table_c8(code)

   *code* がテーブル C.8 (表示プロパティの変更または撤廃) かどうか判定
   します。

stringprep.in_table_c9(code)

   *code* がテーブル C.9 (タグ文字) かどうか判定します。

stringprep.in_table_d1(code)

   *code* がテーブル D.1 (双方向プロパティ "R" または "AL"  を持つ文字
   ) かどうか判定します。

stringprep.in_table_d2(code)

   *code* がテーブル D.2 (双方向プロパティ "L" を持つ文字)  かどうか判
   定します。
