SCPreferencesPath.pas 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. {
  2. * Copyright (c) 2000-2003 Apple Computer, Inc. All rights reserved.
  3. *
  4. * @APPLE_LICENSE_HEADER_START@
  5. *
  6. * This file contains Original Code and/or Modifications of Original Code
  7. * as defined in and that are subject to the Apple Public Source License
  8. * Version 2.0 (the 'License'). You may not use this file except in
  9. * compliance with the License. Please obtain a copy of the License at
  10. * http://www.opensource.apple.com/apsl/ and read it before using this
  11. * file.
  12. *
  13. * The Original Code and all software distributed under the License are
  14. * distributed on an 'AS IS' basis, WITHOUT WARRANTY of ANY KIND, EITHER
  15. * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
  16. * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES of MERCHANTABILITY,
  17. * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
  18. * Please see the License for the specific language governing rights and
  19. * limitations under the License.
  20. *
  21. * @APPLE_LICENSE_HEADER_END@
  22. }
  23. { Pascal Translation: Peter N Lewis, <[email protected]>, 2004 }
  24. {
  25. Modified for use with Free Pascal
  26. Version 200
  27. Please report any bugs to <[email protected]>
  28. }
  29. {$mode macpas}
  30. {$packenum 1}
  31. {$macro on}
  32. {$inline on}
  33. {$CALLING MWPASCAL}
  34. unit SCPreferencesPath;
  35. interface
  36. {$setc UNIVERSAL_INTERFACES_VERSION := $0342}
  37. {$setc GAP_INTERFACES_VERSION := $0200}
  38. {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
  39. {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
  40. {$endc}
  41. {$ifc defined CPUPOWERPC and defined CPUI386}
  42. {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
  43. {$endc}
  44. {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
  45. {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
  46. {$endc}
  47. {$ifc not defined __ppc__ and defined CPUPOWERPC}
  48. {$setc __ppc__ := 1}
  49. {$elsec}
  50. {$setc __ppc__ := 0}
  51. {$endc}
  52. {$ifc not defined __i386__ and defined CPUI386}
  53. {$setc __i386__ := 1}
  54. {$elsec}
  55. {$setc __i386__ := 0}
  56. {$endc}
  57. {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
  58. {$error Conflicting definitions for __ppc__ and __i386__}
  59. {$endc}
  60. {$ifc defined __ppc__ and __ppc__}
  61. {$setc TARGET_CPU_PPC := TRUE}
  62. {$setc TARGET_CPU_X86 := FALSE}
  63. {$elifc defined __i386__ and __i386__}
  64. {$setc TARGET_CPU_PPC := FALSE}
  65. {$setc TARGET_CPU_X86 := TRUE}
  66. {$elsec}
  67. {$error Neither __ppc__ nor __i386__ is defined.}
  68. {$endc}
  69. {$setc TARGET_CPU_PPC_64 := FALSE}
  70. {$ifc defined FPC_BIG_ENDIAN}
  71. {$setc TARGET_RT_BIG_ENDIAN := TRUE}
  72. {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
  73. {$elifc defined FPC_LITTLE_ENDIAN}
  74. {$setc TARGET_RT_BIG_ENDIAN := FALSE}
  75. {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
  76. {$elsec}
  77. {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
  78. {$endc}
  79. {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
  80. {$setc CALL_NOT_IN_CARBON := FALSE}
  81. {$setc OLDROUTINENAMES := FALSE}
  82. {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
  83. {$setc OPAQUE_UPP_TYPES := TRUE}
  84. {$setc OTCARBONAPPLICATION := TRUE}
  85. {$setc OTKERNEL := FALSE}
  86. {$setc PM_USE_SESSION_APIS := TRUE}
  87. {$setc TARGET_API_MAC_CARBON := TRUE}
  88. {$setc TARGET_API_MAC_OS8 := FALSE}
  89. {$setc TARGET_API_MAC_OSX := TRUE}
  90. {$setc TARGET_CARBON := TRUE}
  91. {$setc TARGET_CPU_68K := FALSE}
  92. {$setc TARGET_CPU_MIPS := FALSE}
  93. {$setc TARGET_CPU_SPARC := FALSE}
  94. {$setc TARGET_OS_MAC := TRUE}
  95. {$setc TARGET_OS_UNIX := FALSE}
  96. {$setc TARGET_OS_WIN32 := FALSE}
  97. {$setc TARGET_RT_MAC_68881 := FALSE}
  98. {$setc TARGET_RT_MAC_CFM := FALSE}
  99. {$setc TARGET_RT_MAC_MACHO := TRUE}
  100. {$setc TYPED_FUNCTION_POINTERS := TRUE}
  101. {$setc TYPE_BOOL := FALSE}
  102. {$setc TYPE_EXTENDED := FALSE}
  103. {$setc TYPE_LONGLONG := TRUE}
  104. uses MacTypes,CFBase,SCPreferences,CFDictionary;
  105. {$ALIGN MAC68K}
  106. {!
  107. @header SCPreferencesPath
  108. The SCPreferencesPathXXX() APIs allow an application to
  109. load and store XML configuration data in a controlled
  110. manner and provide the necessary notifications to other
  111. applications that need to be aware of configuration
  112. changes.
  113. The SCPreferencesPathXXX() APIs make certain assumptions
  114. about the layout of the preferences data. These APIs view
  115. the data as a collection of dictionaries of key/value pairs
  116. and an associated path name. The root path ("/") identifies
  117. the top-level dictionary. Additional path components
  118. specify the keys for sub-dictionaries.
  119. For example, the following dictionary can be accessed via
  120. two paths. The root ("/") path would return a dictionary
  121. with all keys and values. The path "/path1" would only
  122. return the dictionary with the "key3" and "key4" properties.
  123. <PRE>
  124. <BR> &lt;dict&gt;
  125. <BR> &lt;key&gt;key1&lt;/key&gt;
  126. <BR> &lt;string&gt;val1&lt;/string&gt;
  127. <BR> &lt;key&gt;key2&lt;/key&gt;
  128. <BR> &lt;string&gt;val2&lt;/string&gt;
  129. <BR> &lt;key&gt;path1&lt;/key&gt;
  130. <BR> &lt;dict&gt;
  131. <BR> &lt;key&gt;key3&lt;/key&gt;
  132. <BR> &lt;string&gt;val3&lt;/string&gt;
  133. <BR> &lt;key&gt;key4&lt;/key&gt;
  134. <BR> &lt;string&gt;val4&lt;/string&gt;
  135. <BR> &lt;/dict&gt;
  136. <BR> &lt;/dict&gt;
  137. </PRE>
  138. Each dictionary can also include the kSCResvLink key. The
  139. value associated with this key is interpreted as a "link" to
  140. another path. If this key is present, a call to the
  141. SCPreferencesPathGetValue() API will return the dictionary
  142. specified by the link.
  143. }
  144. {!
  145. @function SCPreferencesPathCreateUniqueChild
  146. @discussion Creates a new path component within the dictionary
  147. hierarchy.
  148. @param session The SCPreferencesRef handle that should be used to
  149. communicate with the APIs.
  150. @param prefix A string that represents the parent path.
  151. @result A string representing the new (unique) child path; NULL
  152. if the specified path does not exist.
  153. }
  154. function SCPreferencesPathCreateUniqueChild( session: SCPreferencesRef; prefix: CFStringRef ): CFStringRef; external name '_SCPreferencesPathCreateUniqueChild';
  155. {!
  156. @function SCPreferencesPathGetValue
  157. @discussion Returns the dictionary associated with the specified
  158. path.
  159. @param session The SCPreferencesRef handle that should be used to
  160. communicate with the APIs.
  161. @param path A string that represents the path to be returned.
  162. @result The dictionary associated with the specified path; NULL
  163. if the path does not exist.
  164. }
  165. function SCPreferencesPathGetValue( session: SCPreferencesRef; path: CFStringRef ): CFDictionaryRef; external name '_SCPreferencesPathGetValue';
  166. {!
  167. @function SCPreferencesPathGetLink
  168. @discussion Returns the link (if one exists) associated with the
  169. specified path.
  170. @param session The SCPreferencesRef handle that should be used to
  171. communicate with the APIs.
  172. @param path A string that represents the path to be returned.
  173. @result The dictionary associated with the specified path; NULL
  174. if the path is not a link or does not exist.
  175. }
  176. function SCPreferencesPathGetLink( session: SCPreferencesRef; path: CFStringRef ): CFStringRef; external name '_SCPreferencesPathGetLink';
  177. {!
  178. @function SCPreferencesPathSetValue
  179. @discussion Associates a dictionary with the specified path.
  180. @param session The SCPreferencesRef handle that should be used to
  181. communicate with the APIs.
  182. @param path A string that represents the path to be updated.
  183. @param value A dictionary that represents the data to be
  184. stored at the specified path.
  185. @result A boolean indicating the success (or failure) of the call.
  186. }
  187. function SCPreferencesPathSetValue( session: SCPreferencesRef; path: CFStringRef; value: CFDictionaryRef ): Boolean; external name '_SCPreferencesPathSetValue';
  188. {!
  189. @function SCPreferencesPathSetLink
  190. @discussion Associates a link to a second dictionary at the
  191. specified path.
  192. @param session The SCPreferencesRef handle that should be used to
  193. communicate with the APIs.
  194. @param path A string that represents the path to be updated.
  195. @param link A string that represents the link to be stored
  196. at the specified path.
  197. @result A boolean indicating the success (or failure) of the call.
  198. }
  199. function SCPreferencesPathSetLink( session: SCPreferencesRef; path: CFStringRef; link: CFStringRef ): Boolean; external name '_SCPreferencesPathSetLink';
  200. {!
  201. @function SCPreferencesPathRemoveValue
  202. @discussion Removes the data associated with the specified path.
  203. @param session The SCPreferencesRef handle that should be used to
  204. communicate with the APIs.
  205. @param path A string that represents the path to be returned.
  206. @result A boolean indicating the success (or failure) of the call.
  207. }
  208. function SCPreferencesPathRemoveValue( session: SCPreferencesRef; path: CFStringRef ): Boolean; external name '_SCPreferencesPathRemoveValue';
  209. end.