CodeFragments.pas 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779
  1. {
  2. File: CarbonCore/CodeFragments.h
  3. Contains: Public Code Fragment Manager Interfaces.
  4. The contents of this header file are deprecated.
  5. Copyright: © 1992-2011 by Apple Inc. All rights reserved.
  6. }
  7. {
  8. Modified for use with Free Pascal
  9. Version 308
  10. Please report any bugs to <[email protected]>
  11. }
  12. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  13. {$mode macpas}
  14. {$modeswitch cblocks}
  15. {$packenum 1}
  16. {$macro on}
  17. {$inline on}
  18. {$calling mwpascal}
  19. unit CodeFragments;
  20. interface
  21. {$setc UNIVERSAL_INTERFACES_VERSION := $0400}
  22. {$setc GAP_INTERFACES_VERSION := $0308}
  23. {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
  24. {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
  25. {$endc}
  26. {$ifc defined CPUPOWERPC and defined CPUI386}
  27. {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
  28. {$endc}
  29. {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
  30. {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
  31. {$endc}
  32. {$ifc not defined __ppc__ and defined CPUPOWERPC32}
  33. {$setc __ppc__ := 1}
  34. {$elsec}
  35. {$setc __ppc__ := 0}
  36. {$endc}
  37. {$ifc not defined __ppc64__ and defined CPUPOWERPC64}
  38. {$setc __ppc64__ := 1}
  39. {$elsec}
  40. {$setc __ppc64__ := 0}
  41. {$endc}
  42. {$ifc not defined __i386__ and defined CPUI386}
  43. {$setc __i386__ := 1}
  44. {$elsec}
  45. {$setc __i386__ := 0}
  46. {$endc}
  47. {$ifc not defined __x86_64__ and defined CPUX86_64}
  48. {$setc __x86_64__ := 1}
  49. {$elsec}
  50. {$setc __x86_64__ := 0}
  51. {$endc}
  52. {$ifc not defined __arm__ and defined CPUARM}
  53. {$setc __arm__ := 1}
  54. {$elsec}
  55. {$setc __arm__ := 0}
  56. {$endc}
  57. {$ifc not defined __arm64__ and defined CPUAARCH64}
  58. {$setc __arm64__ := 1}
  59. {$elsec}
  60. {$setc __arm64__ := 0}
  61. {$endc}
  62. {$ifc defined cpu64}
  63. {$setc __LP64__ := 1}
  64. {$elsec}
  65. {$setc __LP64__ := 0}
  66. {$endc}
  67. {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
  68. {$error Conflicting definitions for __ppc__ and __i386__}
  69. {$endc}
  70. {$ifc defined __ppc__ and __ppc__}
  71. {$setc TARGET_CPU_PPC := TRUE}
  72. {$setc TARGET_CPU_PPC64 := FALSE}
  73. {$setc TARGET_CPU_X86 := FALSE}
  74. {$setc TARGET_CPU_X86_64 := FALSE}
  75. {$setc TARGET_CPU_ARM := FALSE}
  76. {$setc TARGET_CPU_ARM64 := FALSE}
  77. {$setc TARGET_OS_MAC := TRUE}
  78. {$setc TARGET_OS_IPHONE := FALSE}
  79. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  80. {$setc TARGET_OS_EMBEDDED := FALSE}
  81. {$elifc defined __ppc64__ and __ppc64__}
  82. {$setc TARGET_CPU_PPC := FALSE}
  83. {$setc TARGET_CPU_PPC64 := TRUE}
  84. {$setc TARGET_CPU_X86 := FALSE}
  85. {$setc TARGET_CPU_X86_64 := FALSE}
  86. {$setc TARGET_CPU_ARM := FALSE}
  87. {$setc TARGET_CPU_ARM64 := FALSE}
  88. {$setc TARGET_OS_MAC := TRUE}
  89. {$setc TARGET_OS_IPHONE := FALSE}
  90. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  91. {$setc TARGET_OS_EMBEDDED := FALSE}
  92. {$elifc defined __i386__ and __i386__}
  93. {$setc TARGET_CPU_PPC := FALSE}
  94. {$setc TARGET_CPU_PPC64 := FALSE}
  95. {$setc TARGET_CPU_X86 := TRUE}
  96. {$setc TARGET_CPU_X86_64 := FALSE}
  97. {$setc TARGET_CPU_ARM := FALSE}
  98. {$setc TARGET_CPU_ARM64 := FALSE}
  99. {$ifc defined iphonesim}
  100. {$setc TARGET_OS_MAC := FALSE}
  101. {$setc TARGET_OS_IPHONE := TRUE}
  102. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  103. {$elsec}
  104. {$setc TARGET_OS_MAC := TRUE}
  105. {$setc TARGET_OS_IPHONE := FALSE}
  106. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  107. {$endc}
  108. {$setc TARGET_OS_EMBEDDED := FALSE}
  109. {$elifc defined __x86_64__ and __x86_64__}
  110. {$setc TARGET_CPU_PPC := FALSE}
  111. {$setc TARGET_CPU_PPC64 := FALSE}
  112. {$setc TARGET_CPU_X86 := FALSE}
  113. {$setc TARGET_CPU_X86_64 := TRUE}
  114. {$setc TARGET_CPU_ARM := FALSE}
  115. {$setc TARGET_CPU_ARM64 := FALSE}
  116. {$ifc defined iphonesim}
  117. {$setc TARGET_OS_MAC := FALSE}
  118. {$setc TARGET_OS_IPHONE := TRUE}
  119. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  120. {$elsec}
  121. {$setc TARGET_OS_MAC := TRUE}
  122. {$setc TARGET_OS_IPHONE := FALSE}
  123. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  124. {$endc}
  125. {$setc TARGET_OS_EMBEDDED := FALSE}
  126. {$elifc defined __arm__ and __arm__}
  127. {$setc TARGET_CPU_PPC := FALSE}
  128. {$setc TARGET_CPU_PPC64 := FALSE}
  129. {$setc TARGET_CPU_X86 := FALSE}
  130. {$setc TARGET_CPU_X86_64 := FALSE}
  131. {$setc TARGET_CPU_ARM := TRUE}
  132. {$setc TARGET_CPU_ARM64 := FALSE}
  133. {$setc TARGET_OS_MAC := FALSE}
  134. {$setc TARGET_OS_IPHONE := TRUE}
  135. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  136. {$setc TARGET_OS_EMBEDDED := TRUE}
  137. {$elifc defined __arm64__ and __arm64__}
  138. {$setc TARGET_CPU_PPC := FALSE}
  139. {$setc TARGET_CPU_PPC64 := FALSE}
  140. {$setc TARGET_CPU_X86 := FALSE}
  141. {$setc TARGET_CPU_X86_64 := FALSE}
  142. {$setc TARGET_CPU_ARM := FALSE}
  143. {$setc TARGET_CPU_ARM64 := TRUE}
  144. {$ifc defined ios}
  145. {$setc TARGET_OS_MAC := FALSE}
  146. {$setc TARGET_OS_IPHONE := TRUE}
  147. {$setc TARGET_OS_EMBEDDED := TRUE}
  148. {$elsec}
  149. {$setc TARGET_OS_MAC := TRUE}
  150. {$setc TARGET_OS_IPHONE := FALSE}
  151. {$setc TARGET_OS_EMBEDDED := FALSE}
  152. {$endc}
  153. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  154. {$elsec}
  155. {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ nor __arm64__ is defined.}
  156. {$endc}
  157. {$ifc defined __LP64__ and __LP64__ }
  158. {$setc TARGET_CPU_64 := TRUE}
  159. {$elsec}
  160. {$setc TARGET_CPU_64 := FALSE}
  161. {$endc}
  162. {$ifc defined FPC_BIG_ENDIAN}
  163. {$setc TARGET_RT_BIG_ENDIAN := TRUE}
  164. {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
  165. {$elifc defined FPC_LITTLE_ENDIAN}
  166. {$setc TARGET_RT_BIG_ENDIAN := FALSE}
  167. {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
  168. {$elsec}
  169. {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
  170. {$endc}
  171. {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
  172. {$setc CALL_NOT_IN_CARBON := FALSE}
  173. {$setc OLDROUTINENAMES := FALSE}
  174. {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
  175. {$setc OPAQUE_UPP_TYPES := TRUE}
  176. {$setc OTCARBONAPPLICATION := TRUE}
  177. {$setc OTKERNEL := FALSE}
  178. {$setc PM_USE_SESSION_APIS := TRUE}
  179. {$setc TARGET_API_MAC_CARBON := TRUE}
  180. {$setc TARGET_API_MAC_OS8 := FALSE}
  181. {$setc TARGET_API_MAC_OSX := TRUE}
  182. {$setc TARGET_CARBON := TRUE}
  183. {$setc TARGET_CPU_68K := FALSE}
  184. {$setc TARGET_CPU_MIPS := FALSE}
  185. {$setc TARGET_CPU_SPARC := FALSE}
  186. {$setc TARGET_OS_UNIX := FALSE}
  187. {$setc TARGET_OS_WIN32 := FALSE}
  188. {$setc TARGET_RT_MAC_68881 := FALSE}
  189. {$setc TARGET_RT_MAC_CFM := FALSE}
  190. {$setc TARGET_RT_MAC_MACHO := TRUE}
  191. {$setc TYPED_FUNCTION_POINTERS := TRUE}
  192. {$setc TYPE_BOOL := FALSE}
  193. {$setc TYPE_EXTENDED := FALSE}
  194. {$setc TYPE_LONGLONG := TRUE}
  195. uses MacTypes,CFBundle,Files,Multiprocessing;
  196. {$endc} {not MACOSALLINCLUDE}
  197. {$ifc TARGET_OS_MAC}
  198. {
  199. ===========================================================================================
  200. The Code Fragment Manager API
  201. =============================
  202. }
  203. {$ALIGN MAC68K}
  204. {$ifc not TARGET_CPU_64}
  205. {
  206. ¤
  207. ===========================================================================================
  208. General Types and Constants
  209. ===========================
  210. }
  211. const
  212. kCFragResourceType = FourCharCode('cfrg');
  213. kCFragResourceID = 0;
  214. kCFragLibraryFileType = FourCharCode('shlb');
  215. kCFragAllFileTypes = -1;
  216. type
  217. CFragArchitecture = OSType;
  218. const
  219. { Values for type CFragArchitecture.}
  220. kPowerPCCFragArch = FourCharCode('pwpc');
  221. kMotorola68KCFragArch = FourCharCode('m68k');
  222. kAnyCFragArch = $3F3F3F3F;
  223. {$ifc TARGET_CPU_PPC}
  224. const
  225. kCompiledCFragArch = kPowerPCCFragArch;
  226. {$endc} {TARGET_CPU_PPC}
  227. {$ifc TARGET_CPU_X86 or TARGET_CPU_X86_64}
  228. const
  229. kCompiledCFragArch = FourCharCode('none');
  230. {$endc} {TARGET_CPU_X86 or TARGET_CPU_X86_64}
  231. type
  232. CFragVersionNumber = UInt32;
  233. const
  234. kNullCFragVersion = 0;
  235. kWildcardCFragVersion = -1;
  236. type
  237. CFragUsage = UInt8;
  238. const
  239. { Values for type CFragUsage.}
  240. kImportLibraryCFrag = 0; { Standard CFM import library.}
  241. kApplicationCFrag = 1; { MacOS application.}
  242. kDropInAdditionCFrag = 2; { Application or library private extension/plug-in}
  243. kStubLibraryCFrag = 3; { Import library used for linking only}
  244. kWeakStubLibraryCFrag = 4; { Import library used for linking only and will be automatically weak linked}
  245. const
  246. kIsCompleteCFrag = 0; { A "base" fragment, not an update.}
  247. kFirstCFragUpdate = 1; { The first update, others are numbered 2, 3, ...}
  248. const
  249. kCFragGoesToEOF = 0;
  250. type
  251. CFragLocatorKind = UInt8;
  252. const
  253. { Values for type CFragLocatorKind.}
  254. kMemoryCFragLocator = 0; { Container is in memory.}
  255. kDataForkCFragLocator = 1; { Container is in a file's data fork.}
  256. kResourceCFragLocator = 2; { Container is in a file's resource fork.}
  257. kNamedFragmentCFragLocator = 4; { ! Reserved for possible future use!}
  258. kCFBundleCFragLocator = 5; { Container is in the executable of a CFBundle}
  259. kCFBundlePreCFragLocator = 6; { passed to init routines in lieu of kCFBundleCFragLocator}
  260. {
  261. --------------------------------------------------------------------------------------
  262. A 'cfrg' resource consists of a header followed by a sequence of variable length
  263. members. The constant kDefaultCFragNameLen only provides for a legal ANSI declaration
  264. and for a reasonable display in a debugger. The actual name field is cut to fit.
  265. There may be "extensions" after the name, the memberSize field includes them. The
  266. general form of an extension is a 16 bit type code followed by a 16 bit size in bytes.
  267. Only one standard extension type is defined at present, it is used by SOM's searching
  268. mechanism.
  269. }
  270. type
  271. CFragUsage1UnionPtr = ^CFragUsage1Union;
  272. CFragUsage1Union = record
  273. case SInt16 of
  274. { ! Meaning differs depending on value of "usage".}
  275. 0: (
  276. appStackSize: UInt32; { If the fragment is an application. (Not used by CFM!)}
  277. );
  278. end;
  279. type
  280. CFragUsage2UnionPtr = ^CFragUsage2Union;
  281. CFragUsage2Union = record
  282. case SInt16 of
  283. { ! Meaning differs depending on value of "usage".}
  284. 0: (
  285. appSubdirID: SInt16; { If the fragment is an application. }
  286. );
  287. 1: (
  288. libFlags: UInt16; { If the fragment is an import library. }
  289. );
  290. end;
  291. const
  292. { Bit masks for the CFragUsage2Union libFlags variant.}
  293. kCFragLibUsageMapPrivatelyMask = $0001; { Put container in app heap if necessary.}
  294. type
  295. CFragWhere1UnionPtr = ^CFragWhere1Union;
  296. CFragWhere1Union = record
  297. case SInt16 of
  298. { ! Meaning differs depending on value of "where". }
  299. 0: (
  300. spaceID: UInt32; { If the fragment is in memory. (Actually an AddressSpaceID.)}
  301. );
  302. end;
  303. type
  304. CFragWhere2UnionPtr = ^CFragWhere2Union;
  305. CFragWhere2Union = record
  306. case SInt16 of
  307. { ! Meaning differs depending on value of "where".}
  308. 0: (
  309. reserved: UInt16;
  310. );
  311. end;
  312. const
  313. kDefaultCFragNameLen = 16;
  314. type
  315. CFragResourceMember = record
  316. architecture: CFragArchitecture;
  317. reservedA: UInt16; { ! Must be zero!}
  318. reservedB: UInt8; { ! Must be zero!}
  319. updateLevel: UInt8;
  320. currentVersion: CFragVersionNumber;
  321. oldDefVersion: CFragVersionNumber;
  322. uUsage1: CFragUsage1Union;
  323. uUsage2: CFragUsage2Union;
  324. usage: CFragUsage;
  325. where: CFragLocatorKind;
  326. offset: UInt32;
  327. length: UInt32;
  328. uWhere1: CFragWhere1Union;
  329. uWhere2: CFragWhere2Union;
  330. extensionCount: UInt16; { The number of extensions beyond the name.}
  331. memberSize: UInt16; { Size in bytes, includes all extensions.}
  332. name: array [0..15] of UInt8; { ! Actually a sized PString.}
  333. end;
  334. CFragResourceMemberPtr = ^CFragResourceMember;
  335. type
  336. CFragResourceExtensionHeader = record
  337. extensionKind: UInt16;
  338. extensionSize: UInt16;
  339. end;
  340. CFragResourceExtensionHeaderPtr = ^CFragResourceExtensionHeader;
  341. type
  342. CFragResourceSearchExtension = record
  343. header: CFragResourceExtensionHeader;
  344. libKind: OSType;
  345. qualifiers: SInt8; { ! Actually four PStrings.}
  346. end;
  347. CFragResourceSearchExtensionPtr = ^CFragResourceSearchExtension;
  348. const
  349. kCFragResourceSearchExtensionKind = $30EE;
  350. type
  351. CFragResource = record
  352. reservedA: UInt32; { ! Must be zero!}
  353. reservedB: UInt32; { ! Must be zero!}
  354. reservedC: UInt16; { ! Must be zero!}
  355. version: UInt16;
  356. reservedD: UInt32; { ! Must be zero!}
  357. reservedE: UInt32; { ! Must be zero!}
  358. reservedF: UInt32; { ! Must be zero!}
  359. reservedG: UInt32; { ! Must be zero!}
  360. reservedH: UInt16; { ! Must be zero!}
  361. memberCount: UInt16;
  362. firstMember: CFragResourceMember;
  363. end;
  364. CFragResourcePtr = ^CFragResource;
  365. type
  366. CFragResourceHandle = ^CFragResourcePtr;
  367. const
  368. kCurrCFragResourceVersion = 1;
  369. type
  370. CFragContextID = MPProcessID;
  371. CFragConnectionID = ^SInt32; { an opaque type }
  372. CFragConnectionIDPtr = ^CFragConnectionID; { when a var xx:CFragConnectionID parameter can be nil, it is changed to xx: CFragConnectionIDPtr }
  373. CFragClosureID = ^SInt32; { an opaque type }
  374. CFragClosureIDPtr = ^CFragClosureID; { when a var xx:CFragClosureID parameter can be nil, it is changed to xx: CFragClosureIDPtr }
  375. CFragContainerID = ^SInt32; { an opaque type }
  376. CFragContainerIDPtr = ^CFragContainerID; { when a var xx:CFragContainerID parameter can be nil, it is changed to xx: CFragContainerIDPtr }
  377. CFragLoadOptions = OptionBits;
  378. mainAddrPtr = ^Ptr; { when a var mainAddr: Ptr parameter can be nil, it is changed to mainAddr: mainAddrPtr }
  379. symAddrPtr = ^Ptr; { when a var symAddr: Ptr parameter can be nil, it is changed to symAddr: symAddrPtr }
  380. const
  381. { Values for type CFragLoadOptions.}
  382. kReferenceCFrag = $0001; { Try to use existing copy, increment reference counts.}
  383. kFindCFrag = $0002; { Try find an existing copy, do not increment reference counts.}
  384. kPrivateCFragCopy = $0005; { Prepare a new private copy. (kReferenceCFrag | 0x0004)}
  385. const
  386. kUnresolvedCFragSymbolAddress = 0;
  387. type
  388. CFragSymbolClass = UInt8;
  389. CFragSymbolClassPtr = ^CFragSymbolClass;
  390. const
  391. { Values for type CFragSymbolClass.}
  392. kCodeCFragSymbol = 0;
  393. kDataCFragSymbol = 1;
  394. kTVectorCFragSymbol = 2;
  395. kTOCCFragSymbol = 3;
  396. kGlueCFragSymbol = 4;
  397. {
  398. ¤
  399. ===========================================================================================
  400. Macros and Functions
  401. ====================
  402. }
  403. {$ifc not TARGET_CPU_64}
  404. {
  405. * GetSharedLibrary() *** DEPRECATED ***
  406. *
  407. * Discussion:
  408. * The connID, mainAddr, and errMessage parameters may be NULL with
  409. * MacOS 8.5 and later. Passing NULL as those parameters when
  410. * running Mac OS 8.1 and earlier systems will corrupt low-memory.
  411. *
  412. * Mac OS X threading:
  413. * Thread safe since version 10.4
  414. *
  415. * Availability:
  416. * Mac OS X: in version 10.0 and later in CoreServices.framework [32-bit only] but deprecated in 10.5
  417. * CarbonLib: in CarbonLib 1.0 and later
  418. * Non-Carbon CFM: in CFragManager 1.0 and later
  419. }
  420. function GetSharedLibrary( libName: ConstStr63Param; archType: CFragArchitecture; options: CFragLoadOptions; var connID: CFragConnectionID; var mainAddr: Ptr; var errMessage: Str255 ): OSErr; external name '_GetSharedLibrary';
  421. (* __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_5, __IPHONE_NA, __IPHONE_NA) *)
  422. {
  423. * GetDiskFragment() *** DEPRECATED ***
  424. *
  425. * Mac OS X threading:
  426. * Thread safe since version 10.4
  427. *
  428. * Availability:
  429. * Mac OS X: in version 10.0 and later in CoreServices.framework [32-bit only] but deprecated in 10.5
  430. * CarbonLib: in CarbonLib 1.0 and later
  431. * Non-Carbon CFM: in CFragManager 1.0 and later
  432. }
  433. function GetDiskFragment( const (*var*) fileSpec: FSSpec; offset: UInt32; length: UInt32; fragName: ConstStr63Param { can be NULL }; options: CFragLoadOptions; connID: CFragConnectionIDPtr { can be NULL }; mainAddr: mainAddrPtr { can be NULL }; errMessage: StringPtr { can be NULL } ): OSErr; external name '_GetDiskFragment';
  434. (* __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_5, __IPHONE_NA, __IPHONE_NA) *)
  435. {
  436. * GetMemFragment() *** DEPRECATED ***
  437. *
  438. * Mac OS X threading:
  439. * Thread safe since version 10.4
  440. *
  441. * Availability:
  442. * Mac OS X: in version 10.0 and later in CoreServices.framework [32-bit only] but deprecated in 10.5
  443. * CarbonLib: in CarbonLib 1.0 and later
  444. * Non-Carbon CFM: in CFragManager 1.0 and later
  445. }
  446. function GetMemFragment( memAddr: UnivPtr; length: UInt32; fragName: ConstStringPtr { can be NULL }; options: CFragLoadOptions; connID: CFragConnectionIDPtr { can be NULL }; mainAddr: mainAddrPtr { can be NULL }; errMessage: StringPtr { can be NULL } ): OSErr; external name '_GetMemFragment';
  447. (* __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_5, __IPHONE_NA, __IPHONE_NA) *)
  448. {
  449. * CloseConnection() *** DEPRECATED ***
  450. *
  451. * Mac OS X threading:
  452. * Thread safe since version 10.4
  453. *
  454. * Availability:
  455. * Mac OS X: in version 10.0 and later in CoreServices.framework [32-bit only] but deprecated in 10.5
  456. * CarbonLib: in CarbonLib 1.0 and later
  457. * Non-Carbon CFM: in CFragManager 1.0 and later
  458. }
  459. function CloseConnection( var connID: CFragConnectionID ): OSErr; external name '_CloseConnection';
  460. (* __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_5, __IPHONE_NA, __IPHONE_NA) *)
  461. {
  462. * FindSymbol() *** DEPRECATED ***
  463. *
  464. * Mac OS X threading:
  465. * Thread safe since version 10.4
  466. *
  467. * Availability:
  468. * Mac OS X: in version 10.0 and later in CoreServices.framework [32-bit only] but deprecated in 10.5
  469. * CarbonLib: in CarbonLib 1.0 and later
  470. * Non-Carbon CFM: in CFragManager 1.0 and later
  471. }
  472. function FindSymbol( connID: CFragConnectionID; const (*var*) symName: Str255; symAddr: symAddrPtr { can be NULL }; symClass: CFragSymbolClassPtr { can be NULL } ): OSErr; external name '_FindSymbol';
  473. (* __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_5, __IPHONE_NA, __IPHONE_NA) *)
  474. {
  475. * CountSymbols() *** DEPRECATED ***
  476. *
  477. * Mac OS X threading:
  478. * Thread safe since version 10.4
  479. *
  480. * Availability:
  481. * Mac OS X: in version 10.0 and later in CoreServices.framework [32-bit only] but deprecated in 10.5
  482. * CarbonLib: in CarbonLib 1.0 and later
  483. * Non-Carbon CFM: in CFragManager 1.0 and later
  484. }
  485. function CountSymbols( connID: CFragConnectionID; var symCount: SIGNEDLONG ): OSErr; external name '_CountSymbols';
  486. (* __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_5, __IPHONE_NA, __IPHONE_NA) *)
  487. {
  488. * GetIndSymbol() *** DEPRECATED ***
  489. *
  490. * Mac OS X threading:
  491. * Thread safe since version 10.4
  492. *
  493. * Availability:
  494. * Mac OS X: in version 10.0 and later in CoreServices.framework [32-bit only] but deprecated in 10.5
  495. * CarbonLib: in CarbonLib 1.0 and later
  496. * Non-Carbon CFM: in CFragManager 1.0 and later
  497. }
  498. function GetIndSymbol( connID: CFragConnectionID; symIndex: SIGNEDLONG; symName: StringPtr { can be NULL }; symAddr: symAddrPtr { can be NULL }; symClass: CFragSymbolClassPtr { can be NULL } ): OSErr; external name '_GetIndSymbol';
  499. (* __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_0, __MAC_10_5, __IPHONE_NA, __IPHONE_NA) *)
  500. {
  501. ¤
  502. ===========================================================================================
  503. Initialization & Termination Routines
  504. =====================================
  505. }
  506. {
  507. -----------------------------------------------------------------------------------------
  508. A fragment's initialization and termination routines are called when a new incarnation of
  509. the fragment is created or destroyed, respectively. Exactly when this occurs depends on
  510. what kinds of section sharing the fragment has and how the fragment is prepared. Import
  511. libraries have at most one incarnation per process. Fragments prepared with option
  512. kPrivateCFragCopy may have many incarnations per process.
  513. The initialization function is passed a pointer to an initialization information structure
  514. and returns an OSErr. If an initialization function returns a non-zero value the entire
  515. closure of which it is a part fails. The C prototype for an initialization function is:
  516. OSErr CFragInitFunction ( const CFragInitBlock * initBlock );
  517. The termination procedure takes no parameters and returns nothing. The C prototype for a
  518. termination procedure is:
  519. void CFragTermProcedure ( void );
  520. Note that since the initialization and termination routines are themselves "CFM"-style
  521. routines whether or not they have the "pascal" keyword is irrelevant.
  522. }
  523. {
  524. -----------------------------------------------------------------------------------------
  525. ! Note:
  526. ! The "System7" portion of these type names was introduced during the evolution towards
  527. ! the now defunct Copland version of Mac OS. Copland was to be called System 8 and there
  528. ! were slightly different types for System 7 and System 8. The "generic" type names were
  529. ! conditionally defined for the desired target system.
  530. ! Always use the generic types, e.g. CFragInitBlock! The "System7" names have been kept
  531. ! only to avoid perturbing code that (improperly) used the target specific type.
  532. }
  533. {$endc} {not TARGET_CPU_64}
  534. type
  535. CFragSystem7MemoryLocatorPtr = ^CFragSystem7MemoryLocator;
  536. CFragSystem7MemoryLocator = record
  537. address: LogicalAddress;
  538. length: UInt32;
  539. inPlace: Boolean;
  540. reservedA: UInt8; { ! Must be zero!}
  541. reservedB: UInt16; { ! Must be zero!}
  542. end;
  543. type
  544. CFragSystem7DiskFlatLocatorPtr = ^CFragSystem7DiskFlatLocator;
  545. CFragSystem7DiskFlatLocator = record
  546. fileSpec: FSSpecPtr;
  547. offset: UInt32;
  548. length: UInt32;
  549. end;
  550. { ! This must have a file specification at the same offset as a disk flat locator!}
  551. type
  552. CFragSystem7SegmentedLocatorPtr = ^CFragSystem7SegmentedLocator;
  553. CFragSystem7SegmentedLocator = record
  554. fileSpec: FSSpecPtr;
  555. rsrcType: OSType;
  556. rsrcID: SInt16;
  557. reservedA: UInt16; { ! Must be zero!}
  558. end;
  559. {
  560. The offset and length for a "Bundle" locator refers to the offset in
  561. the CFM executable contained by the bundle.
  562. }
  563. type
  564. CFragCFBundleLocatorPtr = ^CFragCFBundleLocator;
  565. CFragCFBundleLocator = record
  566. fragmentBundle: CFBundleRef; { Do not call CFRelease on this bundle!}
  567. offset: UInt32;
  568. length: UInt32;
  569. end;
  570. type
  571. CFragSystem7LocatorPtr = ^CFragSystem7Locator;
  572. CFragSystem7Locator = record
  573. where: SInt32;
  574. case SInt16 of
  575. 0: (
  576. onDisk: CFragSystem7DiskFlatLocator;
  577. );
  578. 1: (
  579. inMem: CFragSystem7MemoryLocator;
  580. );
  581. 2: (
  582. inSegs: CFragSystem7SegmentedLocator;
  583. );
  584. 3: (
  585. inBundle: CFragCFBundleLocator;
  586. );
  587. end;
  588. type
  589. CFragSystem7InitBlock = record
  590. contextID: CFragContextID;
  591. closureID: CFragClosureID;
  592. connectionID: CFragConnectionID;
  593. fragLocator: CFragSystem7Locator;
  594. libName: StringPtr;
  595. reservedA: UInt32; { ! Must be zero!}
  596. end;
  597. CFragSystem7InitBlockPtr = ^CFragSystem7InitBlock;
  598. type
  599. CFragInitBlock = CFragSystem7InitBlock;
  600. CFragInitBlockPtr = CFragSystem7InitBlockPtr;
  601. { These init/term routine types are only of value to CFM itself.}
  602. type
  603. CFragInitFunction = function( const (*var*) initBlock: CFragInitBlock ): OSErr;
  604. CFragTermProcedure = procedure;
  605. { For use by init routines. If you get a BundlePreLocator, convert it to a CFBundleLocator with this}
  606. {$ifc not TARGET_CPU_64}
  607. {
  608. * ConvertBundlePreLocator() *** DEPRECATED ***
  609. *
  610. * Availability:
  611. * Mac OS X: in version 10.1 and later in CoreServices.framework [32-bit only] but deprecated in 10.5
  612. * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.1 and later
  613. * Non-Carbon CFM: not available
  614. }
  615. function ConvertBundlePreLocator( initBlockLocator: CFragSystem7LocatorPtr ): OSErr; external name '_ConvertBundlePreLocator';
  616. (* __OSX_AVAILABLE_BUT_DEPRECATED(__MAC_10_1, __MAC_10_5, __IPHONE_NA, __IPHONE_NA) *)
  617. {
  618. ¤
  619. ===========================================================================================
  620. Old Name Spellings
  621. ==================
  622. }
  623. {
  624. -------------------------------------------------------------------------------------------
  625. We've tried to reduce the risk of name collisions in the future by introducing the phrase
  626. "CFrag" into constant and type names. The old names are defined below in terms of the new.
  627. }
  628. {$endc} {not TARGET_CPU_64}
  629. const
  630. kLoadCFrag = kReferenceCFrag;
  631. {$if OLDROUTINENAMES}
  632. //#define IsFileLocation CFragHasFileLocation
  633. type
  634. ConnectionID = CFragConnectionID;
  635. LoadFlags = CFragLoadOptions;
  636. SymClass = CFragSymbolClass;
  637. InitBlock = CFragInitBlock;
  638. InitBlockPtr = CFragInitBlockPtr;
  639. MemFragment = CFragSystem7MemoryLocator;
  640. DiskFragment = CFragSystem7DiskFlatLocator;
  641. SegmentedFragment = CFragSystem7SegmentedLocator;
  642. FragmentLocator = CFragSystem7Locator;
  643. FragmentLocatorPtr = CFragSystem7LocatorPtr;
  644. CFragHFSMemoryLocator = CFragSystem7MemoryLocator;
  645. CFragHFSDiskFlatLocator = CFragSystem7DiskFlatLocator;
  646. CFragHFSSegmentedLocator = CFragSystem7SegmentedLocator;
  647. CFragHFSLocator = CFragSystem7Locator;
  648. CFragHFSLocatorPtr = CFragSystem7LocatorPtr;
  649. const
  650. kPowerPCArch = kPowerPCCFragArch;
  651. kMotorola68KArch = kMotorola68KCFragArch;
  652. kAnyArchType = kAnyCFragArch;
  653. kNoLibName = 0;
  654. kNoConnectionID = 0;
  655. kLoadLib = kLoadCFrag;
  656. kFindLib = kFindCFrag;
  657. kNewCFragCopy = kPrivateCFragCopy;
  658. kLoadNewCopy = kPrivateCFragCopy;
  659. kUseInPlace = $80;
  660. kCodeSym = kCodeCFragSymbol;
  661. kDataSym = kDataCFragSymbol;
  662. kTVectSym = kTVectorCFragSymbol;
  663. kTOCSym = kTOCCFragSymbol;
  664. kGlueSym = kGlueCFragSymbol;
  665. kInMem = kMemoryCFragLocator;
  666. kOnDiskFlat = kDataForkCFragLocator;
  667. kOnDiskSegmented = kResourceCFragLocator;
  668. kIsLib = kImportLibraryCFrag;
  669. kIsApp = kApplicationCFrag;
  670. kIsDropIn = kDropInAdditionCFrag;
  671. kFullLib = kIsCompleteCFrag;
  672. kUpdateLib = kFirstCFragUpdate;
  673. kWholeFork = kCFragGoesToEOF;
  674. kCFMRsrcType = kCFragResourceType;
  675. kCFMRsrcID = kCFragResourceID;
  676. kSHLBFileType = kCFragLibraryFileType;
  677. kUnresolvedSymbolAddress = kUnresolvedCFragSymbolAddress;
  678. const
  679. kPowerPC = kPowerPCCFragArch;
  680. kMotorola68K = kMotorola68KCFragArch;
  681. {$endc} {OLDROUTINENAMES}
  682. {$endc} {not TARGET_CPU_64}
  683. {$endc} {TARGET_OS_MAC}
  684. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  685. end.
  686. {$endc} {not MACOSALLINCLUDE}