Next: Information about Files, Previous: Writing to Files, Up: Files [Contents][Index]
2人のユーザーが同時に同じファイルを編集する際、おそらく彼らは互いに干渉しあうことになるでしょう。Emacsはファイルが変更される際にファイルロック(file lock)を記録することによって、このような状況の発生を防ぎます。そしてEmacsは他のEmacsジョブにロックされているファイルをvisitしているバッファーへの変更の最初の試みを検知して、ユーザーに何を行うか尋ねます。このファイルロックの実態は、編集中のファイルと同じディレクトリーに格納される特別な名前をもつシンボリックリンクです(シンボリックリンクをサポートしないファイルシステムでは通常ファイルが使用される)。
ファイルのアクセスにNFSを使用する際には、可能性は小さいものの他のユーザーと同じファイルを同時にロックするかもしれません。これが発生すると2人のユーザーが同時にファイルを変更することが可能になりますが、それでもEmacsは2番目に保存するユーザーにたいして警告を発するでしょう。たファイルをvisitしているバッファーでディスク上でファイルの変更を検知することにより、ある種の同時編集を捕捉できます。Modification Timeを参照してください。
この関数はファイルfilenameがロックされていなければnil
をリターンする。このEmacsプロセスによりロックされていればt
、他のEmacsジョブによりロックされている場合はロックしたユーザーの名前をリターンする。
(file-locked-p "foo") ⇒ nil
この関数はカレントバッファーが変更されていればファイルfilenameをロックする。引数filenameのデフォルトはカレントバッファーがvisitしているファイル。カレントバッファーがファイルをvisitしていない、バッファーが変更されていない、またはcreate-lockfiles
がnil
なら何もしない。
この関数はカレントバッファーが変更されていればバッファーによりvisitされているファイルをアンロックする。バッファーが変更されていなければ、そのファイルをロックしてはならないのでこの関数は何もしない。カレントバッファーがファイルをvisitしていない、またはファイルがロックされていなければこの関数は何もしない。
この変数がnil
ならEmacsはファイルをロックしない。
この関数はユーザーがfileの変更を試みたが、それが名前other-userのユーザーにロックされていたとき呼び出される。この関数のデフォルト定義は何を行うかユーザーに尋ねる関数。この関数がリターンする値はEmacsが次に何を行うかを決定する:
t
はそのファイルのロックを奪うことを意味する。その場合にはother-userはロックを失い、そのユーザーがファイルを編集することができる。
nil
はロックを無視して、とにかくユーザーがファイルを編集できるようにすることを意味する。
file-locked
をシグナルする。この場合には、ユーザーが行おうとしていた変更は行われない。
このエラーにたいするエラーメッセージは以下のようになる:
error→ File is locked: file other-user
ここでfile
はファイル名、other-userはそのファイルのロックを所有するユーザーの名前。
望むなら他の方法で判定を行う独自バージョンでask-user-about-lock
関数を置き換えることができる。