CTGlyphInfo.pas 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441
  1. {
  2. * CTGlyphInfo.h
  3. * CoreText
  4. *
  5. * Copyright (c) 2006-2012 Apple Inc. All rights reserved.
  6. *
  7. }
  8. { Initial Pascal Translation: Jonas Maebe, <[email protected]>, October 2009 }
  9. { Pascal Translation Updated: Jonas Maebe, <[email protected]>, October 2012 }
  10. { Pascal Translation Updated: Jonas Maebe, <[email protected]>, August 2015 }
  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 CTGlyphInfo;
  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.CTFont,MacOsApi.CFBase,MacOsApi.CGFont;
  203. {$ELSE FPC_DOTTEDUNITS}
  204. uses MacTypes,CTFont,CFBase,CGFont;
  205. {$ENDIF FPC_DOTTEDUNITS}
  206. {$endc} {not MACOSALLINCLUDE}
  207. {$ALIGN POWER}
  208. {!
  209. @header
  210. Thread Safety Information
  211. All functions in this header are thread safe unless otherwise specified.
  212. }
  213. { --------------------------------------------------------------------------- }
  214. { Glyph Info Types }
  215. { --------------------------------------------------------------------------- }
  216. type
  217. CTGlyphInfoRef = ^__CTGlyphInfo; { an opaque type }
  218. __CTGlyphInfo = record end;
  219. CTGlyphInfoRefPtr = ^CTGlyphInfoRef;
  220. {!
  221. @function CTGlyphInfoGetTypeID
  222. @abstract Returns the CFType of the glyph info object
  223. }
  224. function CTGlyphInfoGetTypeID: CFTypeID; external name '_CTGlyphInfoGetTypeID';
  225. (* CT_AVAILABLE_STARTING( __MAC_10_5, __IPHONE_3_2) *)
  226. { --------------------------------------------------------------------------- }
  227. { Glyph Info Values }
  228. { --------------------------------------------------------------------------- }
  229. {!
  230. @enum CTCharacterCollection
  231. @abstract These constants specify character collections.
  232. @constant kCTCharacterCollectionIdentityMapping
  233. Indicates that the character identifier is equal to the CGGlyph
  234. glyph index.
  235. @constant kCTCharacterCollectionAdobeCNS1
  236. Indicates the Adobe-CNS1 mapping.
  237. @constant kCTCharacterCollectionAdobeGB1
  238. Indicates the Adobe-GB1 mapping.
  239. @constant kCTCharacterCollectionAdobeJapan1
  240. Indicates the Adobe-Japan1 mapping.
  241. @constant kCTCharacterCollectionAdobeJapan2
  242. Indicates the Adobe-Japan2 mapping.
  243. @constant kCTCharacterCollectionAdobeKorea1
  244. Indicates the Adobe-Korea1 mapping.
  245. }
  246. const
  247. kCTCharacterCollectionIdentityMapping = 0;
  248. kCTCharacterCollectionAdobeCNS1 = 1;
  249. kCTCharacterCollectionAdobeGB1 = 2;
  250. kCTCharacterCollectionAdobeJapan1 = 3;
  251. kCTCharacterCollectionAdobeJapan2 = 4;
  252. kCTCharacterCollectionAdobeKorea1 = 5;
  253. kCTIdentityMappingCharacterCollection = kCTCharacterCollectionIdentityMapping;
  254. kCTAdobeCNS1CharacterCollection = kCTCharacterCollectionAdobeCNS1;
  255. kCTAdobeGB1CharacterCollection = kCTCharacterCollectionAdobeGB1;
  256. kCTAdobeJapan1CharacterCollection = kCTCharacterCollectionAdobeJapan1;
  257. kCTAdobeJapan2CharacterCollection = kCTCharacterCollectionAdobeJapan2;
  258. kCTAdobeKorea1CharacterCollection = kCTCharacterCollectionAdobeKorea1;
  259. type
  260. CTCharacterCollection = UInt16;
  261. { --------------------------------------------------------------------------- }
  262. { Glyph Info Creation }
  263. { --------------------------------------------------------------------------- }
  264. {!
  265. @function CTGlyphInfoCreateWithGlyphName
  266. @abstract Creates an immutable glyph info object.
  267. @discussion This function creates an immutable glyph info object for a glyph
  268. name such as "copyright" and a specified font.
  269. @param glyphName
  270. The name of the glyph.
  271. @param font
  272. The font to be associated with the returned CTGlyphInfo object.
  273. @param baseString
  274. The part of the string the returned object is intended
  275. to override.
  276. @result If glyph info creation was successful, this function will return
  277. a valid reference to an immutable CTGlyphInfo object. Otherwise,
  278. this function will return NULL.
  279. }
  280. function CTGlyphInfoCreateWithGlyphName( glyphName: CFStringRef; font: CTFontRef; baseString: CFStringRef ): CTGlyphInfoRef; external name '_CTGlyphInfoCreateWithGlyphName';
  281. (* CT_AVAILABLE_STARTING( __MAC_10_5, __IPHONE_3_2) *)
  282. {!
  283. @function CTGlyphInfoCreateWithGlyph
  284. @abstract Creates an immutable glyph info object.
  285. @discussion This function creates an immutable glyph info object for a glyph
  286. index and a specified font.
  287. @param glyph
  288. The glyph identifier.
  289. @param font
  290. The font to be associated with the returned CTGlyphInfo object.
  291. @param baseString
  292. The part of the string the returned object is intended
  293. to override.
  294. @result If glyph info creation was successful, this function will return
  295. a valid reference to an immutable CTGlyphInfo object. Otherwise,
  296. this function will return NULL.
  297. }
  298. function CTGlyphInfoCreateWithGlyph( glyph: CGGlyph; font: CTFontRef; baseString: CFStringRef ): CTGlyphInfoRef; external name '_CTGlyphInfoCreateWithGlyph';
  299. (* CT_AVAILABLE_STARTING( __MAC_10_5, __IPHONE_3_2) *)
  300. {!
  301. @function CTGlyphInfoCreateWithCharacterIdentifier
  302. @abstract Creates an immutable glyph info object.
  303. @discussion This function creates an immutable glyph info object for a
  304. character identifier and a character collection.
  305. @param cid
  306. A character identifier.
  307. @param collection
  308. A character collection identifier.
  309. @param baseString
  310. The part of the string the returned object is intended
  311. to override.
  312. @result If glyph info creation was successful, this function will return
  313. a valid reference to an immutable CTGlyphInfo object. Otherwise,
  314. this function will return NULL.
  315. }
  316. function CTGlyphInfoCreateWithCharacterIdentifier( cid: CGFontIndex; collection: CTCharacterCollection; baseString: CFStringRef ): CTGlyphInfoRef; external name '_CTGlyphInfoCreateWithCharacterIdentifier';
  317. (* CT_AVAILABLE_STARTING( __MAC_10_5, __IPHONE_3_2) *)
  318. { --------------------------------------------------------------------------- }
  319. { Glyph Info Access }
  320. { --------------------------------------------------------------------------- }
  321. {!
  322. @function CTGlyphInfoGetGlyphName
  323. @abstract Gets the glyph name for a glyph info, if applicable.
  324. @discussion This function will return the glyph name.
  325. @param glyphInfo
  326. The glyph info for which you would like the glyph name. This
  327. parameter may not be set to NULL.
  328. @result If the glyph info object was created with a glyph name, it will
  329. be returned. Otherwise, this function will return NULL.
  330. }
  331. function CTGlyphInfoGetGlyphName( glyphInfo: CTGlyphInfoRef ): CFStringRef; external name '_CTGlyphInfoGetGlyphName';
  332. (* CT_AVAILABLE_STARTING( __MAC_10_5, __IPHONE_3_2) *)
  333. {!
  334. @function CTGlyphInfoGetCharacterIdentifier
  335. @abstract Gets the character identifier for a glyph info.
  336. @discussion This function will return the character identifier.
  337. @param glyphInfo
  338. The glyph info for which you would like the character identifier.
  339. This parameter may not be set to NULL.
  340. @result If the glyph info object was created with a character identifier,
  341. it will be returned. Otherwise, this function will return 0.
  342. }
  343. function CTGlyphInfoGetCharacterIdentifier( glyphInfo: CTGlyphInfoRef ): CGFontIndex; external name '_CTGlyphInfoGetCharacterIdentifier';
  344. (* CT_AVAILABLE_STARTING( __MAC_10_5, __IPHONE_3_2) *)
  345. {!
  346. @function CTGlyphInfoGetCharacterCollection
  347. @abstract Gets the character collection for a glyph info.
  348. @discussion This function will return the character collection. If the glyph
  349. info object was created with a glyph name or a glyph index, its
  350. character collection will be
  351. kCTIdentityMappingCharacterCollection.
  352. @param glyphInfo
  353. The glyph info for which you would like the character collection.
  354. This parameter may not be set to NULL.
  355. @result This function will return the character collection of the given
  356. glyph info.
  357. }
  358. function CTGlyphInfoGetCharacterCollection( glyphInfo: CTGlyphInfoRef ): CTCharacterCollection; external name '_CTGlyphInfoGetCharacterCollection';
  359. (* CT_AVAILABLE_STARTING( __MAC_10_5, __IPHONE_3_2) *)
  360. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  361. end.
  362. {$endc} {not MACOSALLINCLUDE}