プロパティリスト

出典: フリー百科事典『ウィキペディア(Wikipedia)』
移動: 案内, 検索
プロパティリスト
拡張子 .plist
開発者 アップルおよびGNUstep
かつてはNeXT
種別 データシリアライゼーション
テンプレートを表示

プロパティリスト(property list)は、Mac OS X CocoaNeXTSTEPGNUstepなどで利用されるオブジェクトシリアライゼーションのためのファイルである。また、 .plist という拡張子をもつので、plistファイルと呼ばれることが多い。

プロパティリストは NSPropertyListSerialization クラスによってパースされる。プロパティリストが含むことができるのは、FoundationまたはCore Foundationのオブジェクトのみである。プロパティリスト全体は配列(NSArray)または連想配列(NSDictionary)でなければならない。

実用では、ユーザーの設定を保存するのによく使われる。これはWindowsにおけるレジストリと似た使い方である。また、プロパティリストはバンドルの情報を格納するためにも用いられ、以前のMac OSではリソースフォークが近い用途に用いられていた。

目次

[編集] 表現形式

プロパティリストが表現するデータは抽象的なもので、永続化のためのファイルフォーマットは固定されてはいない。元々、NeXTSTEPでは1つのフォーマットが使われていたが、その後のGNUstepやMac OS Xのフレームワークで異なるフォーマットが誕生した。

[編集] NeXTSTEP

NeXTSTEPにおいては、プロパティリストはヒューマンリーダブルなフォーマットとして設計され、人間が手で編集し、プログラミング言語風の構文をもつASCIIテキストにシリアライズされた。

文字列(NSString)は、

"This is a plist string"

バイナリデータ(NSData)は十六進表記で、

< 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などがある。
$ cat com.example.app.plist | plget key
$ cat com.example.app.plist | plget key | plget key

のようにすることでplist内の階層化されたキーに対応する値が取得できる。

[編集] Mac OS X

Mac OS XはNeXTSTEPのフォーマットも扱うことができるが、アップルは別に2つの新しいフォーマットを開発した。

Mac OS X 10.0では、NeXTSTEPのフォーマットは非推奨とされ、アップルが定義したDTD [1] を持つ、新しいXMLフォーマットが登場した。

しかし、XMLは空間効率に問題があるため、10.2で新しいバイナリフォーマットが登場した。これは10.4以降のデフォルトのフォーマットとなった。

10.2以降で利用できるplutilユーティリティを使うと、プロパティリストの文法チェックや、フォーマット間の変換が可能となる。

MacOS XのXMLフォーマットで使われるタグと、それに対応するFoundationのクラスを示す。ルート要素は<plist>である。また、GNUstepのフォーマットとは多少違いがある。

クラス名 XMLタグ
NSString <string>
NSNumber <real>, <integer>,
<true />, or <false />
NSDate <date>
NSData <data>
NSArray <array>
NSDictionary <dict>

<dict>の中身は

 <dict>
   <key>key</key>
   <string>value</string>
 </dict>

のように記述する。

[編集] 外部リンク

個人用ツール
名前空間

変種
操作
案内
ヘルプ
ツールボックス
他の言語