- Property list
Infobox file format
name = Property List
extension = .plist
mime =
owner =Apple Computer andGNUstep , formerlyNeXT
creatorcode =
genre =Serialization of dictionary objects.
containerfor =
containedby =
extendedfrom =
extendedto = In theMac OS X Cocoa,NeXTSTEP , andGNUstep programmingframework s, property list files are files that store serialized objects. Property list files use thefilename extension .plist, and thus are often referred to as plist files. Property lists are parsed with the NSPropertyListSerialization class. A property list file can only containCore Foundation orFoundation Kit objects, as the library does not know how to serialize any other type of object.In practical terms they are often used to store a user's settings. They are also used to store information about bundles and applications, a task served by the
resource fork in the old Mac OS.Representations
Since the data represented by property lists is somewhat abstract, the underlying
file format can be implemented many ways. Namely,NeXTSTEP used one format to represent a property list, and the subsequentGNUstep andMac OS X frameworks introduced differing formats.NeXTSTEP
Under
NeXTSTEP , property lists were designed to behuman readable and edited by hand, serialized to ASCII in a syntax somewhat like aprogramming language .Strings were represented as: "This is a plist string"Binary data was represented as: < "
[hexadecimal codes in ASCII] " >Arrays were represented as: ( "1", "2", "3" )And dictionaries were represented as: { "key" = "value"; ... }One limitation of the original NeXT property list format is that it could not represent an NSValue (number, boolean, etc) object.
GNUstep
GNUstep adopts the NeXTSTEP format, with a few additions. First, it now supports NSValue objects (which are represented as plain ASCII), and second, it supports NSDate objects (which are serialized as <*DYYYY-MM-DD HH:MM:SS timezone>)
GNUstep can also read and write property lists in the formats used by
Mac OS X .Mac OS X
While the Mac OS can also read the NeXTSTEP format, Apple sets it aside in favor of two new formats of its own.
In Mac OS 10.0, the NeXTSTEP format was
deprecated , and a newXML format was introduced, with a public DTD defined by Apple. The XML format supports non-ASCII characters and storing NSValue objects (which, unlike GNUstep's ASCII property list format, Apple's ASCII property list format does not support).Since XML files, however, are not the most space-efficient means of storage, version 10.2 introduced a new format where property list files are stored as binary files. Starting with version 10.4, this is the default format for preference files.
The
plutil utility (introduced in version 10.2) can be used to check the syntax of property lists, or convert a property list file from one format to another.XML property lists are hand-editable in any text editor, but Apple provides a "
Property List Editor " application as part of their Developer Tools installation that provides a hierarchical viewer/editor which can also handle binary formatted plists.For the XML format, the tags, related Foundation classes and CoreFoundation types, and data storage formats are as follows:
The defaults utility can be used to manipulate plist files used for storage of preferences (also known before OS X as "defaults", hence the name) on the command line via their preferences domain, whereas Property List Editor (part of the SDK) can be used to edit any plist file (including those used for preferences). As of OS X 10.4, Apple provides an AppleScript interface for reading property list files through the System Events application. As of OS X 10.5, Apple now provides an AppleScript interface for [http://www.apple.com/applescript/features/propertylists.html editing, creating and writing property list files] as well.
External links
* [http://developer.apple.com/documentation/Darwin/Reference/ManPages/man5/plist.5.html The plist manual page] at developer.apple.com
* [http://developer.apple.com/documentation/Cocoa/Conceptual/PropertyLists/index.html#//apple_ref/doc/uid/10000048i Property List Programming Guide for Cocoa]
* [http://developer.apple.com/documentation/CoreFoundation/Conceptual/CFPropertyLists/CFPropertyLists.html Property List Programming Topics for Core Foundation]
* [http://www.gnustep.org/resources/documentation/Developer/Base/Reference/NSPropertyList.html NSPropertyListSerialization class documentation] from theGNUstep project
* [http://docs.sun.com/app/docs/doc/802-2112/6i63mn65o?a=view OpenStep plist API] from Sun Microsystems
* [http://jakarta.apache.org/commons/configuration Jakarta Commons Configuration] Configuration API in Java supporting the Property List formatThird party editing tools
* [http://rixstep.com/acp/plistedit PlistEdit] , a general property list editor
* [http://www.fatcatsoftware.com/plisteditpro PlistEdit Pro] , a general property list editor
* [http://www.bresink.com/osx/PrefEdit.html PrefEdit] , specializing in editing preference plists
* [http://www.latenightsw.com/freeware/PListTools/index.html Property List Tools] , an Applescript scripting addition for manipulating plists
Wikimedia Foundation. 2010.