Next: Buffer List, Previous: Modification Time, Up: Buffers [Contents][Index]
あるバッファーが読み取り専用(read-only)の場合は、たとえスクロールやナローイングによってファイルのコンテンツのビューを変更しても、そのコンテンツを変更することはできません。
読み取り専用バッファーは、2つのタイプの状況において使用されます:
ここでの目的は、ユーザーにたいしてそのファイルへの保存を意図したバッファーの編集が無益、または望ましくないかもしれないことを伝えることである。それにも関わらずバッファーのテキストの変更を望むユーザーは、C-x C-qで読み取り専用フラグをクリアーした後、これを行うことができる。
このようなモードのスペシャルコマンドは、buffer-read-only
を(let
により)nil
にバインドしたり、テキストを変更する箇所ではinhibit-read-only
をt
にバインドする。
このバッファーローカル変数は、そのバッファーが読み取り専用かどうかを指定する。この変数が非nil
なら、そのバッファーは読み取り専用である。
この変数が非nil
の場合、読み取り専用バッファー、およびその実際の値に依存して、一部もしくはすべての読み取り専用文字が変更されている。バッファー内の読み取り専用文字とは、テキストプロパティread-only
が非nil
の文字である。テキストプロパティについての詳細は、Special Propertiesを参照のこと。
inhibit-read-only
がt
の場合、すべてのread-only
文字プロパティは効果がなくなる。inhibit-read-only
がリストの場合、read-only
文字プロパティがリストのメンバーなら効果がなくなる(比較はeq
で行われる)。
これは、バッファーローカルなマイナーモードである、Read
Onlyモードにたいするモードコマンドである。このモードが有効なときは、そのバッファーのbuffer-read-only
は非nil
である。無効なときは、そのバッファーのbuffer-read-only
はnil
である。呼び出す際の慣習は、他のマイナーモードコマンドの慣習と同じである(Minor Mode Conventionsを参照)。
このマイナーモードは他のマイナーモードとは異なり、主にbuffer-read-only
にたいするラッパーの役目を果たし、別個にread-only-mode
変数は存在しない。Read
Onlyモードが無効なときでも、read-only
テキストプロパティが非nil
の文字は読み取り専用のままである。一時的にすべての読み取り専用ステータスを無視するには、上述のinhibit-read-only
をバインドすること。
Read
Onlyモードを有効にする際、このモードコマンドはオプションview-read-only
が非nil
なら、Viewモードも有効にする。Miscellaneous Buffer Operations in The GNU Emacs
Manualを参照のこと。Read Onlyモードを無効にする際に、もしもViewモードが有効なら、Viewモードも無効にする。
この関数は、カレントバッファーが読み取り専用の場合は、buffer-read-only
エラーをシグナルする。カレントバッファーが読み取り専用の場合にエラーをシグナルする他の方法については、Using Interactiveを参照のこと。