プロパティリスト
| 拡張子 | |
|---|---|
| 開発者 | アップル および GNUstep、 かつては NeXT |
| 種別 | データシリアライゼーション |
プロパティリスト(英: property list)は、Mac OS X Cocoa・NeXTSTEP・GNUstep などで利用されるオブジェクトシリアライゼーションのためのファイルである。また、 .plist という拡張子をもつので、plistファイルと呼ばれることが多い。
プロパティリストは NSPropertyListSerialization クラスによってパースされる。プロパティリストが含むことができるのは、Foundation または Core Foundation のオブジェクトのみである。プロパティリスト全体は配列(NSArray)または連想配列(NSDictionary)でなければならない。
実用では、ユーザーの設定を保存するのによく使われる。これは Windows におけるレジストリと似た使い方である。また、プロパティリストはバンドルの情報を格納するためにも用いられ、以前の Mac OS ではリソースフォークが近い用途に用いられていた。
目次 |
表現形式[編集]
プロパティリストが表現するデータは抽象的なもので、永続化のためのファイルフォーマットは固定されてはいない。元々、NeXTSTEP ではひとつのフォーマットが使われていたが、その後の GNUstep や Mac OS X のフレームワークで異なるフォーマットが誕生した。
NeXTSTEP[編集]
NeXTSTEP おいては、プロパティリストは可読なフォーマットとして設計され、人間が手で編集し、プログラミング言語風の構文をもつASCII テキストに直列化された。
文字列(NSString)は、
"This is a plist string"
バイナリデータ(NSData)はぬ16進表記で、
< 54637374 696D67 >
配列は、
( "one", "two", "three" )
連想配列は、
{
"key" = "value";
…
}
と表記する。
このオリジナルのプロパティリストには制限があり、NSValue(数値、真偽値など)のオブジェクトは表現できなかった。
GNUstep[編集]
GNUstep は NeXTSTEP のフォーマットを採用し、いくつかの拡張を施した。
NSValueをサポートした。<*INNN>(NNNが数値)のように表記する。NSDate(時刻)をサポートした。<*DYYYY-MM-DD HH:MM:SS timezone>のように表記する。
GNUstep はまた、後述する Mac OS X のフォーマットも読み書きすることができる。(defaults)
- GNUstep に付属するツールにplget[1]などがある。
$ cat com.example.app.plist | plget key
$ cat com.example.app.plist | plget key | plget key
のようにすることでplist内の階層化されたキーに対応する値が取得できる。
Mac OS X[編集]
Mac OS X は NeXTSTEP のフォーマットも扱うことができるが、アップルは別にふたつの新しいフォーマットを開発した。
Mac OS X 10.0 では、NeXTSTEP のフォーマットは非推奨とされ、アップルが定義したDTD [2]を持つ、新しいXMLフォーマットが登場した。
しかし、XMLは空間効率に問題があるため、10.2で新しいバイナリフォーマットが登場した。これは10.4以降のデフォルトのフォーマットとなった。
10.2以降で利用できるユーティリティ「plutil」を使うと、プロパティリストの文法チェックや、フォーマット間の変換が可能となる。
MacOS X のXMLフォーマットで使われるタグと、それに対応する Foundation のクラスを示す。ルート要素は <plist> である。また、GNUstep のフォーマットとは多少違いがある。
| クラス名 | XML要素 |
|---|---|
NSString |
string |
NSNumber |
real、integer、true、false |
NSDate |
date |
NSData |
data |
NSArray |
array |
NSDictionary |
dict |
dict要素の中身は
<dict>
<key>key</key>
<string>value</string>
</dict>
のように記述する。
脚注[編集]
- ^ http://manpages.ubuntu.com/manpages/intrepid/man1/pldes.1.html
- ^ http://www.apple.com/DTDs/PropertyList-1.0.dtd
外部リンク[編集]
- Manual Page For plist(5)
- Property List Programming Guide for Cocoa
NSPropertyListSerializationclass documentation- OpenStep plist API
|
|||||||||||||||||