もう少し踏み込んだ里々の解説です。
里々の仕様書ではないので注意。
里々とは櫛ケ浜やぎ氏が開発した栞で、シンプルかつ簡単にゴーストを作れることから、初心者に推奨される筆頭となっています。「簡単に」という売りは伊達ではなく、特筆すべきは
さくらスクリプトを使うこともできますし、半角文字も記号など一部例外を除いて基本的に全て使う事ができます。里々は初心者向けという側面と共に、トークを主体とするゴースト開発に便利な栞なのです。これは他の栞には真似のできない強力な特徴です。
また、里々は一般に複雑な処理には向かないと言われますが、それでもある程度の関数や文字列操作を備えており、また、不得手であるファイル操作や変数管理も他の栞をSAORIとして使用する等でカバーする事が可能です。
従来より、里々は本体と共に「ポストと狛犬」というテンプレートゴーストのパッケージで配布されており、これの改造によってゴースト制作を行うのが一般的でした。
現状では公式の里々の更新は停止し、有志による里々改修用プロジェクトを搭載したポストと狛犬がこれを引き継いでいます。
注意点としては、これらの開発は個別の有志の手によるものであり、必ずしもポストと狛犬が最新版の里々を搭載しているとは限りません。
バージョンアップにより新規追加された関数などもあります。
詳しくはファイル構成のページで解説されていますが、里々における構成ファイルはおおまかに3種類に分けられます。
まず、里々本体satori.dllと、ライセンス上同梱を義務付けられているsatori_license.txt。(※Mc163-5以降では不要)
次に、ゴーストを構成する辞書(ファイル名がdicから始まるテキストファイル)。
最後に、指定された名前のテキストファイルを用意することによって効果を発揮する補助ファイル。
補助ファイルの中で要求頻度の高いものは、初期変数の設定とsaoriの登録を行うsatori_conf.txt、特定の文字にウェイトを加えたり【タブ】をタブ文字に変換するなど置換機能を設定するreplace.txt/replace_after.txtなどが多くのゴーストで常用されており、相対的に必須だと言うことができます。
里々の辞書はごく普通のtxtファイルで、全角記号の「*」「@」を行頭で使用した行が定義の開始宣言となります。定義の終端は次に「*」か「@」が来るまで、もしくはテキストの終端までです。この時、終端までの改行は自動排除されます。
その他の記号は全て*定義の中で使用します(単体で使用することはできず、また使おうとしても定義の終点が伸びるだけです)。辞書ファイル内において最初に*または@が来るまでの行は無視されます。
詳しくは特殊記号一覧を参照して下さい。
*トーク名 定義行 ~ 定義行 @単語群名 単語定義 単語定義 単語定義
*によるトーク定義中の通常改行は自動的に\nに置換されます。ただし$や>など、行頭で宣言し一行占有する場合はこの限りではありません。
同じトーク名がつけられた場合は、()や>で評価される時の候補となり、ランダムで一つ選択されます。
トーク名を記述しなかった場合、ランダムトークの候補として定義されます。
@による単語定義は、以降の行が常に一行が一候補として定義されます。
つまり、複数行に渡って定義することで、一行ごとに評価時の選出候補となります。*と同様、同じ名前をつけた場合も全て候補になります。
里々では全角の丸括弧()を使い、トーク、単語群、変数、関数(SAORI含む)を呼び出し、評価します。
これは以下の動作をします。
$を行頭に記述し、一行占有して定義します。これに限らず、行頭に記述する記号はすべて*セクション内でのみ用いる記号となります。
$変数名【タブ】値
以上のような行を追加する事で、変数に値を格納できます。
この変数の定義は、一部のシステム設定を司る変数の変更にも使用します。
定義された変数は、例外を除き全てがセーブデータに自動的に保存されます。処理中において自動的に破棄される一時変数などは存在しないため、できるだけ明示的に変数の削除を行う必要があります。
格納された変数はトークと似た扱いになり、()によって参照できます。
里々では特殊記号一覧にある*、@によってベースウェアのリクエストに対応します。
以下はSSPが通知するイベントの例。
GET SHIORI/3.0 Charset: Shift_JIS Sender: SSP SecurityLevel: local ID: OnSecondChange Reference0: 0 Reference1: 0 Reference2: 0 Reference3: 1 Reference4: 0
これに辞書が対応する(レスポンスを定義する)には、
*OnSecondChange 定義
とするだけで、非常に簡単に記述できます。
この内、Charset、Sender、Referenceは後述する方法で参照できます。
*OnBoot 定義 @homeurl http://
作成した定義は、他の栞と同じように、里々内部で自動的にさくらスクリプトによるトークへと変換されてからベースウェアに渡されます。
前述したイベントのReference等を参照する方法です。参考→情報取得変数のシステム情報
以上のような括弧を含めた記述がそれぞれヘッダ情報に置換されます。
ただし、Referenceに関してはこれをそのまま使うより、(R0)(R1)(R2)....という記述での参照を推奨します。
これは、里々はsaoriからの戻り値に(S○)、ループ関数のカウンタに(C○)、ユーザ関数の引数に(A○)…といった形で似たような記述による参照方法が存在するためです。
里々ではゴースト開発を補助する独自イベントがあります。
これらは里々内部の処理であるため、辞書側で制御できません。
例えば、「○△つつかれ」は里々で触り反応を制作しやすくしている機能の一つですが、これはベースウェアから通知される栞イベント「OnMouseDoubleClick」を利用して行われています。
従って、「○△つつかれ」「OnMouseDoubleClick」の両方を辞書に定義すると、基本的にOnMouseDoubleClickで定義したものが優先されて、○△つつかれの内容は実行されません。
里々の独自イベントにはこうした既存の栞イベントを使って実現しているものとそうでないものがあり、高度な処理を行う場合は優先順位や未定義時の反応などを各自調査する必要が出てきます。
ところで、独自イベントには書式として学ぶべき点も多くあります。
例えば「○△つつかれ」は、OnMouseDoubleClickに以下の定義したものと等価です。
該当するラベルのトークがあればそれを呼び出し、なければスルーする仕組みとなります。
*OnMouseDoubleClick >(R3)(R4)つつかれ
独自イベントには記載されていませんが、これも独自の機能にあたります。
里々のランダムトークは、特殊変数の定義に従って、一定間隔で自動的にラベルのない(*のみの)トークを実行するものだと考えて下さい。
この機能はOnSecondChange*1で制御する事はできず、特殊変数によってのみ里々内部のランダムトーク設定で制御します。
参考:さくらスクリプト
里々は様々な独自仕様と記述方法を持っていますが、さくらスクリプトを使用する事もできます。
使用条件や前準備などは必要ありません。
但し、選択肢関連のさくらスクリプトとイベントには、独自の情報取得変数のために改変が施されます。
里々の内部処理を参照して下さい。