Next: Window Sizes, Previous: Basic Windows, Up: Windows [Contents][Index]
ウィンドウはそれぞれ厳密に1つのフレームに属します(Framesを参照)。
この関数はウィンドウwindowが属するフレームをリターンする。windowがnil
の場合のデフォルトは選択されたウィンドウ。
この関数はフレームframeに属する生きたウィンドウのリストをリターンする。frameが省略またはnil
の場合のデフォルトは選択されたフレーム。
オプション引数minibufferはリターンされるリストにミニバッファーウィンドウを含めるべきかどうかを指定する。minibufferがt
ならミニバッファーウィンドウが含まれ、minibufferがnil
または省略された場合にはミニバッファーウィンドウがアクティブのときだけ含まれる。minibufferがnil
とt
以外ならミニバッファーウィンドウは含まれない。
オプション引数windowが非nil
なら、それは指定されたフレーム上の生きたウィンドウであること。その場合にはwindowがリターンされるリストの最初の要素になる。windowが省略またはnil
なら、そのフレームの選択されたウィンドウが最初の要素になる。
同一フレーム内のウィンドウは、リーフノード(leaf nodes)が生きたウィンドウであるようなウィンドウツリー(window tree)内に組織化されます。ウィンドウツリーの内部ノード(internal nodes)は生きたウィンドウではありません。これらのウィンドウは生きたウィンドウ間の関係を組織化するという目的のために存在します。ウィンドウツリーのルートノード(root node)はルートウィンドウ(root window)と呼ばれます。ルートノードは生きたウィンドウ(そのフレームにウィンドウが1つだけの場合)、または内部ウィンドウのいずれかです。
フレーム内で唯一ではないミニバッファーウィンドウ(Minibuffer Windowsを参照)は親ウィンドウをもたないので、厳密に言えばフレームのウィンドウツリーの一部ではありません。それでもフレームのルートウィンドウの兄弟ウィンドウなので、window-next-sibling
を通じて到達することができます。さらにこのセクションの最後に説明する関数window-tree
は実際のウィンドウツリーと共にミニバッファーウィンドウをリスとします。
この関数はframe-or-windowにたいするルートウィンドウをリターンする。引数frame-or-windowはウィンドウかフレームのいずれかであること。これが省略またはnil
の場合のデフォルトは選択されたフレーム。frame-or-windowがウィンドウなら、リターン値はそのウィンドウのフレームのルートウィンドウ。
ウィンドウが分割(split)されているときは、以前は1つだった2つの生きたウィンドウが存在します。これらのうちの一方は、元のウィンドウと同じLispウィンドウオブジェクトとして表され、もう一方は新たに作成されたLispウィンドウオブジェクトとして表されます。これらの生きたウィンドウはいずれも単一の内部ウィンドウの子ウィンドウ(child windows)として、ウィンドウツリーのリーフノードになります。もし必要ならEmacsはこの内部ウィンドウを自動的に作成します。この内部ウィンドウは親ウィンドウ(parent window)とも呼ばれ、ウィンドウツリー内の適切な位置に配置されます。同じ親を共有するウィンドウセットは兄弟(sibling)と呼ばれます。
この関数はwindowの親ウィンドウ(parent
window)をリターンする。windowが省略またはnil
の場合のデフォルトは選択されたウィンドウ。windowが親をもたない場合(ミニバッファーウィンドウやそのフレームのルートウィンドウ)にはリターン値はnil
。
内部ウィンドウはそれぞれ、常に最低でも2つの子ウィンドウをもちます。ウィンドウ削除によりこの数値が1になるとEmacsは自動的に内部ウィンドウを削除して、その残った単一の子ウィンドウがウィンドウツリー内のその位置に配置されます。
子ウィンドウはそれぞれ生きたウィンドウ、または(次に自身の子ウィンドウをもつであろう)内部ウィンドウのいずれかです。したがって各内部ウィンドウは、最終的にはその内部ウィンドウの子孫であるような生きたウィンドウにより占有される領域を結合した、特定の矩形スクリーン領域(screen area)を占有すると考えることができます。
内部ウィンドウそれぞれにたいして、近接する子たちのスクリーン領域は垂直(vertically)か水平(horizontally)のいずれかにより整列されます(両方で整列されることはない)。子ウィンドウが他の子ウィンドウと上下に整列される場合、それらは垂直コンビネーション(vertical combination)、左右に整列される場合は水平コンビネーション(horizontal combination)を形成すると表現されます。以下の例で考えてみましょう:
______________________________________ | ______ ____________________________ | || || __________________________ || || ||| ||| || ||| ||| || ||| ||| || |||____________W4____________||| || || __________________________ || || ||| ||| || ||| ||| || |||____________W5____________||| ||__W2__||_____________W3_____________ | |__________________W1__________________|
このフレームのルートウィンドウは内部ウィンドウW1です。これの子ウィンドウは、生きたウィンドウW2と内部ウィンドウW3からなる水平コンビネーションを形成します。W3の子ウィンドウは、生きたウィンドウW4とW5からなる垂直コンビネーションを形成します。したがって、このウィンドウツリー内の生きたウィンドウはW2、W4、およびW5です。
以下の関数は内部ウィンドウの子ウィンドウ、および子ウィンドウの兄弟を取得するために使用できます。
この関数は内部ウィンドウwindowの子ウィンドウが垂直コンビネーションを形成する場合には、windowの一番上の子ウィンドウをリターンする。他のタイプのウィンドウにたいするリターン値はnil
。
この関数は内部ウィンドウwindowの子ウィンドウが水平コンビネーションを形成する場合には、windowの一番左の子ウィンドウをリターンする。他のタイプのウィンドウにたいするリターン値はnil
。
この関数は内部ウィンドウwindowの最初の子ウィンドウをリターンする。これは垂直コンビネーションにたいしては一番上、水平コンビネーションにたいしては一番左の子ウィンドウ。windowが生きたウィンドウならリターン値はnil
。
この関数はwindowが垂直コンビネーションの一部である場合のみ非nil
をリターンする。windowが省略またはnil
の場合のデフォルトは選択されたウィンドウ。
オプション引数horizontalが非nil
なら、windowが水平コンビネーションの一部である場合のみ非nil
をリターンすることを意味する。
この関数はウィンドウwindowの次の兄弟をリターンする。省略またはnil
なら、windowのデフォルトは選択されたウィンドウ。windowがその親の最後の子ならリターン値はnil
。
この関数はウィンドウwindowの前の兄弟をリターンする。省略またはnil
なら、windowのデフォルトは選択されたウィンドウ。windowがその親の最初の子ならリターン値はnil
。
関数window-next-sibling
とwindow-prev-sibling
を、ウィンドウのサイクル順(Cyclic Window Orderingを参照)で次や前のウィンドウをリターンする関数next-window
とprevious-window
と混同しないでください。
以下の関数はフレーム内のウィンドウの配置に有用です。
この関数はframe-or-windowにより指定されたフレームの左上隅の生きたウィンドウをリターンする。引数frame-or-windowはウィンドウか生きたフレームを指定しなければならず、デフォルトは選択されたフレーム。frame-or-windowがウィンドウを指定する場合には、この関数はそのウィンドウのフレームの最初のウィンドウをリターンする。前の例のフレームが(frame-first-window)
で選択されたとするとW2がリターンされる。
この関数はwindowのフレーム内でwindowがsideに配置されていればt
をリターンする。引数windowは有効なウィンドウでなければならず、デフォルトは選択されたウィンドウ。引数sideはシンボルleft
、top
、right
、bottom
のいずれか。デフォルト値のnil
はbottom
として扱われる。
この関数はミニバッファーウィンドウを無視することに注意(Minibuffer Windowsを参照)。したがってsideがbottom
なら、windowの右下にミニバッファーウィンドウがある際にもt
をリターンするかもしれない。
この関数はウィンドウwindow内の位置window-point
から、方向directionにあるもっとも近い生きたウィンドウをリターンする。引数directionはabove
、below
、left
、right
のいずれかでなければならない。オプション引数windowは生きたウィンドウでなければならず、デフォルトは選択されたウィンドウ。
この関数はパラメーターno-other-window
が非nil
のウィンドウをリターンしない(Window Parametersを参照)。もっとも近いウィンドウのno-other-window
パラメーターが非nil
なら、この関数は指定された方向でno-other-window
パラメーターがnil
であるような他のウィンドウを探す。オプション引数ignoreが非nil
なら、たとえno-other-window
パラメーターが非nil
のウィンドウでもリターンされるだろう。
オプション引数signが負の数値なら、それは参照位置としてwindow-point
のかわりにwindowの右端、または下端を使用することを意味する。signが正の数値なら、それは参照位置としてwindowの左端か上端を使用することを意味する。
オプション引数wrapが非nil
なら、それはフレームのボーダー(borders:
枠線)をdirectionがラップアラウンド(wrap around:
最後に達したら最初に戻る)することを意味する。たとえばwindowはフレームの最上にありdirectionがabove
なら、そのフレームのミニバッファーウィンドウがアクティブでそれがフレームの他のウィンドウの最下にある場合には、この関数は通常はミニバッファーウィンドウをリターンする。
miniがnil
なら、カレントでアクティブな場合のみミニバッファーウィンドウをリターンすることを意味する。minibufが非nil
なら、この関数はアクティブではないミニバッファーウィンドウをリターンするかもしれない。しかしwrapが非nil
なら、常にminiがnil
であるかのように振る舞う。
適切なウィンドウが見つからなければ、この関数はnil
をリターンする。
この関数をdirectionにウィンドウが存在しないかどうかをチェックするために使用しないこと。それを行うには上述のwindow-at-side-p
を呼び出すほうが効果的である。
以下の関数によりフレームのウィンドウツリー全体を取得できます:
この関数はフレームframeにたいするウィンドウツリーを表すリストをリターンする。frameが省略nil
の場合のデフォルトは選択されたフレーム。
リターン値は(root
mini)
という形式のリスト。ここでrootはそのフレームのウィンドウツリーのルートウィンドウ、miniはそのフレームのミニバッファーウィンドウを表す。
ルートウィンドウが生きていればrootはそのウィンドウ自身、それ以外ならrootはリスト(dir
edges w1 w2
...)
。ここでdirは水平コンビネーションならnil
、垂直コンビネーションならt
となり、edgesはそのコンビネーションのサイズと位置を与え、残りの要素は子ウィンドウである。子ウィンドウはそれぞれ、同じようにウィンドウオブジェクト(生きたウィンドウにたいして)、または上記フォーマットと同じ形式のリスト(内部ウィンドウにたいして)かもしれない。edges要素はwindow-edges
がリターンする値のようなリスト(left
top right bottom)
(Coordinates and Windowsを参照)。