123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656 |
- {
- File: ATSLayoutTypes.p
-
- Contains: Apple Type Services layout public structures and constants.
-
- Version: Technology: Mac OS 9/Carbon
- Release: Universal Interfaces 3.4.2
-
- Copyright: © 1994-2002 by Apple Computer, Inc., all rights reserved.
-
- Bugs?: For bug reports, consult the following page on
- the World Wide Web:
-
- http://www.freepascal.org/bugs.html
-
- }
- {
- 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 ATSLayoutTypes;
- 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,SFNTLayoutTypes,ATSTypes;
- {$ALIGN MAC68K}
- { --------------------------------------------------------------------------- }
- { CONSTANTS and related scalar types }
- { --------------------------------------------------------------------------- }
- { Miscellaneous constants }
- const
- kATSUseGlyphAdvance = $7FFFFFFF; { assignment to use natural glyph advance value }
- kATSUseLineHeight = $7FFFFFFF; { assignment to use natural line ascent/descent values }
- kATSNoTracking = $80000000; { negativeInfinity }
- {
- * ATSULayoutOperationSelector
- *
- * Summary:
- * This is used to select which operations to override, or which
- * operation is currently being run.
- }
- type ATSULayoutOperationSelector = UInt32;
- const
- {
- * No Layout operation is currently selected.
- }
- kATSULayoutOperationNone = $00000000;
- {
- * Select the Justification operation.
- }
- kATSULayoutOperationJustification = $00000001;
- {
- * Select the character morphing operation.
- }
- kATSULayoutOperationMorph = $00000002;
- {
- * Select the kerning adjustment operation.
- }
- kATSULayoutOperationKerningAdjustment = $00000004;
- {
- * Select the baseline adjustment operation.
- }
- kATSULayoutOperationBaselineAdjustment = $00000008;
- {
- * Select the tracking adjustment operation.
- }
- kATSULayoutOperationTrackingAdjustment = $00000010;
- {
- * Select the period of time after ATSUI has finished all of it's
- * layout operations.
- }
- kATSULayoutOperationPostLayoutAdjustment = $00000020;
- kATSULayoutOperationAppleReserved = $FFFFFFC0;
- { ---------------------------------------------------------------------------- }
- {
- * ATSULayoutOperationCallbackStatus
- *
- * Summary:
- * One of these must be returned by a
- * ATSUDLayoutOperationOverrideUPP callback function in order to
- * indicate ATSUI's status.
- }
- type ATSULayoutOperationCallbackStatus = UInt32;
- const
- {
- * Return this if the callback function has totally handled the
- * operation which triggered the callback and does not need ATSUI to
- * run any further processing for the operation.
- }
- kATSULayoutOperationCallbackStatusHandled = $00000000;
- {
- * Return this if the callback function has not totally handled the
- * operation which triggered the callback and needs ATSUI to run it's
- * own processing.
- }
- kATSULayoutOperationCallbackStatusContinue = $00000001;
- { ---------------------------------------------------------------------------- }
- {
- * ATSLineLayoutOptions
- *
- * Summary:
- * ATSLineLayoutOptions are normally set in an ATSUTextLayout object
- * via the kATSULineLayoutOptionsTag layout control attribute. They
- * can also be set in an ATSLineLayoutParams structure.
- }
- type ATSLineLayoutOptions = UInt32;
- const
- {
- * No options specified.
- }
- kATSLineNoLayoutOptions = $00000000;
- {
- * This line option is no longer used.
- }
- kATSLineIsDisplayOnly = $00000001; { obsolete option }
- {
- * Specifies that no hangers to be formed on the line.
- }
- kATSLineHasNoHangers = $00000002;
- {
- * Specifies that no optical alignment to be performed on the line.
- }
- kATSLineHasNoOpticalAlignment = $00000004;
- {
- * Specifies that space charcters should not be treated as hangers.
- }
- kATSLineKeepSpacesOutOfMargin = $00000008;
- {
- * Specifies no post-compensation justification is to be performed.
- }
- kATSLineNoSpecialJustification = $00000010;
- {
- * Specifies that if the line is the last of a paragraph, it will not
- * get justified.
- }
- kATSLineLastNoJustification = $00000020;
- {
- * Specifies that the displayed line glyphs will adjust for device
- * metrics.
- }
- kATSLineFractDisable = $00000040;
- {
- * Specifies that the carets at the ends of the line will be
- * guarenteed to be perpendicular to the baseline.
- }
- kATSLineImposeNoAngleForEnds = $00000080;
- {
- * Highlights for the line end characters will be extended to 0 and
- * the specified line width.
- }
- kATSLineFillOutToWidth = $00000100;
- {
- * Specifies that the tab character width will be automatically
- * adjusted to fit the specified line width.
- }
- kATSLineTabAdjustEnabled = $00000200;
- {
- * Specifies that any leading value specified by a font will be
- * ignored.
- }
- kATSLineIgnoreFontLeading = $00000400;
- {
- * Specifies that ATS produce antialiased glyph images despite system
- * preferences or CGContext settings.
- }
- kATSLineApplyAntiAliasing = $00000800;
- {
- * Specifies that ATS turn-off antialiasing glyph imaging despite
- * system preferences or CGContext settings (negates
- * kATSLineApplyAntiAliasing bit if set).
- }
- kATSLineNoAntiAliasing = $00001000;
- {
- * Specifies that if the line width is not sufficient to hold all its
- * glyphs, glyph positions are allowed to extend beyond the line's
- * assigned width so negative justification is not used.
- }
- kATSLineDisableNegativeJustification = $00002000;
- {
- * Specifies that lines with any integer glyph positioning (due to
- * either any character non-antialiased or kATSLineFractDisable
- * specified), not automatically esthetically adjust individual
- * character positions while rendering to display.
- }
- kATSLineDisableAutoAdjustDisplayPos = $00004000;
- {
- * Specifies that rendering be done through Quickdraw (default
- * rendering in ATSUI is through CoreGraphics on MacOSX).
- }
- kATSLineUseQDRendering = $00008000;
- {
- * Specifies that any Justification operations will not be run.
- }
- kATSLineDisableAllJustification = $00010000;
- {
- * Specifies that any glyph morphing operations will not be run.
- }
- kATSLineDisableAllGlyphMorphing = $00020000;
- {
- * Specifies that any kerning adjustment operations will not be run.
- }
- kATSLineDisableAllKerningAdjustments = $00040000;
- {
- * Specifies that any baseline adjustment operations will not be run.
- }
- kATSLineDisableAllBaselineAdjustments = $00080000;
- {
- * Specifies that any tracking adjustment operations will not be run.
- }
- kATSLineDisableAllTrackingAdjustments = $00100000;
- {
- * Convenience constant for turning-off all adjustments.
- }
- kATSLineDisableAllLayoutOperations = kATSLineDisableAllJustification or kATSLineDisableAllGlyphMorphing or kATSLineDisableAllKerningAdjustments or kATSLineDisableAllBaselineAdjustments or kATSLineDisableAllTrackingAdjustments;
- {
- * Specifies to optimize for displaying text only. Note, rounded
- * device metrics will be used instead of fractional path metrics.
- }
- kATSLineUseDeviceMetrics = $01000000;
- {
- * Specifies that line breaking should occur at the nearest
- * character, not word. This could cause a word to be split among
- * multiple lines.
- }
- kATSLineBreakToNearestCharacter = $02000000;
- {
- * These bits are reserved by Apple and will result in a invalid
- * value error if attemped to set. Obsolete constants:
- }
- kATSLineAppleReserved = $FCE00000;
- { --------------------------------------------------------------------------- }
- {
- * ATSStyleRenderingOptions
- *
- * Summary:
- * ATSStyleRenderingOptions are set in the ATSUStyle object via the
- * attribute tag kATSUStyleRenderingOptions. They provide finer
- * control over how the style is rendered.
- }
- type ATSStyleRenderingOptions = UInt32;
- const
- {
- * No options specified.
- }
- kATSStyleNoOptions = $00000000;
- {
- * Specifies that ATS produce "unhinted" glyph outlines (default is
- * hinted glyph outlines).
- }
- kATSStyleNoHinting = $00000001;
- {
- * Specifies that ATS produce antialiased glyph images despite system
- * preferences or CGContext settings.
- }
- kATSStyleApplyAntiAliasing = $00000002;
- {
- * Specifies that ATS turn-off antialiasing glyph imaging despite
- * system preferences or CGContext settings (negates
- * kATSStyleApplyAntiAliasing bit if set).
- }
- kATSStyleNoAntiAliasing = $00000004;
- {
- * These bits are reserved by Apple and will result in a invalid
- * value error if attemped to set.
- }
- kATSStyleAppleReserved = $FFFFFFF8;
- {
- * (OBSOLETE) Specifies that ATS produce "hinted" glyph outlines (the
- * default behavior). THIS NAME IS OBSOLETE. DO NOT USE. It's only
- * left in for backwards compatibility.
- }
- kATSStyleApplyHints = kATSStyleNoOptions;
- {
- * ATSGlyphInfoFlags
- *
- * Summary:
- * ATSGlyphInfoFlags are set in the individual ATSLayoutRecord
- * structures and apply only to the ATSGlyphRef in that structure.
- * The are used by the layout engine to flag a glyph with specific
- * properties.
- }
- type ATSGlyphInfoFlags = UInt32;
- const
- {
- * These bits are Apple reserved and may result in an invalid value
- * error if attempted to set.
- }
- kATSGlyphInfoAppleReserved = $1FFBFFE8;
- {
- * The glyph attaches to another glyph.
- }
- kATSGlyphInfoIsAttachment = $80000000;
- {
- * The glyph can hang off left/top edge of line.
- }
- kATSGlyphInfoIsLTHanger = $40000000;
- {
- * The glyph can hang off right/bottom edge of line.
- }
- kATSGlyphInfoIsRBHanger = $20000000;
- {
- * The glyph is not really a glyph at all, but an end-marker designed
- * to allow the calculation of the previous glyph's advance.
- }
- kATSGlyphInfoTerminatorGlyph = $00080000;
- {
- * The glyph is a white space glyph.
- }
- kATSGlyphInfoIsWhiteSpace = $00040000;
- {
- * Glyph has a style specified imposed width (i.e. advance)
- }
- kATSGlyphInfoHasImposedWidth = $00000010;
- {
- * A three-bit mask, that can be used to get the size of the original
- * character that spawned this glyph. When a logical 'and' operation
- * with this mask and an ATSGlyphInfoFlags variable, it will yield
- * the size in bytes of the original character (0 - 7 bytes possible).
- }
- kATSGlyphInfoByteSizeMask = $00000007;
- { --------------------------------------------------------------------------- }
- {
- * Summary:
- * These values are passed into the ATSUGetGlyphBounds function to
- * indicate whether the width of the resulting typographic glyph
- * bounds will be determined using the caret origin, glyph origin in
- * device space, or glyph origin in fractional absolute positions
- }
- const
- {
- * Specifies that the width of the typographic glyph bounds will be
- * determined using the caret origin. The caret origin is halfway
- * between two characters.
- }
- kATSUseCaretOrigins = 0;
- {
- * Specifies that the width of the typographic glyph bounds will be
- * determined using the glyph origin in device space. This is useful
- * for adjusting text on the screen.
- }
- kATSUseDeviceOrigins = 1;
- {
- * Specifies that the width of the typographic glyph bounds will be
- * determined using the glyph origin in fractional absolute
- * positions, which are uncorrected for device display. This provides
- * the ideal position of laid-out text and is useful for scaling text
- * on the screen. This origin is also used to get the width of the
- * typographic bounding rectangle when you call ATSUMeasureText.
- }
- kATSUseFractionalOrigins = 2;
- kATSUseOriginFlags = 3;
- { --------------------------------------------------------------------------- }
- { STRUCTURED TYPES and related constants }
- { --------------------------------------------------------------------------- }
- {
- The ATSTrapezoid structure supplies a convenient container
- for glyph bounds in trapezoidal form.
- }
- type
- ATSTrapezoidPtr = ^ATSTrapezoid;
- ATSTrapezoid = record
- upperLeft: FixedPoint;
- upperRight: FixedPoint;
- lowerRight: FixedPoint;
- lowerLeft: FixedPoint;
- end;
- {
- The JustWidthDeltaEntryOverride structure specifies values for the grow and shrink case during
- justification, both on the left and on the right. It also contains flags. This particular structure
- is used for passing justification overrides to LLC. For further sfnt resource 'just' table
- constants and structures, see SFNTLayoutTypes.h.
- }
- ATSJustWidthDeltaEntryOverridePtr = ^ATSJustWidthDeltaEntryOverride;
- ATSJustWidthDeltaEntryOverride = record
- beforeGrowLimit: Fixed; { ems AW can grow by at most on LT }
- beforeShrinkLimit: Fixed; { ems AW can shrink by at most on LT }
- afterGrowLimit: Fixed; { ems AW can grow by at most on RB }
- afterShrinkLimit: Fixed; { ems AW can shrink by at most on RB }
- growFlags: JustificationFlags; { flags controlling grow case }
- shrinkFlags: JustificationFlags; { flags controlling shrink case }
- end;
- { The JustPriorityOverrides type is an array of 4 width delta records, one per priority level override. }
- ATSJustPriorityWidthDeltaOverrides = array [0..3] of ATSJustWidthDeltaEntryOverride;
- { --------------------------------------------------------------------------- }
- {
- * ATSULineRef
- *
- * Summary:
- * A reference to a line that is being laid out. This is passed into
- * the ATSUDirectLayoutOperationOverrideUPP callback function to be
- * used by the ATSUDirectGetLayoutDataArrayPtrFromLineRef function.
- * The only way to get a line ref is inside of the callback. The
- * only time the line ref is valid is inside of the callback.
- }
- type
- ATSULineRef = ^SInt32; { an opaque 32-bit type }
- { ---------------------------------------------------------------------------- }
- { DirectAccess Layout Callback Definitions }
- { ---------------------------------------------------------------------------- }
- {
- * ATSUDirectLayoutOperationOverrideProcPtr
- *
- * Summary:
- * Callback definition for a low-level adjustment routine hook.
- *
- * Discussion:
- * This callback can be set in an ATSUTextLayout object by setting
- * the attribute tag kATSULayoutOperationOverrideTag and passing in
- * a ATSULayoutOperationOverrideSpecifier structure into
- * ATSUSetLayoutAttribute. This callback will be called whenever an
- * ATSUI call triggers a re-layout for each operation it is
- * installed for. The operation that triggered the callback will be
- * set in the iCurrentOperation parameter. The callback function
- * defined by the developer is only required to do one thing: return
- * it's status to ATSUI as to what it has done. This is done via the
- * oCallbackStatus parameter. It needs to tell ATSUI if it had
- * handled the layout operation or if it still needs ATSUI to run
- * it's own processes. iOperationCallbackParameterPtr is there in
- * case there are ever any ATSUDirectLayoutOperationSelector which
- * require extra parameters to be passed into the callback function.
- * It is currently unused and will always be set to NULL. iRefCon is
- * the constant that is set in the ATSUTextLayout object that
- * spawned the operation by the ATSUSetTextLayoutRefCon() API.
- * Within the context of the callback itself, only a limited subset
- * of ATSUI APIs may be called. Basically, only the APIs that have
- * no chance of triggering a re-layout are allowed to be called. The
- * reason for this restriction is to prevent runaway recursion. Most
- * of the APIs that have "create", "get", or "copy" are safe. Any
- * attempt to call one of the restricted APIs will result in an
- * immediate return with the kATSUInvalidCallInsideCallbackErr
- * error. ATSULayoutOperationSelector and
- * ATSULayoutOperationCallbackStatus are defined in ATSLayoutTypes.i.
- }
- type ATSUDirectLayoutOperationOverrideProcPtr = function( iCurrentOperation: ATSULayoutOperationSelector; iLineRef: ATSULineRef; iRefCon: UInt32; iOperationCallbackParameterPtr: UnivPtr; var oCallbackStatus: ATSULayoutOperationCallbackStatus ): OSStatus;
- // Beats me what this translates to. If someone finds out they can tell me and we'll update it
- // typedef STACK_UPP_TYPE(ATSUDirectLayoutOperationOverrideProcPtr) ATSUDirectLayoutOperationOverrideUPP;
- type ATSUDirectLayoutOperationOverrideUPP = Ptr;
- {
- * NewATSUDirectLayoutOperationOverrideUPP()
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in ApplicationServices.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: available as macro/inline
- }
- // AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER
- function NewATSUDirectLayoutOperationOverrideUPP( userRoutine: ATSUDirectLayoutOperationOverrideProcPtr ): ATSUDirectLayoutOperationOverrideUPP; external name '_NewATSUDirectLayoutOperationOverrideUPP';
- {
- * DisposeATSUDirectLayoutOperationOverrideUPP()
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in ApplicationServices.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: available as macro/inline
- }
- // AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER
- procedure DisposeATSUDirectLayoutOperationOverrideUPP( userUPP: ATSUDirectLayoutOperationOverrideUPP ); external name '_DisposeATSUDirectLayoutOperationOverrideUPP';
- {
- * InvokeATSUDirectLayoutOperationOverrideUPP()
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in ApplicationServices.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: available as macro/inline
- }
- // AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER
- function InvokeATSUDirectLayoutOperationOverrideUPP( iCurrentOperation: ATSULayoutOperationSelector; iLineRef: ATSULineRef; iRefCon: UInt32; iOperationCallbackParameterPtr: UnivPtr; var oCallbackStatus: ATSULayoutOperationCallbackStatus; userUPP: ATSUDirectLayoutOperationOverrideUPP ): OSStatus; external name '_InvokeATSUDirectLayoutOperationOverrideUPP';
- { ---------------------------------------------------------------------------- }
- {
- * ATSULayoutOperationOverrideSpecifier
- *
- * Summary:
- * This structure is used to install a callback for one or more
- * ATSUI operations. To do this, simply passed one of these
- * structure into the ATSUSetLayoutControls call with the
- * kATSULayoutOperationOverrideTag tag.
- }
- type
- ATSULayoutOperationOverrideSpecifier = record
- {
- * A bitfield containing the selector for the operations in which the
- * callback will be installed for.
- }
- operationSelector: ATSULayoutOperationSelector;
- overrideUPP: ATSUDirectLayoutOperationOverrideUPP;
- end;
- ATSULayoutOperationOverrideSpecifierPtr = ^ATSULayoutOperationOverrideSpecifier;
- {$ALIGN MAC68K}
- end.
|