[スマートフォルダ]Spotlightを使いこなそう! 4[検索]
1.SCの仕組み
spotlight commentに書き込まれた情報は、3カ所に格納される。
(a) .DS_Store:Finder上で"情報をみる”によって確認可能
(b) spotlight database:各volumeのルートディレクトリにある不可視フォルダ内部に格納されている。
「mdls ファイル名」で確認できる。
(c) 拡張属性(Extended Attributes; 以下EA):ファイル本体の一部。com.apple.metadata:kMDItemFinderComment
という場所に格納されている。格納されている情報は「xattr -l ファイル名」で確認できる。
(a)にコメントやタグを書き込むと、それが、(b), (c)にも自動的に反映されます。
2.SCの問題点
ファイル一個ずつに、「情報を見る」を開いて、自分の手でSCを書き込んで行く分には、
問題ありません。(a), (b), (c), 3つの情報は間違いなく同期されます。
しかし、タグ付けソフト(punakea, Leap, Yep, Together, Tag Folders, Tagbot etc...)を
使って、「一度に、複数のファイルに情報を書き込む」と、とたんに問題が生じます。例えば、
(a)の情報はちゃんと書き換えられたのに、それが(b)に変更されない等。特に、ファイル数が10程度でも
一気にタグを付けようとすると、(a)vs.(b)の間に食い違いが生じます。
他にも、次のようなケースでは、3つの情報に食い違いが生じることがあります。
ケース1:.DS_Storeを手動で削除する
ケース2:terminal上で、xattrコマンドを使い、ファイルのEA(com.apple.metadata:kMDItemFinderComment)を削除する。
いったん、(a), (b), (c)の間に食い違いが生じると、それを修正するのはかなり困難です。
数時間かけて、spotlightのreindexをせにゃならん時もあります。場合によっては、
時間をかけて蓄積した情報が消え去ってしまう事すらあります。
(2.SCの問題点、続き)
もう一つの問題は、複数のMac間で、ファイルを同期する場合です。基本的に、
ファイル本体と.DS_Storeの2つが、同時にコピーされないと、SCは同期されません。
多くの同期ソフトは、ファイルに変更が加えられた場合、あるいは、ファイル変更時間が
変化した場合にのみ、そのファイルを、同期先へコピーします。ところが、SCを変更しても
ファイルサイズや変更時間は、変化しないのです。ただ単に、.DS_Storeのサイズや変更時間が
代わるので、それだけがコピーされます。
一方、同期先のMacでは、.DS_Storeが新しいものと置き換わるので、(a)は更新されます。
ところが、.DS_Storeがコピーされただけでは、(b), (c)は変化しません。ここでも、3つの
情報間に食い違いが生じてしまいます。
余談ですが、この問題は、rsync 3.0を使えば回避できます。なぜなら、rsync 3.0はEAに変化が
生じるとそれにトリガーされて、ファイル本体を同期先にコピーするからです。.DS_Storeとファイル
本体がコピーされると、同期先の(b)も更新されるのです。
(2.SCの問題点、さらに続き)
良く似た問題ですが、「フォルダXからフォルダYにファイルを移動、コピーしたら
SCの情報が消える」という現象も存在します。
Finder上でファイルを移動/コピーする分には問題ありません。ファイル本体の移動に
よってEAが移動するだけでなく、コピー先(Y)の.DS_Storeも、Finderが責任もって
書き換え、さらにspotlight databaseも書き換えてくれます。つまり、コピー先でも
(a),(b),(c)の3つがちゃんと同期されます。
Terminal標準のcpやmvでも、3つの情報は同期されます(ref5).ところが、
ソフトやコマンドによっては、同期が崩れる場合もあります。つまり、ファイル本体の
移動/コピーによってEAは移動するけれど、コピー先の.DS_Storeが変更されず、その結果
(b)も変更されない等々。
この辺り、様々なケースが考えられますが、とにかく、結論。
「SCに格納された情報は、ユーザーが思いもしない理由で、簡単に消え去ってしまう」
3.OpenMetaプロジェクト
この問題は、諸タグ付けソフトのユーザーフォーラムで、繰り返し議論されてきました。
「SCは不安定であてにならない。そんなものに頼った情報管理/タグ付けなんて、危なくて
やってられない」。
sjkというユーザーなんて、Ironic software(Leap, Yepの開発元)やDevonthinkのフォーラム、
Apple本家のフォーラム、あるいは、TUAWやMac系の諸ブログのコメント欄まで、縦横無尽に
同じ名前で現れては、この問題を指摘し続けてきました。
ここで登場したのが、Ironic softwareです。昨年の12月、彼らはDeepという画像ファイル
タグ付けソフトを公開しました。そして、ユーザーフォーラムの中で、「Deepは、OpenMetaという
仕組みでタグをファイルに格納する。OpenMetaはオープンソースで無料公開し、誰もが自由に
使えるようにする」と宣言したのです。
そして、その宣言通り、今日ついに、OpenMetaに使用されるコマンドツールや
一連のタグ付けソフトが公開されました(ref2, ref3)。
OpenMetaは、ファイルの 拡張属性(EA)として、ファイル本体にタグを書き込みます。
具体的には、com.apple.metadata:kOMUserTagsという拡張属性が作成され、
そこに情報が書き込まれます。
(3.OpenMetaプロジェクト、続き)
特徴1..DS_Storeには情報を書き込まない。故に、(b),(c)の同期だけ気にすれば良い。
特徴2.(c)に書き込まれた情報は、即座に、(b)に反映される
SCを使っていた時と違い、「(a)だけ更新されたが、(b)が更新されてない」なんて事は
生じません。一度に、100個以上のファイルにタグをつけてみましたが、1秒ほどで、
(b)と (c)の両方が見事に変更されました。SCでは、いちどにこれだけの数のファイルに、
タグ付けすることはできません。いろいろ試したのですが、とにかく「fast & robust」なシステム。
SCなんて、全く、比べ物になりません。
特徴3.spotlightで、検索可能。
SCの情報は「comment:タグ」という書式で検索できます。同様にOpenMetaで書き込まれた情報は
「tag:タグ」という書式で検索できます(注1)。当然、スマートフォルダも作れるし、(原理的には)
Spotinside, Houdaspot, Tagfolders等々、spotlightを利用する全てのソフトから検索できます。
注1:ただし(ref4)が発売するTags.appを一度起動する必要あり。これが無くても、クエリー無しで検索可。
特徴4.ターミナルで使用可能なコマンド(omtool)がフリーで提供される(ref3)
これを使えば、誰でもApplescriptやシェルスクリプトを使って、タグ付けスクリプトを
作れます。現在、QuicksilverのFile tagging moduelはOpenMetaに対応していませんが、
誰かがモジュールを作れば、QSからのタグ付け、閲覧も可能となるでしょう。
自分でAppelscriptとスマートフォルダを作ってQSに登録しても良いかもしれません。
280 :
書きなぐり失礼:2009/01/20(火) 08:23:07 ID:FsR+C6hB0
(3.OpenMetaプロジェクト、続き)
特徴5.複数のベンダーが、OpenMetaに依拠したタグ付けソフトを提供
Ironic softwareは、コマンドラインツールと、フリーのタグ付けソフトを提供済(ref3)
今後、有料ソフトのLeap, Yepも、SCからOpenMetaへ移行予定。
Gravity Applicationsは、30ドルでTags.appを提供。これはかなり本格的なタグ付け支援ソフト。
特徴6.複数のMac間でコピー/移動してもタグが消えない。
今後の検証しだいですが、EAさえ保持されていれば、タグは消えないし、コピー先の
spotlight databaseも、移動/コピーが終了すれば、即座に更新されます。.DS_Storeの
更新も考慮しなければならないSCと比べ、格段に安全です。
・個人的まとめ
SCと違い「情報を見る」からタグを書き換えることはできません。Terminalか専用アプリが
必要となりますが、その価値があると思えるくらい、堅牢で安定したシステムだと感じています。
SCを使って、大量のファイルを管理していた人なら、OpenMetaはとても便利で魅力的な
プラットフォームだと思います。
以上、長文投稿、失礼しました。