| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245 | {	CFAttributedString.h	Copyright (c) 2004-2005, Apple, Inc. All rights reserved.}{       Pascal Translation:  Peter N Lewis, <[email protected]>, August 2005 }{    Modified for use with Free Pascal    Version 200    Please report any bugs to <[email protected]>}{$mode macpas}{$packenum 1}{$macro on}{$inline on}{$CALLING MWPASCAL}unit CFAttributedString;interface{$setc UNIVERSAL_INTERFACES_VERSION := $0342}{$setc GAP_INTERFACES_VERSION := $0200}{$ifc not defined USE_CFSTR_CONSTANT_MACROS}    {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}{$endc}{$ifc defined CPUPOWERPC and defined CPUI386}	{$error Conflicting initial definitions for CPUPOWERPC and CPUI386}{$endc}{$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}	{$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}{$endc}{$ifc not defined __ppc__ and defined CPUPOWERPC}	{$setc __ppc__ := 1}{$elsec}	{$setc __ppc__ := 0}{$endc}{$ifc not defined __i386__ and defined CPUI386}	{$setc __i386__ := 1}{$elsec}	{$setc __i386__ := 0}{$endc}{$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}	{$error Conflicting definitions for __ppc__ and __i386__}{$endc}{$ifc defined __ppc__ and __ppc__}	{$setc TARGET_CPU_PPC := TRUE}	{$setc TARGET_CPU_X86 := FALSE}{$elifc defined __i386__ and __i386__}	{$setc TARGET_CPU_PPC := FALSE}	{$setc TARGET_CPU_X86 := TRUE}{$elsec}	{$error Neither __ppc__ nor __i386__ is defined.}{$endc}{$setc TARGET_CPU_PPC_64 := FALSE}{$ifc defined FPC_BIG_ENDIAN}	{$setc TARGET_RT_BIG_ENDIAN := TRUE}	{$setc TARGET_RT_LITTLE_ENDIAN := FALSE}{$elifc defined FPC_LITTLE_ENDIAN}	{$setc TARGET_RT_BIG_ENDIAN := FALSE}	{$setc TARGET_RT_LITTLE_ENDIAN := TRUE}{$elsec}	{$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}{$endc}{$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}{$setc CALL_NOT_IN_CARBON := FALSE}{$setc OLDROUTINENAMES := FALSE}{$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}{$setc OPAQUE_UPP_TYPES := TRUE}{$setc OTCARBONAPPLICATION := TRUE}{$setc OTKERNEL := FALSE}{$setc PM_USE_SESSION_APIS := TRUE}{$setc TARGET_API_MAC_CARBON := TRUE}{$setc TARGET_API_MAC_OS8 := FALSE}{$setc TARGET_API_MAC_OSX := TRUE}{$setc TARGET_CARBON := TRUE}{$setc TARGET_CPU_68K := FALSE}{$setc TARGET_CPU_MIPS := FALSE}{$setc TARGET_CPU_SPARC := FALSE}{$setc TARGET_OS_MAC := TRUE}{$setc TARGET_OS_UNIX := FALSE}{$setc TARGET_OS_WIN32 := FALSE}{$setc TARGET_RT_MAC_68881 := FALSE}{$setc TARGET_RT_MAC_CFM := FALSE}{$setc TARGET_RT_MAC_MACHO := TRUE}{$setc TYPED_FUNCTION_POINTERS := TRUE}{$setc TYPE_BOOL := FALSE}{$setc TYPE_EXTENDED := FALSE}{$setc TYPE_LONGLONG := TRUE}uses MacTypes,CFBase,CFString,CFDictionary;{$ALIGN POWER}{! @header CFAttributedStringInstance of CFAttributedString manage character strings and associated sets of attributes (for example, font and kerning) that apply to individual characters or ranges of characters in the string. CFAttributedString as defined in CoreFoundation provides the basic container functionality, while higher levels provide definitions for standard attributes, their values, and additional behaviors involving these. CFAttributedString is not a "subclass" of CFString; that is, it does not respond to CFString function calls. CFAttributedString conceptually contains a CFString to which it applies attributes. This protects users of attributed strings from ambiguities caused by the semantic differences between simple and attributed string.Attributes are identified by key/value pairs stored in CFDictionaryRefs. Keys must be CFStrings, while the values are arbitrary CFTypeRefs.}{ CFAttributedString comes in immutable and mutable flavors.}type	CFAttributedStringRef = ^SInt32; { an opaque 32-bit type }	CFMutableAttributedStringRef = ^SInt32; { an opaque 32-bit type }{! @function CFAttributedStringGetTypeIDReturns the type identifier of all CFAttributedString instances.}function CFAttributedStringGetTypeID: CFTypeID; external name '_CFAttributedStringGetTypeID';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){** CFAttributedString **}{! @function CFAttributedStringCreateCreates an attributed string with the specified string and attributes (both copied).}function CFAttributedStringCreate( alloc: CFAllocatorRef; str: CFStringRef; attributes: CFDictionaryRef ): CFAttributedStringRef; external name '_CFAttributedStringCreate';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringCreateWithSubstringCreates a sub-attributed string from the specified range. It's a programming error for range to specify characters outside the bounds of aStr.}function CFAttributedStringCreateWithSubstring( alloc: CFAllocatorRef; aStr: CFAttributedStringRef; range: CFRange ): CFAttributedStringRef; external name '_CFAttributedStringCreateWithSubstring';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringCreateCopyCreates an immutable attributed string copy.}function CFAttributedStringCreateCopy( alloc: CFAllocatorRef; aStr: CFAttributedStringRef ): CFAttributedStringRef; external name '_CFAttributedStringCreateCopy';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringGetStringReturns the string for the attributed string. For performance reasons, this will often point at the backing store of the attributed string, and it might change if the attributed string is edited.  However, this is an implementation detail, and definitely not something that should be counted on.}function CFAttributedStringGetString( aStr: CFAttributedStringRef ): CFStringRef; external name '_CFAttributedStringGetString';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringGetLengthReturns the length of the attributed string in characters; same as CFStringGetLength(CFAttributedStringGetString(aStr))}function CFAttributedStringGetLength( aStr: CFAttributedStringRef ): CFIndex; external name '_CFAttributedStringGetLength';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringGetAttributesReturns the attributes at the specified location. If effectiveRange is not NULL, upon return *effectiveRange contains a range over which the exact same set of attributes apply. Note that for performance reasons, the returned effectiveRange is not necessarily the maximal range - for that, use CFAttributedStringGetAttributesAndLongestEffectiveRange().  It's a programming error for loc to specify a location outside the bounds of the attributed string.Note that the returned attribute dictionary might change in unpredicatable ways from under the caller if the attributed string is edited after this call. If you wish to hang on to the dictionary long-term, you should make an actual copy of it rather than just retaining it.  Also, no assumptions should be made about the relationship of the actual CFDictionaryRef returned by this call and the dictionary originally used to set the attributes, other than the fact that the values stored in the dictionary will be identical (that is, ==) to those originally specified.}function CFAttributedStringGetAttributes( aStr: CFAttributedStringRef; loc: CFIndex; effectiveRange: CFRangePtr ): CFDictionaryRef; external name '_CFAttributedStringGetAttributes';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringGetAttributeReturns the value of a single attribute at the specified location. If the specified attribute doesn't exist at the location, returns NULL. If effectiveRange is not NULL, upon return *effectiveRange contains a range over which the exact same attribute value applies. Note that for performance reasons, the returned effectiveRange is not necessarily the maximal range - for that, use CFAttributedStringGetAttributeAndLongestEffectiveRange(). It's a programming error for loc to specify a location outside the bounds of the attributed string.}function CFAttributedStringGetAttribute( aStr: CFAttributedStringRef; loc: CFIndex; attrName: CFStringRef; effectiveRange: CFRangePtr ): CFTypeRef; external name '_CFAttributedStringGetAttribute';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringGetAttributesAndLongestEffectiveRangeReturns the attributes at the specified location. If longestEffectiveRange is not NULL, upon return *longestEffectiveRange contains the maximal range within inRange over which the exact same set of attributes apply. The returned range is clipped to inRange. It's a programming error for loc or inRange to specify locations outside the bounds of the attributed string.}function CFAttributedStringGetAttributesAndLongestEffectiveRange( aStr: CFAttributedStringRef; loc: CFIndex; inRange: CFRange; longestEffectiveRange: CFRangePtr ): CFDictionaryRef; external name '_CFAttributedStringGetAttributesAndLongestEffectiveRange';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringGetAttributeAndLongestEffectiveRangeReturns the value of a single attribute at the specified location. If longestEffectiveRange is not NULL, upon return *longestEffectiveRange contains the maximal range within inRange over which the exact same attribute value applies. The returned range is clipped to inRange. It's a programming error for loc or inRange to specify locations outside the bounds of the attributed string.}function CFAttributedStringGetAttributeAndLongestEffectiveRange( aStr: CFAttributedStringRef; loc: CFIndex; attrName: CFStringRef; inRange: CFRange; longestEffectiveRange: CFRangePtr ): CFTypeRef; external name '_CFAttributedStringGetAttributeAndLongestEffectiveRange';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){** CFMutableAttributedString **}{! @function CFAttributedStringCreateMutableCopyCreates a mutable attributed string copy. maxLength, if not 0, is a hard bound on the length of the attributed string; exceeding this size limit during any editing operation is a programming error. If 0, there is no limit on the length.}function CFAttributedStringCreateMutableCopy( alloc: CFAllocatorRef; maxLength: CFIndex; aStr: CFAttributedStringRef ): CFMutableAttributedStringRef; external name '_CFAttributedStringCreateMutableCopy';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringCreateMutableCreates a mutable empty attributed string. maxLength, if not 0, is a hard bound on the length of the attributed string; exceeding this size limit during any editing operation is a programming error. If 0, there is no limit on the length.}function CFAttributedStringCreateMutable( alloc: CFAllocatorRef; maxLength: CFIndex ): CFMutableAttributedStringRef; external name '_CFAttributedStringCreateMutable';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringReplaceStringModifies the string for the attributed string, much like CFStringReplace().  It's an error for range to specify characters outside the bounds of aStr. (Note: This function is a convenience on CFAttributedStringGetMutableString(); however, until CFAttributedStringGetMutableString() is implemented, it remains the only way to edit the string of the attributed string.)}procedure CFAttributedStringReplaceString( aStr: CFMutableAttributedStringRef; range: CFRange; replacement: CFStringRef ); external name '_CFAttributedStringReplaceString';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringGetMutableStringGets the string for the attributed string as a mutable string, allowing editing the character contents of the string as if it were an CFMutableString. Attributes corresponding to the edited range are appropriately modified. If, as a result of the edit, new characters are introduced into the string, they inherit the attributes of the first replaced character from range. If no existing characters are replaced by the edit, the new characters inherit the attributes of the character preceding range if it has any, otherwise of the character following range. If the initial string is empty, the attributes for the new characters are also empty.(Note: This function is not yet implemented and will return NULL except for toll-free bridged instances.)}function CFAttributedStringGetMutableString( aStr: CFMutableAttributedStringRef ): CFMutableStringRef; external name '_CFAttributedStringGetMutableString';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringSetAttributesSets the value of multiple attributes over the specified range, which should be valid. If clearOtherAttributes is false, existing attributes (which aren't being replaced) are left alone; otherwise they are cleared. The dictionary should be setup for "usual" CF type usage --- CFString keys, and arbitrary CFType values. Note that after this call, further mutations to the replacement dictionary argument by the caller will not affect the contents of the attributed string.}procedure CFAttributedStringSetAttributes( aStr: CFMutableAttributedStringRef; range: CFRange; replacement: CFDictionaryRef; clearOtherAttributes: Boolean ); external name '_CFAttributedStringSetAttributes';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringSetAttributeSets the value of a single attribute over the specified range, which should be valid. value should not be NULL. }procedure CFAttributedStringSetAttribute( aStr: CFMutableAttributedStringRef; range: CFRange; attrName: CFStringRef; value: CFTypeRef ); external name '_CFAttributedStringSetAttribute';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringRemoveAttributeRemoves the value of a single attribute over the specified range, which should be valid. It's OK for the attribute not the exist over the specified range.}procedure CFAttributedStringRemoveAttribute( aStr: CFMutableAttributedStringRef; range: CFRange; attrName: CFStringRef ); external name '_CFAttributedStringRemoveAttribute';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringReplaceAttributedStringReplaces the attributed substring over the specified range with the attributed string specified in replacement. range should be valid. To delete a range of the attributed string, call CFAttributedStringReplaceString() with empty string and specified range. }procedure CFAttributedStringReplaceAttributedString( aStr: CFMutableAttributedStringRef; range: CFRange; replacement: CFAttributedStringRef ); external name '_CFAttributedStringReplaceAttributedString';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringBeginEditingIn cases where attributed string might do a bunch of work to assure self-consistency, CFAttributedStringBeginEditing/CFAttributedStringEndEditing allow disabling that to allow deferring and coalescing any work. It's a good idea to call these around a set of related mutation calls which don't require the string to be in consistent state in between. These calls can be nested. }procedure CFAttributedStringBeginEditing( aStr: CFMutableAttributedStringRef ); external name '_CFAttributedStringBeginEditing';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *){! @function CFAttributedStringEndEditingIn cases where attributed string might do a bunch of work to assure self-consistency, CFAttributedStringBeginEditing/CFAttributedStringEndEditing allow disabling that to allow deferring and coalescing any work. It's a good idea to call these around a set of related mutation calls which don't require the string to be in consistent state in between. These calls can be nested. }procedure CFAttributedStringEndEditing( aStr: CFMutableAttributedStringRef ); external name '_CFAttributedStringEndEditing';(* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *)end.
 |