<!-- -*- mode:text coding:euc-jp -*-
   $FML: cgi.examples.sgml,v 1.3 2005/06/25 15:11:33 fukachan Exp $

   注意: cgi.sgml の中にはめ込むので <chapter> は不必要だ。
-->


<sect1 id="cgi.internal.example.isa">
	<title>
	CGI の実装: CGI 関連クラスの継承関係
	</title>

<para>
config.cgi では、@ISA (継承関係)が次のようになっています。
<screen>
FML::CGI::Menu   FML::Process::CGI::Kernel FML::Process::CGI::Param
</screen>
thread.cgi の継承も同様で、次のようになっています。
<screen>
FML::CGI::Thread FML::Process::CGI::Kernel FML::Process::CGI::Param
</screen>
</para>

<para>
各 .cgi 固有のコードは FML::CGI:: の階層に置くようにしています。
</para>

<para>
固有でないコード(.cgi 群で共有するコード)は
FML::Process::CGI::Kernel に定義されています。
ここには、
プロセス全体の制御部分と、
デフォルトの CGI 固有関数「run_cgi_なんとか()」が定義されています。
</para>

<para>
必要に応じて FML::CGI:: の階層で、
これらのメソッドをオーバーロードしてください。
</para>

<para>
なお、FML::Process::CGI::Kernel の以下のメソッドは定義されているだけで、
実際には使われていません。
<screen>
run_cgi_log
run_cgi_dummy
run_cgi_date
</screen>
</para>

</sect1>


<sect1 id="cgi.internal.example.config.cgi">
	<title>
	CGI の実装: config.cgi の実装
	</title>

<para>
前述のように config.cgi の場合、継承関係は次のようになっています。
<screen>
FML::CGI::Menu FML::Process::CGI::Kernel FML::Process::CGI::Param
</screen>
以下では、config.cgi の処理をみてみましょう。
</para>

<para>
config.cgi のプロセスオブジェクト $curproc は
FML::Process::CGI::Kernel クラスです。
FML::Process::CGI::Kernel では
<screen>
	new()
	prepare()
	verify_request()
	run()
	finish()
</screen>
が順に呼ばれます。
</para>

<para>
重要なのは run() です。run() は
<screen>
    $curproc->html_start();          (FML::CGI::Menu)
    $curproc->_drive_cgi_by_table(); (FML::Process::CGI::Kernel)
    $curproc->html_end();            (FML::CGI::Menu)
</screen>
を実行します。
CGI の画面を作る実体は _drive_cgi_by_table() メソッドです。
このメソッド内から呼ばれる関数が CGI のメイン部分です。
</para>

<para>
$curproc->_drive_cgi_by_table() メソッドは、
以下の各「run_いろいろ()」メソッド群を呼び出します。
</para>

<para>
たとえば、コマンドを実行するメイン部分が run_cgi_main です。
これは、
cgi_execute_command (FML::Process::CGI::Kernel) を呼び出し、
FML::Command 経由で「FML::Command::Admin::コマンド」クラスを実行します。
これが、GUI からコマンドを実行するコードの本体です。
</para>

<para>
画面の表示をする際には、
別のメソッド群が呼ばれています。
</para>

<para>
たとえば GUI から「ユーザのメールアドレスを登録する」場合、
run_cgi_menu() が入力画面の生成をおこないます。
run_cgi_menu() は cgi_execute_cgi_menu() 経由で、
各コマンドクラスの
「FML::Command::Admin::コマンド::cgi_menu()」を実行しています。
この場合
FML::Command::Admin::subscribe::cgi_menu() 
メソッドを呼び出しています。
</para>

<para>
ちなみに、実際の登録作業をする run_cgi_main() は、
FML::Command::Admin::subscribe::process() 
メソッドを呼び出しています。
</para>

<para>
他にも run_cgi_* 関数がありますが、
これらは画面の作りに関係する補助的な関数と言ってよいでしょう。
</para>

<para>
次の２つのメソッドは、たいていデフォルトの関数を呼び出しています。
<screen>
run_cgi_title             FML::Process::CGI::Kernel クラス (タイトル表示)
run_cgi_options           FML::Process::CGI::Kernel クラス (言語選択画面)
</screen>
また、
この .cgi 固有の画面作り関連メソッド群として次のものがあります。
<screen>
run_cgi_navigator         FML::CGI::Menu クラス
run_cgi_help              FML::CGI::Menu クラス
run_cgi_command_help      FML::CGI::Menu クラス
run_cgi_menu              FML::CGI::Menu クラス
</screen>
ヘルプなどはコマンドごとに違うわけですから、当たり前ですね？
もっとも、
これらは、
メッセージなどが異なるだけで、
モジュールが違っても、
ほぼ似たようなつくりになっています。
</para>

</sect1>
