HITextUtils.pas 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. {
  2. File: HIToolbox/HITextUtils.h
  3. Contains: Text utilities provided by HIToolbox.
  4. Version: HIToolbox-219.4.81~2
  5. Copyright: © 2002-2005 by Apple Computer, Inc., all rights reserved.
  6. Bugs?: For bug reports, consult the following page on
  7. the World Wide Web:
  8. http://www.freepascal.org/bugs.html
  9. }
  10. { Pascal Translation: Peter N Lewis, <[email protected]>, August 2005 }
  11. {
  12. Modified for use with Free Pascal
  13. Version 200
  14. Please report any bugs to <[email protected]>
  15. }
  16. {$mode macpas}
  17. {$packenum 1}
  18. {$macro on}
  19. {$inline on}
  20. {$CALLING MWPASCAL}
  21. unit HITextUtils;
  22. interface
  23. {$setc UNIVERSAL_INTERFACES_VERSION := $0342}
  24. {$setc GAP_INTERFACES_VERSION := $0200}
  25. {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
  26. {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
  27. {$endc}
  28. {$ifc defined CPUPOWERPC and defined CPUI386}
  29. {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
  30. {$endc}
  31. {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
  32. {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
  33. {$endc}
  34. {$ifc not defined __ppc__ and defined CPUPOWERPC}
  35. {$setc __ppc__ := 1}
  36. {$elsec}
  37. {$setc __ppc__ := 0}
  38. {$endc}
  39. {$ifc not defined __i386__ and defined CPUI386}
  40. {$setc __i386__ := 1}
  41. {$elsec}
  42. {$setc __i386__ := 0}
  43. {$endc}
  44. {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
  45. {$error Conflicting definitions for __ppc__ and __i386__}
  46. {$endc}
  47. {$ifc defined __ppc__ and __ppc__}
  48. {$setc TARGET_CPU_PPC := TRUE}
  49. {$setc TARGET_CPU_X86 := FALSE}
  50. {$elifc defined __i386__ and __i386__}
  51. {$setc TARGET_CPU_PPC := FALSE}
  52. {$setc TARGET_CPU_X86 := TRUE}
  53. {$elsec}
  54. {$error Neither __ppc__ nor __i386__ is defined.}
  55. {$endc}
  56. {$setc TARGET_CPU_PPC_64 := FALSE}
  57. {$ifc defined FPC_BIG_ENDIAN}
  58. {$setc TARGET_RT_BIG_ENDIAN := TRUE}
  59. {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
  60. {$elifc defined FPC_LITTLE_ENDIAN}
  61. {$setc TARGET_RT_BIG_ENDIAN := FALSE}
  62. {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
  63. {$elsec}
  64. {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
  65. {$endc}
  66. {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
  67. {$setc CALL_NOT_IN_CARBON := FALSE}
  68. {$setc OLDROUTINENAMES := FALSE}
  69. {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
  70. {$setc OPAQUE_UPP_TYPES := TRUE}
  71. {$setc OTCARBONAPPLICATION := TRUE}
  72. {$setc OTKERNEL := FALSE}
  73. {$setc PM_USE_SESSION_APIS := TRUE}
  74. {$setc TARGET_API_MAC_CARBON := TRUE}
  75. {$setc TARGET_API_MAC_OS8 := FALSE}
  76. {$setc TARGET_API_MAC_OSX := TRUE}
  77. {$setc TARGET_CARBON := TRUE}
  78. {$setc TARGET_CPU_68K := FALSE}
  79. {$setc TARGET_CPU_MIPS := FALSE}
  80. {$setc TARGET_CPU_SPARC := FALSE}
  81. {$setc TARGET_OS_MAC := TRUE}
  82. {$setc TARGET_OS_UNIX := FALSE}
  83. {$setc TARGET_OS_WIN32 := FALSE}
  84. {$setc TARGET_RT_MAC_68881 := FALSE}
  85. {$setc TARGET_RT_MAC_CFM := FALSE}
  86. {$setc TARGET_RT_MAC_MACHO := TRUE}
  87. {$setc TYPED_FUNCTION_POINTERS := TRUE}
  88. {$setc TYPE_BOOL := FALSE}
  89. {$setc TYPE_EXTENDED := FALSE}
  90. {$setc TYPE_LONGLONG := TRUE}
  91. uses MacTypes, TextCommon, CFBase;
  92. {$ALIGN POWER}
  93. {
  94. * GetTextAndEncodingFromCFString()
  95. *
  96. * Summary:
  97. * Converts the contents of a CFString to the one- or two-byte
  98. * encoding that most accurately represents the original Unicode
  99. * characters in the string.
  100. *
  101. * Discussion:
  102. * Because the Macintosh toolbox has had, until Carbon, little
  103. * support for Unicode, you may often find that your applications
  104. * need to translate a CFString (containing Unicode characters) back
  105. * to a one- or two-byte encoding of the string in order to draw,
  106. * measure, or otherwise use the text in the string.
  107. * GetTextAndEncodingFromCFString is a utility that may be helpful
  108. * to do this, in some circumstances. The Carbon toolbox uses this
  109. * API itself when translating CFStrings to Pascal strings.
  110. * GetTextAndEncodingFromCFString attempts to convert the Unicode
  111. * characters in the string to the closest non-Unicode
  112. * representation of the string. For example, a string containing
  113. * only Unicode characters that are present in the MacRoman one-byte
  114. * encoding will be translated to MacRoman, and
  115. * kTextEncodingMacRoman will be returned as the encoding of the
  116. * text. A string containing Unicode characters that are present in
  117. * the MacJapanese two-byte encoding will be translated to
  118. * MacJapanese (Shift-JIS), and kTextEncodingMacJapanese will be
  119. * returned as the encoding of the text.
  120. * GetTextAndEncodingFromCFString is designed to be used for simple
  121. * strings which contain only text from a single language. It is not
  122. * designed to translate strings with multiple runs of text from
  123. * different languages, and will only return the first run of such a
  124. * string; for example, if you pass it a string containing a run of
  125. * Roman characters followed by a run of Japanese characters, it
  126. * will only return the Roman characters in the output buffer. For
  127. * more complex text translation, you should call the Unicode
  128. * converter directly (see ConvertFromUnicodeToTextRun, which
  129. * GetTextAndEncodingFromCFString uses internally).
  130. *
  131. * Mac OS X threading:
  132. * Not thread safe
  133. *
  134. * Parameters:
  135. *
  136. * inString:
  137. * The string to convert.
  138. *
  139. * outText:
  140. * The output buffer in which to place the converted text.
  141. *
  142. * inTextMaxLength:
  143. * The length in bytes of the input buffer.
  144. *
  145. * outTextLength:
  146. * On exit, contains the length in bytes of the text that was
  147. * placed into the output buffer.
  148. *
  149. * outEncoding:
  150. * On exit, contains the encoding of the text that was placed into
  151. * the output buffer.
  152. *
  153. * Availability:
  154. * Mac OS X: in version 10.0 and later in Carbon.framework
  155. * CarbonLib: in CarbonLib 1.2.5 and later
  156. * Non-Carbon CFM: not available
  157. }
  158. function GetTextAndEncodingFromCFString( inString: CFStringRef; outText: BytePtr; inTextMaxLength: ByteCount; var outTextLength: ByteCount; outEncoding: TextEncodingPtr { can be NULL } ): OSStatus; external name '_GetTextAndEncodingFromCFString';
  159. (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
  160. end.