AppleHelp.pas 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401
  1. {
  2. File: Help/AppleHelp.h
  3. Contains: Apple Help
  4. Version: Help-36~232
  5. Copyright: © 2000-2008 by Apple Computer, Inc., all rights reserved.
  6. Bugs?: For bug reports, consult the following page on
  7. the World Wide Web:
  8. http://bugs.freepascal.org
  9. }
  10. { Translation Updated: Jonas Maebe, <[email protected]>, October 2009 }
  11. {
  12. Modified for use with Free Pascal
  13. Version 308
  14. Please report any bugs to <[email protected]>
  15. }
  16. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  17. {$mode macpas}
  18. {$packenum 1}
  19. {$macro on}
  20. {$inline on}
  21. {$calling mwpascal}
  22. unit AppleHelp;
  23. interface
  24. {$setc UNIVERSAL_INTERFACES_VERSION := $0400}
  25. {$setc GAP_INTERFACES_VERSION := $0308}
  26. {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
  27. {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
  28. {$endc}
  29. {$ifc defined CPUPOWERPC and defined CPUI386}
  30. {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
  31. {$endc}
  32. {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
  33. {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
  34. {$endc}
  35. {$ifc not defined __ppc__ and defined CPUPOWERPC32}
  36. {$setc __ppc__ := 1}
  37. {$elsec}
  38. {$setc __ppc__ := 0}
  39. {$endc}
  40. {$ifc not defined __ppc64__ and defined CPUPOWERPC64}
  41. {$setc __ppc64__ := 1}
  42. {$elsec}
  43. {$setc __ppc64__ := 0}
  44. {$endc}
  45. {$ifc not defined __i386__ and defined CPUI386}
  46. {$setc __i386__ := 1}
  47. {$elsec}
  48. {$setc __i386__ := 0}
  49. {$endc}
  50. {$ifc not defined __x86_64__ and defined CPUX86_64}
  51. {$setc __x86_64__ := 1}
  52. {$elsec}
  53. {$setc __x86_64__ := 0}
  54. {$endc}
  55. {$ifc not defined __arm__ and defined CPUARM}
  56. {$setc __arm__ := 1}
  57. {$elsec}
  58. {$setc __arm__ := 0}
  59. {$endc}
  60. {$ifc not defined __arm64__ and defined CPUAARCH64}
  61. {$setc __arm64__ := 1}
  62. {$elsec}
  63. {$setc __arm64__ := 0}
  64. {$endc}
  65. {$ifc defined cpu64}
  66. {$setc __LP64__ := 1}
  67. {$elsec}
  68. {$setc __LP64__ := 0}
  69. {$endc}
  70. {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
  71. {$error Conflicting definitions for __ppc__ and __i386__}
  72. {$endc}
  73. {$ifc defined __ppc__ and __ppc__}
  74. {$setc TARGET_CPU_PPC := TRUE}
  75. {$setc TARGET_CPU_PPC64 := FALSE}
  76. {$setc TARGET_CPU_X86 := FALSE}
  77. {$setc TARGET_CPU_X86_64 := FALSE}
  78. {$setc TARGET_CPU_ARM := FALSE}
  79. {$setc TARGET_CPU_ARM64 := FALSE}
  80. {$setc TARGET_OS_MAC := TRUE}
  81. {$setc TARGET_OS_IPHONE := FALSE}
  82. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  83. {$setc TARGET_OS_EMBEDDED := FALSE}
  84. {$elifc defined __ppc64__ and __ppc64__}
  85. {$setc TARGET_CPU_PPC := FALSE}
  86. {$setc TARGET_CPU_PPC64 := TRUE}
  87. {$setc TARGET_CPU_X86 := FALSE}
  88. {$setc TARGET_CPU_X86_64 := FALSE}
  89. {$setc TARGET_CPU_ARM := FALSE}
  90. {$setc TARGET_CPU_ARM64 := FALSE}
  91. {$setc TARGET_OS_MAC := TRUE}
  92. {$setc TARGET_OS_IPHONE := FALSE}
  93. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  94. {$setc TARGET_OS_EMBEDDED := FALSE}
  95. {$elifc defined __i386__ and __i386__}
  96. {$setc TARGET_CPU_PPC := FALSE}
  97. {$setc TARGET_CPU_PPC64 := FALSE}
  98. {$setc TARGET_CPU_X86 := TRUE}
  99. {$setc TARGET_CPU_X86_64 := FALSE}
  100. {$setc TARGET_CPU_ARM := FALSE}
  101. {$setc TARGET_CPU_ARM64 := FALSE}
  102. {$ifc defined(iphonesim)}
  103. {$setc TARGET_OS_MAC := FALSE}
  104. {$setc TARGET_OS_IPHONE := TRUE}
  105. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  106. {$elsec}
  107. {$setc TARGET_OS_MAC := TRUE}
  108. {$setc TARGET_OS_IPHONE := FALSE}
  109. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  110. {$endc}
  111. {$setc TARGET_OS_EMBEDDED := FALSE}
  112. {$elifc defined __x86_64__ and __x86_64__}
  113. {$setc TARGET_CPU_PPC := FALSE}
  114. {$setc TARGET_CPU_PPC64 := FALSE}
  115. {$setc TARGET_CPU_X86 := FALSE}
  116. {$setc TARGET_CPU_X86_64 := TRUE}
  117. {$setc TARGET_CPU_ARM := FALSE}
  118. {$setc TARGET_CPU_ARM64 := FALSE}
  119. {$ifc defined(iphonesim)}
  120. {$setc TARGET_OS_MAC := FALSE}
  121. {$setc TARGET_OS_IPHONE := TRUE}
  122. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  123. {$elsec}
  124. {$setc TARGET_OS_MAC := TRUE}
  125. {$setc TARGET_OS_IPHONE := FALSE}
  126. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  127. {$endc}
  128. {$setc TARGET_OS_EMBEDDED := FALSE}
  129. {$elifc defined __arm__ and __arm__}
  130. {$setc TARGET_CPU_PPC := FALSE}
  131. {$setc TARGET_CPU_PPC64 := FALSE}
  132. {$setc TARGET_CPU_X86 := FALSE}
  133. {$setc TARGET_CPU_X86_64 := FALSE}
  134. {$setc TARGET_CPU_ARM := TRUE}
  135. {$setc TARGET_CPU_ARM64 := FALSE}
  136. { will require compiler define when/if other Apple devices with ARM cpus ship }
  137. {$setc TARGET_OS_MAC := FALSE}
  138. {$setc TARGET_OS_IPHONE := TRUE}
  139. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  140. {$setc TARGET_OS_EMBEDDED := TRUE}
  141. {$elifc defined __arm64__ and __arm64__}
  142. {$setc TARGET_CPU_PPC := FALSE}
  143. {$setc TARGET_CPU_PPC64 := FALSE}
  144. {$setc TARGET_CPU_X86 := FALSE}
  145. {$setc TARGET_CPU_X86_64 := FALSE}
  146. {$setc TARGET_CPU_ARM := FALSE}
  147. {$setc TARGET_CPU_ARM64 := TRUE}
  148. { will require compiler define when/if other Apple devices with ARM cpus ship }
  149. {$setc TARGET_OS_MAC := FALSE}
  150. {$setc TARGET_OS_IPHONE := TRUE}
  151. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  152. {$setc TARGET_OS_EMBEDDED := TRUE}
  153. {$elsec}
  154. {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ nor __arm64__ is defined.}
  155. {$endc}
  156. {$ifc defined __LP64__ and __LP64__ }
  157. {$setc TARGET_CPU_64 := TRUE}
  158. {$elsec}
  159. {$setc TARGET_CPU_64 := FALSE}
  160. {$endc}
  161. {$ifc defined FPC_BIG_ENDIAN}
  162. {$setc TARGET_RT_BIG_ENDIAN := TRUE}
  163. {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
  164. {$elifc defined FPC_LITTLE_ENDIAN}
  165. {$setc TARGET_RT_BIG_ENDIAN := FALSE}
  166. {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
  167. {$elsec}
  168. {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
  169. {$endc}
  170. {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
  171. {$setc CALL_NOT_IN_CARBON := FALSE}
  172. {$setc OLDROUTINENAMES := FALSE}
  173. {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
  174. {$setc OPAQUE_UPP_TYPES := TRUE}
  175. {$setc OTCARBONAPPLICATION := TRUE}
  176. {$setc OTKERNEL := FALSE}
  177. {$setc PM_USE_SESSION_APIS := TRUE}
  178. {$setc TARGET_API_MAC_CARBON := TRUE}
  179. {$setc TARGET_API_MAC_OS8 := FALSE}
  180. {$setc TARGET_API_MAC_OSX := TRUE}
  181. {$setc TARGET_CARBON := TRUE}
  182. {$setc TARGET_CPU_68K := FALSE}
  183. {$setc TARGET_CPU_MIPS := FALSE}
  184. {$setc TARGET_CPU_SPARC := FALSE}
  185. {$setc TARGET_OS_UNIX := FALSE}
  186. {$setc TARGET_OS_WIN32 := FALSE}
  187. {$setc TARGET_RT_MAC_68881 := FALSE}
  188. {$setc TARGET_RT_MAC_CFM := FALSE}
  189. {$setc TARGET_RT_MAC_MACHO := TRUE}
  190. {$setc TYPED_FUNCTION_POINTERS := TRUE}
  191. {$setc TYPE_BOOL := FALSE}
  192. {$setc TYPE_EXTENDED := FALSE}
  193. {$setc TYPE_LONGLONG := TRUE}
  194. uses MacTypes,CFBase,Files,CFString;
  195. {$endc} {not MACOSALLINCLUDE}
  196. {$ifc TARGET_OS_MAC}
  197. {$ALIGN POWER}
  198. { AppleHelp Error Codes }
  199. const
  200. kAHInternalErr = -10790;
  201. kAHInternetConfigPrefErr = -10791;
  202. type
  203. AHTOCType = SInt16;
  204. const
  205. kAHTOCTypeUser = 0;
  206. kAHTOCTypeDeveloper = 1;
  207. {
  208. * AHSearch()
  209. *
  210. * Discussion:
  211. * Delivers a request to perform the specified search to the Help
  212. * Viewer application.
  213. *
  214. * Parameters:
  215. *
  216. * bookname:
  217. * Optionally, the AppleTitle of the Help book to be searched. If
  218. * NULL, all installed Help books are searched.
  219. *
  220. * query:
  221. * The query to be made. This string can, if desired, have boolean
  222. * operators or be a natural language phrase.
  223. *
  224. * Result:
  225. * An operating system result code that indicates whether the
  226. * request was successfully sent to the Help Viewer application.
  227. * Possible values: noErr, paramErr, kAHInternalErr.
  228. *
  229. * Availability:
  230. * Mac OS X: in version 10.0 and later in Carbon.framework
  231. * CarbonLib: in CarbonLib 1.1 and later
  232. * Non-Carbon CFM: not available
  233. }
  234. function AHSearch( bookname: CFStringRef; query: CFStringRef ): OSStatus; external name '_AHSearch';
  235. (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
  236. {
  237. * AHGotoMainTOC() *** DEPRECATED ***
  238. *
  239. * Discussion:
  240. * Delivers a request to load the main table of contents of
  241. * installed help books to the Help Viewer application. This method
  242. * has been deprecated in Mac OS X 10.4. Instead, please use
  243. * AHGotoPage to jump directly to different books or anchors.
  244. *
  245. * Parameters:
  246. *
  247. * toctype:
  248. * The type of table of contents to be loaded: user or developer.
  249. *
  250. * Result:
  251. * An operating system result code that indicates whether the
  252. * request was successfully sent to the Help Viewer application.
  253. * Possible values: noErr, paramErr, kAHInternalErr.
  254. *
  255. * Availability:
  256. * Mac OS X: in version 10.0 and later in Carbon.framework but deprecated in 10.4
  257. * CarbonLib: in CarbonLib 1.1 and later
  258. * Non-Carbon CFM: not available
  259. }
  260. function AHGotoMainTOC( toctype: AHTOCType ): OSStatus; external name '_AHGotoMainTOC';
  261. (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *)
  262. {
  263. * AHGotoPage()
  264. *
  265. * Discussion:
  266. * Delivers a request to load a specific text/html file to the Help
  267. * Viewer application.
  268. *
  269. * Parameters:
  270. *
  271. * bookname:
  272. * Optionally, the AppleTitle of an installed Help book. If NULL,
  273. * the path parameter must be a full file: URL to the file to be
  274. * opened.
  275. *
  276. * path:
  277. * Optionally, one of two types of paths: 1) a URL-style path to a
  278. * file that is relative to the main folder of the book supplied
  279. * in the bookname parameter, or 2) if bookname is NULL, a full
  280. * file: URL to the file to be opened. If this parameter is NULL,
  281. * then bookname must not be NULL, and is used to open the Help
  282. * Viewer to the main page of Help content for the specified book.
  283. *
  284. * anchor:
  285. * Optionally, the name of anchor tag to scroll to in the newly
  286. * opened file. Can be NULL.
  287. *
  288. * Result:
  289. * An operating system result code that indicates whether the
  290. * request was successfully sent to the Help Viewer application.
  291. * Possible values: noErr, paramErr, kAHInternalErr.
  292. *
  293. * Availability:
  294. * Mac OS X: in version 10.0 and later in Carbon.framework
  295. * CarbonLib: in CarbonLib 1.1 and later
  296. * Non-Carbon CFM: not available
  297. }
  298. function AHGotoPage( bookname: CFStringRef; path: CFStringRef; anchor: CFStringRef ): OSStatus; external name '_AHGotoPage';
  299. (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
  300. {
  301. * AHLookupAnchor()
  302. *
  303. * Discussion:
  304. * Delivers a request to perform an anchor lookup to the Help Viewer
  305. * application. Note: anchor lookups will fail unless you have
  306. * indexed your help content with anchor indexing turned on in the
  307. * indexing tool's preferences panel.
  308. *
  309. * Parameters:
  310. *
  311. * bookname:
  312. * Optionally, the AppleTitle of the Help book to searched. If
  313. * NULL, the anchor lookup is performed using all installed Help
  314. * books.
  315. *
  316. * anchor:
  317. * The name of the anchor tag to look up.
  318. *
  319. * Result:
  320. * An operating system result code that indicates whether the
  321. * request was successfully sent to the Help Viewer application.
  322. * Possible values: noErr, paramErr, kAHInternalErr.
  323. *
  324. * Availability:
  325. * Mac OS X: in version 10.0 and later in Carbon.framework
  326. * CarbonLib: in CarbonLib 1.1 and later
  327. * Non-Carbon CFM: not available
  328. }
  329. function AHLookupAnchor( bookname: CFStringRef; anchor: CFStringRef ): OSStatus; external name '_AHLookupAnchor';
  330. (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
  331. {
  332. * AHRegisterHelpBook()
  333. *
  334. * Discussion:
  335. * Registers a book of Help content such that the book will appear
  336. * in the current user's main table of contents (Help Center) in the
  337. * Help Viewer application. To be used when help books reside
  338. * outside of the known help folders (i.e. help books that are kept
  339. * inside of application bundles).
  340. *
  341. * Parameters:
  342. *
  343. * appBundleRef:
  344. * An FSRef pointer to the bundle within which one or more Help
  345. * books is stored. This is likely an FSRef to your application's
  346. * main bundle.
  347. *
  348. * Result:
  349. * An operating system result code that indicates whether all help
  350. * books contained within the specified bundle were registered.
  351. * Possible values: noErr, paramErr, kAHInternalErr, dirNFErr.
  352. *
  353. * Availability:
  354. * Mac OS X: in version 10.0 and later in Carbon.framework
  355. * CarbonLib: in CarbonLib 1.1 and later
  356. * Non-Carbon CFM: not available
  357. }
  358. function AHRegisterHelpBook( const (*var*) appBundleRef: FSRef ): OSStatus; external name '_AHRegisterHelpBook';
  359. (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
  360. function AHRegisterHelpBookWithURL( {const} applicationURL: CFURLRef ): OSStatus; external name '_AHRegisterHelpBookWithURL';
  361. (* AVAILABLE_MAC_OS_X_VERSION_10_6_AND_LATER *)
  362. {$endc} {TARGET_OS_MAC}
  363. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  364. end.
  365. {$endc} {not MACOSALLINCLUDE}