AppleHelp.pas 12 KB

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