source-engine/common/quicktime_win32/AEDataModel.h
FluorescentCIAAfricanAmerican 3bf9df6b27 1
2020-04-22 12:56:21 -04:00

1325 lines
46 KiB
C

/*
File: AEDataModel.h
Contains: AppleEvent Data Model Interfaces.
Version: QuickTime 7.3
Copyright: (c) 2007 (c) 1996-2001 by Apple Computer, Inc., all rights reserved
Bugs?: For bug reports, consult the following page on
the World Wide Web:
http://developer.apple.com/bugreporter/
*/
#ifndef __AEDATAMODEL__
#define __AEDATAMODEL__
#ifndef __MACTYPES__
#include <MacTypes.h>
#endif
#ifndef __MIXEDMODE__
#include <MixedMode.h>
#endif
#if PRAGMA_ONCE
#pragma once
#endif
#ifdef __cplusplus
extern "C" {
#endif
#if PRAGMA_IMPORT
#pragma import on
#endif
#if PRAGMA_STRUCT_ALIGN
#pragma options align=mac68k
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(push, 2)
#elif PRAGMA_STRUCT_PACK
#pragma pack(2)
#endif
/* Apple event descriptor types */
enum {
typeBoolean = FOUR_CHAR_CODE('bool'),
typeChar = FOUR_CHAR_CODE('TEXT')
};
/* Preferred numeric Apple event descriptor types */
enum {
typeSInt16 = FOUR_CHAR_CODE('shor'),
typeSInt32 = FOUR_CHAR_CODE('long'),
typeUInt32 = FOUR_CHAR_CODE('magn'),
typeSInt64 = FOUR_CHAR_CODE('comp'),
typeIEEE32BitFloatingPoint = FOUR_CHAR_CODE('sing'),
typeIEEE64BitFloatingPoint = FOUR_CHAR_CODE('doub'),
type128BitFloatingPoint = FOUR_CHAR_CODE('ldbl'),
typeDecimalStruct = FOUR_CHAR_CODE('decm')
};
/* Non-preferred Apple event descriptor types */
enum {
typeSMInt = typeSInt16,
typeShortInteger = typeSInt16,
typeInteger = typeSInt32,
typeLongInteger = typeSInt32,
typeMagnitude = typeUInt32,
typeComp = typeSInt64,
typeSMFloat = typeIEEE32BitFloatingPoint,
typeShortFloat = typeIEEE32BitFloatingPoint,
typeFloat = typeIEEE64BitFloatingPoint,
typeLongFloat = typeIEEE64BitFloatingPoint,
typeExtended = FOUR_CHAR_CODE('exte')
};
/* More Apple event descriptor types */
enum {
typeAEList = FOUR_CHAR_CODE('list'),
typeAERecord = FOUR_CHAR_CODE('reco'),
typeAppleEvent = FOUR_CHAR_CODE('aevt'),
typeEventRecord = FOUR_CHAR_CODE('evrc'),
typeTrue = FOUR_CHAR_CODE('true'),
typeFalse = FOUR_CHAR_CODE('fals'),
typeAlias = FOUR_CHAR_CODE('alis'),
typeEnumerated = FOUR_CHAR_CODE('enum'),
typeType = FOUR_CHAR_CODE('type'),
typeAppParameters = FOUR_CHAR_CODE('appa'),
typeProperty = FOUR_CHAR_CODE('prop'),
typeFSS = FOUR_CHAR_CODE('fss '),
typeFSRef = FOUR_CHAR_CODE('fsrf'),
typeFileURL = FOUR_CHAR_CODE('furl'),
typeKeyword = FOUR_CHAR_CODE('keyw'),
typeSectionH = FOUR_CHAR_CODE('sect'),
typeWildCard = FOUR_CHAR_CODE('****'),
typeApplSignature = FOUR_CHAR_CODE('sign'),
typeQDRectangle = FOUR_CHAR_CODE('qdrt'),
typeFixed = FOUR_CHAR_CODE('fixd'),
typeProcessSerialNumber = FOUR_CHAR_CODE('psn '),
typeApplicationURL = FOUR_CHAR_CODE('aprl'),
typeNull = FOUR_CHAR_CODE('null') /* null or nonexistent data */
};
#if CALL_NOT_IN_CARBON
/* Deprecated addressing modes under Carbon */
enum {
typeSessionID = FOUR_CHAR_CODE('ssid'),
typeTargetID = FOUR_CHAR_CODE('targ'),
typeDispatcherID = FOUR_CHAR_CODE('dspt')
};
#endif /* CALL_NOT_IN_CARBON */
/* Keywords for Apple event attributes */
enum {
keyTransactionIDAttr = FOUR_CHAR_CODE('tran'),
keyReturnIDAttr = FOUR_CHAR_CODE('rtid'),
keyEventClassAttr = FOUR_CHAR_CODE('evcl'),
keyEventIDAttr = FOUR_CHAR_CODE('evid'),
keyAddressAttr = FOUR_CHAR_CODE('addr'),
keyOptionalKeywordAttr = FOUR_CHAR_CODE('optk'),
keyTimeoutAttr = FOUR_CHAR_CODE('timo'),
keyInteractLevelAttr = FOUR_CHAR_CODE('inte'), /* this attribute is read only - will be set in AESend */
keyEventSourceAttr = FOUR_CHAR_CODE('esrc'), /* this attribute is read only - returned as typeShortInteger */
keyMissedKeywordAttr = FOUR_CHAR_CODE('miss'), /* this attribute is read only */
keyOriginalAddressAttr = FOUR_CHAR_CODE('from'), /* new in 1.0.1 */
keyAcceptTimeoutAttr = FOUR_CHAR_CODE('actm') /* new for Mac OS X */
};
/* Constants used for specifying the factoring of AEDescLists. */
enum {
kAEDescListFactorNone = 0,
kAEDescListFactorType = 4,
kAEDescListFactorTypeAndSize = 8
};
/* Constants used creating an AppleEvent */
enum {
/* Constant for the returnID param of AECreateAppleEvent */
kAutoGenerateReturnID = -1, /* AECreateAppleEvent will generate a session-unique ID */
/* Constant for transaction ID's */
kAnyTransactionID = 0 /* no transaction is in use */
};
/* Apple event manager data types */
typedef ResType DescType;
typedef FourCharCode AEKeyword;
#if OPAQUE_TOOLBOX_STRUCTS
typedef struct OpaqueAEDataStorageType* AEDataStorageType;
#else
typedef Ptr AEDataStorageType;
#endif /* OPAQUE_TOOLBOX_STRUCTS */
typedef AEDataStorageType * AEDataStorage;
struct AEDesc {
DescType descriptorType;
AEDataStorage dataHandle;
};
typedef struct AEDesc AEDesc;
typedef AEDesc * AEDescPtr;
struct AEKeyDesc {
AEKeyword descKey;
AEDesc descContent;
};
typedef struct AEKeyDesc AEKeyDesc;
/* a list of AEDesc's is a special kind of AEDesc */
typedef AEDesc AEDescList;
/* AERecord is a list of keyworded AEDesc's */
typedef AEDescList AERecord;
/* an AEDesc which contains address data */
typedef AEDesc AEAddressDesc;
/* an AERecord that contains an AppleEvent, and related data types */
typedef AERecord AppleEvent;
typedef AppleEvent * AppleEventPtr;
typedef SInt16 AEReturnID;
typedef SInt32 AETransactionID;
typedef FourCharCode AEEventClass;
typedef FourCharCode AEEventID;
typedef SInt8 AEArrayType;
enum {
kAEDataArray = 0,
kAEPackedArray = 1,
kAEDescArray = 3,
kAEKeyDescArray = 4
};
enum {
kAEHandleArray = 2
};
union AEArrayData {
short kAEDataArray[1];
char kAEPackedArray[1];
Handle kAEHandleArray[1];
AEDesc kAEDescArray[1];
AEKeyDesc kAEKeyDescArray[1];
};
typedef union AEArrayData AEArrayData;
typedef AEArrayData * AEArrayDataPointer;
/**************************************************************************
These constants are used by AEMach and AEInteraction APIs. They are not
strictly part of the data format, but are declared here due to layering.
**************************************************************************/
typedef SInt16 AESendPriority;
enum {
kAENormalPriority = 0x00000000, /* post message at the end of the event queue */
kAEHighPriority = 0x00000001 /* post message at the front of the event queue (same as nAttnMsg) */
};
typedef SInt32 AESendMode;
enum {
kAENoReply = 0x00000001, /* sender doesn't want a reply to event */
kAEQueueReply = 0x00000002, /* sender wants a reply but won't wait */
kAEWaitReply = 0x00000003, /* sender wants a reply and will wait */
kAEDontReconnect = 0x00000080, /* don't reconnect if there is a sessClosedErr from PPCToolbox */
kAEWantReceipt = 0x00000200, /* (nReturnReceipt) sender wants a receipt of message */
kAENeverInteract = 0x00000010, /* server should not interact with user */
kAECanInteract = 0x00000020, /* server may try to interact with user */
kAEAlwaysInteract = 0x00000030, /* server should always interact with user where appropriate */
kAECanSwitchLayer = 0x00000040, /* interaction may switch layer */
kAEDontRecord = 0x00001000, /* don't record this event - available only in vers 1.0.1 and greater */
kAEDontExecute = 0x00002000, /* don't send the event for recording - available only in vers 1.0.1 and greater */
kAEProcessNonReplyEvents = 0x00008000 /* allow processing of non-reply events while awaiting synchronous AppleEvent reply */
};
/* Constants for timeout durations */
enum {
kAEDefaultTimeout = -1, /* timeout value determined by AEM */
kNoTimeOut = -2 /* wait until reply comes back, however long it takes */
};
/**************************************************************************
These calls are used to set up and modify the coercion dispatch table.
**************************************************************************/
typedef CALLBACK_API( OSErr , AECoerceDescProcPtr )(const AEDesc *fromDesc, DescType toType, long handlerRefcon, AEDesc *toDesc);
typedef CALLBACK_API( OSErr , AECoercePtrProcPtr )(DescType typeCode, const void *dataPtr, Size dataSize, DescType toType, long handlerRefcon, AEDesc *result);
typedef STACK_UPP_TYPE(AECoerceDescProcPtr) AECoerceDescUPP;
typedef STACK_UPP_TYPE(AECoercePtrProcPtr) AECoercePtrUPP;
/*
* NewAECoerceDescUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( AECoerceDescUPP )
NewAECoerceDescUPP(AECoerceDescProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppAECoerceDescProcInfo = 0x00003FE0 }; /* pascal 2_bytes Func(4_bytes, 4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(AECoerceDescUPP) NewAECoerceDescUPP(AECoerceDescProcPtr userRoutine) { return (AECoerceDescUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppAECoerceDescProcInfo, GetCurrentArchitecture()); }
#else
#define NewAECoerceDescUPP(userRoutine) (AECoerceDescUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppAECoerceDescProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewAECoercePtrUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( AECoercePtrUPP )
NewAECoercePtrUPP(AECoercePtrProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppAECoercePtrProcInfo = 0x0003FFE0 }; /* pascal 2_bytes Func(4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(AECoercePtrUPP) NewAECoercePtrUPP(AECoercePtrProcPtr userRoutine) { return (AECoercePtrUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppAECoercePtrProcInfo, GetCurrentArchitecture()); }
#else
#define NewAECoercePtrUPP(userRoutine) (AECoercePtrUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppAECoercePtrProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* DisposeAECoerceDescUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeAECoerceDescUPP(AECoerceDescUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeAECoerceDescUPP(AECoerceDescUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeAECoerceDescUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeAECoercePtrUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeAECoercePtrUPP(AECoercePtrUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeAECoercePtrUPP(AECoercePtrUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeAECoercePtrUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* InvokeAECoerceDescUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSErr )
InvokeAECoerceDescUPP(
const AEDesc * fromDesc,
DescType toType,
long handlerRefcon,
AEDesc * toDesc,
AECoerceDescUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(OSErr) InvokeAECoerceDescUPP(const AEDesc * fromDesc, DescType toType, long handlerRefcon, AEDesc * toDesc, AECoerceDescUPP userUPP) { return (OSErr)CALL_FOUR_PARAMETER_UPP(userUPP, uppAECoerceDescProcInfo, fromDesc, toType, handlerRefcon, toDesc); }
#else
#define InvokeAECoerceDescUPP(fromDesc, toType, handlerRefcon, toDesc, userUPP) (OSErr)CALL_FOUR_PARAMETER_UPP((userUPP), uppAECoerceDescProcInfo, (fromDesc), (toType), (handlerRefcon), (toDesc))
#endif
#endif
/*
* InvokeAECoercePtrUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSErr )
InvokeAECoercePtrUPP(
DescType typeCode,
const void * dataPtr,
Size dataSize,
DescType toType,
long handlerRefcon,
AEDesc * result,
AECoercePtrUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(OSErr) InvokeAECoercePtrUPP(DescType typeCode, const void * dataPtr, Size dataSize, DescType toType, long handlerRefcon, AEDesc * result, AECoercePtrUPP userUPP) { return (OSErr)CALL_SIX_PARAMETER_UPP(userUPP, uppAECoercePtrProcInfo, typeCode, dataPtr, dataSize, toType, handlerRefcon, result); }
#else
#define InvokeAECoercePtrUPP(typeCode, dataPtr, dataSize, toType, handlerRefcon, result, userUPP) (OSErr)CALL_SIX_PARAMETER_UPP((userUPP), uppAECoercePtrProcInfo, (typeCode), (dataPtr), (dataSize), (toType), (handlerRefcon), (result))
#endif
#endif
#if CALL_NOT_IN_CARBON || OLDROUTINENAMES
/* support for pre-Carbon UPP routines: New...Proc and Call...Proc */
#define NewAECoerceDescProc(userRoutine) NewAECoerceDescUPP(userRoutine)
#define NewAECoercePtrProc(userRoutine) NewAECoercePtrUPP(userRoutine)
#define CallAECoerceDescProc(userRoutine, fromDesc, toType, handlerRefcon, toDesc) InvokeAECoerceDescUPP(fromDesc, toType, handlerRefcon, toDesc, userRoutine)
#define CallAECoercePtrProc(userRoutine, typeCode, dataPtr, dataSize, toType, handlerRefcon, result) InvokeAECoercePtrUPP(typeCode, dataPtr, dataSize, toType, handlerRefcon, result, userRoutine)
#endif /* CALL_NOT_IN_CARBON */
/* a AECoercionHandlerUPP is by default a AECoerceDescUPP. If you are registering a
Ptr based coercion handler you will have to add a cast to AECoerceDescUPP from
your AECoercePtrUPP type. A future release of the interfaces will fix this by
introducing seperate Desc and Ptr coercion handler installation/remove/query routines. */
typedef AECoerceDescUPP AECoercionHandlerUPP;
/*
* AEInstallCoercionHandler()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEInstallCoercionHandler(
DescType fromType,
DescType toType,
AECoercionHandlerUPP handler,
long handlerRefcon,
Boolean fromTypeIsDesc,
Boolean isSysHandler) THREEWORDINLINE(0x303C, 0x0A22, 0xA816);
/*
* AERemoveCoercionHandler()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AERemoveCoercionHandler(
DescType fromType,
DescType toType,
AECoercionHandlerUPP handler,
Boolean isSysHandler) THREEWORDINLINE(0x303C, 0x0723, 0xA816);
/*
* AEGetCoercionHandler()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetCoercionHandler(
DescType fromType,
DescType toType,
AECoercionHandlerUPP * handler,
long * handlerRefcon,
Boolean * fromTypeIsDesc,
Boolean isSysHandler) THREEWORDINLINE(0x303C, 0x0B24, 0xA816);
/**************************************************************************
The following calls provide for a coercion interface.
**************************************************************************/
/*
* AECoercePtr()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AECoercePtr(
DescType typeCode,
const void * dataPtr,
Size dataSize,
DescType toType,
AEDesc * result) THREEWORDINLINE(0x303C, 0x0A02, 0xA816);
/*
* AECoerceDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AECoerceDesc(
const AEDesc * theAEDesc,
DescType toType,
AEDesc * result) THREEWORDINLINE(0x303C, 0x0603, 0xA816);
/**************************************************************************
The following calls apply to any AEDesc. Every 'result' descriptor is
created for you, so you will be responsible for memory management
(including disposing) of the descriptors so created.
**************************************************************************/
/* because AEDescs are opaque under Carbon, this AEInitializeDesc provides a
'clean' way of initializating them to be empty. */
/*
* AEInitializeDesc()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
AEInitializeDesc(AEDesc * desc);
#ifdef __cplusplus
inline void AEInitializeDescInline(AEDesc* d) { d->descriptorType = typeNull; d->dataHandle = NULL; };
#else
#define AEInitializeDescInline(__d) do { AEDesc* d = __d; d->descriptorType = typeNull; d->dataHandle = NULL; } while (0)
#endif
/*
* AECreateDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AECreateDesc(
DescType typeCode,
const void * dataPtr,
Size dataSize,
AEDesc * result) THREEWORDINLINE(0x303C, 0x0825, 0xA816);
/*
* AEDisposeDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEDisposeDesc(AEDesc * theAEDesc) THREEWORDINLINE(0x303C, 0x0204, 0xA816);
/*
* AEDuplicateDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEDuplicateDesc(
const AEDesc * theAEDesc,
AEDesc * result) THREEWORDINLINE(0x303C, 0x0405, 0xA816);
/*
* Create an AEDesc with memory "borrowed" from the application. The
* data passed in *must* be immutable and not freed until the Dispose
* callback is made.
* The dispose callback may be made at any time, including during the
* creation of the descriptor.
* If possible, the descriptor will be copied to the address space of
* any recipient process using virtual memory APIs and avoid an
* actual memory copy.
*/
typedef CALLBACK_API( void , AEDisposeExternalProcPtr )(const void *dataPtr, Size dataLength, long refcon);
typedef STACK_UPP_TYPE(AEDisposeExternalProcPtr) AEDisposeExternalUPP;
/*
* AECreateDescFromExternalPtr()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( OSStatus )
AECreateDescFromExternalPtr(
OSType descriptorType,
const void * dataPtr,
Size dataLength,
AEDisposeExternalUPP disposeCallback,
long disposeRefcon,
AEDesc * theDesc);
/**************************************************************************
The following calls apply to AEDescList. Since AEDescList is a subtype of
AEDesc, the calls in the previous section can also be used for AEDescList.
All list and array indices are 1-based. If the data was greater than
maximumSize in the routines below, then actualSize will be greater than
maximumSize, but only maximumSize bytes will actually be retrieved.
**************************************************************************/
/*
* AECreateList()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AECreateList(
const void * factoringPtr,
Size factoredSize,
Boolean isRecord,
AEDescList * resultList) THREEWORDINLINE(0x303C, 0x0706, 0xA816);
/*
* AECountItems()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AECountItems(
const AEDescList * theAEDescList,
long * theCount) THREEWORDINLINE(0x303C, 0x0407, 0xA816);
/*
* AEPutPtr()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEPutPtr(
AEDescList * theAEDescList,
long index,
DescType typeCode,
const void * dataPtr,
Size dataSize) THREEWORDINLINE(0x303C, 0x0A08, 0xA816);
/*
* AEPutDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEPutDesc(
AEDescList * theAEDescList,
long index,
const AEDesc * theAEDesc) THREEWORDINLINE(0x303C, 0x0609, 0xA816);
/*
* AEGetNthPtr()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetNthPtr(
const AEDescList * theAEDescList,
long index,
DescType desiredType,
AEKeyword * theAEKeyword,
DescType * typeCode,
void * dataPtr,
Size maximumSize,
Size * actualSize) THREEWORDINLINE(0x303C, 0x100A, 0xA816);
/*
* AEGetNthDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetNthDesc(
const AEDescList * theAEDescList,
long index,
DescType desiredType,
AEKeyword * theAEKeyword,
AEDesc * result) THREEWORDINLINE(0x303C, 0x0A0B, 0xA816);
/*
* AESizeOfNthItem()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AESizeOfNthItem(
const AEDescList * theAEDescList,
long index,
DescType * typeCode,
Size * dataSize) THREEWORDINLINE(0x303C, 0x082A, 0xA816);
/*
* AEGetArray()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetArray(
const AEDescList * theAEDescList,
AEArrayType arrayType,
AEArrayDataPointer arrayPtr,
Size maximumSize,
DescType * itemType,
Size * itemSize,
long * itemCount) THREEWORDINLINE(0x303C, 0x0D0C, 0xA816);
/*
* AEPutArray()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEPutArray(
AEDescList * theAEDescList,
AEArrayType arrayType,
const AEArrayData * arrayPtr,
DescType itemType,
Size itemSize,
long itemCount) THREEWORDINLINE(0x303C, 0x0B0D, 0xA816);
/*
* AEDeleteItem()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEDeleteItem(
AEDescList * theAEDescList,
long index) THREEWORDINLINE(0x303C, 0x040E, 0xA816);
/**************************************************************************
The following calls apply to AERecord. Since AERecord is a subtype of
AEDescList, the calls in the previous sections can also be used for
AERecord an AERecord can be created by using AECreateList with isRecord
set to true.
**************************************************************************/
/*************************************************************************
AERecords can have an abitrary descriptorType. This allows you to
check if desc is truly an AERecord
************************************************************************/
/*
* AECheckIsRecord()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( Boolean )
AECheckIsRecord(const AEDesc * theDesc);
/*
Note: The following #defines map "key" calls on AERecords into "param" calls on
AppleEvents. Although no errors are currently returned if AERecords are
passed to "param" calls and AppleEvents to "key" calls, the behavior of
this type of API-mixing is not explicitly documented in Inside Macintosh.
It just happens that the "key" calls have the same functionality as their
"param" counterparts. Since none of the "key" calls are currently available
in the PowerPC IntefaceLib, the #defines exploit the fact that "key" and
"param" routines can be used interchangeably, and makes sure that every
invocation of a "key" API becomes an invocation of a "param" API.
*/
#define AEPutKeyPtr(theAERecord, theAEKeyword, typeCode, dataPtr, dataSize) \
AEPutParamPtr((theAERecord), (theAEKeyword), (typeCode), (dataPtr), (dataSize))
#define AEPutKeyDesc(theAERecord, theAEKeyword, theAEDesc) \
AEPutParamDesc((theAERecord), (theAEKeyword), (theAEDesc))
#define AEGetKeyPtr(theAERecord, theAEKeyword, desiredType, typeCode, dataPtr, maxSize, actualSize) \
AEGetParamPtr((theAERecord), (theAEKeyword), (desiredType), (typeCode), (dataPtr), (maxSize), (actualSize))
#define AEGetKeyDesc(theAERecord, theAEKeyword, desiredType, result) \
AEGetParamDesc((theAERecord), (theAEKeyword), (desiredType), (result))
#define AESizeOfKeyDesc(theAERecord, theAEKeyword, typeCode, dataSize) \
AESizeOfParam((theAERecord), (theAEKeyword), (typeCode), (dataSize))
#define AEDeleteKeyDesc(theAERecord, theAEKeyword) \
AEDeleteParam((theAERecord), (theAEKeyword))
/**************************************************************************
The following calls create and manipulate the AppleEvent data type.
**************************************************************************/
/*
* AECreateAppleEvent()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AECreateAppleEvent(
AEEventClass theAEEventClass,
AEEventID theAEEventID,
const AEAddressDesc * target,
AEReturnID returnID,
AETransactionID transactionID,
AppleEvent * result) THREEWORDINLINE(0x303C, 0x0B14, 0xA816);
/**************************************************************************
The following calls are used to pack and unpack parameters from records
of type AppleEvent. Since AppleEvent is a subtype of AERecord, the calls
in the previous sections can also be used for variables of type
AppleEvent. The next six calls are in fact identical to the six calls
for AERecord.
**************************************************************************/
/*
* AEPutParamPtr()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEPutParamPtr(
AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
DescType typeCode,
const void * dataPtr,
Size dataSize) THREEWORDINLINE(0x303C, 0x0A0F, 0xA816);
/*
* AEPutParamDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEPutParamDesc(
AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
const AEDesc * theAEDesc) THREEWORDINLINE(0x303C, 0x0610, 0xA816);
/*
* AEGetParamPtr()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetParamPtr(
const AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
DescType desiredType,
DescType * typeCode,
void * dataPtr,
Size maximumSize,
Size * actualSize) THREEWORDINLINE(0x303C, 0x0E11, 0xA816);
/*
* AEGetParamDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetParamDesc(
const AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
DescType desiredType,
AEDesc * result) THREEWORDINLINE(0x303C, 0x0812, 0xA816);
/*
* AESizeOfParam()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AESizeOfParam(
const AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
DescType * typeCode,
Size * dataSize) THREEWORDINLINE(0x303C, 0x0829, 0xA816);
/*
* AEDeleteParam()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEDeleteParam(
AppleEvent * theAppleEvent,
AEKeyword theAEKeyword) THREEWORDINLINE(0x303C, 0x0413, 0xA816);
/**************************************************************************
The following calls also apply to type AppleEvent. Message attributes are
far more restricted, and can only be accessed through the following 5
calls. The various list and record routines cannot be used to access the
attributes of an event.
**************************************************************************/
/*
* AEGetAttributePtr()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetAttributePtr(
const AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
DescType desiredType,
DescType * typeCode,
void * dataPtr,
Size maximumSize,
Size * actualSize) THREEWORDINLINE(0x303C, 0x0E15, 0xA816);
/*
* AEGetAttributeDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetAttributeDesc(
const AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
DescType desiredType,
AEDesc * result) THREEWORDINLINE(0x303C, 0x0826, 0xA816);
/*
* AESizeOfAttribute()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AESizeOfAttribute(
const AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
DescType * typeCode,
Size * dataSize) THREEWORDINLINE(0x303C, 0x0828, 0xA816);
/*
* AEPutAttributePtr()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEPutAttributePtr(
AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
DescType typeCode,
const void * dataPtr,
Size dataSize) THREEWORDINLINE(0x303C, 0x0A16, 0xA816);
/*
* AEPutAttributeDesc()
*
* Availability:
* Non-Carbon CFM: in InterfaceLib 7.1 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEPutAttributeDesc(
AppleEvent * theAppleEvent,
AEKeyword theAEKeyword,
const AEDesc * theAEDesc) THREEWORDINLINE(0x303C, 0x0627, 0xA816);
/**************************************************************************
AppleEvent Serialization Support
AESizeOfFlattenedDesc, AEFlattenDesc, AEUnflattenDesc
These calls will work for all AppleEvent data types and between different
versions of the OS (including between Mac OS 9 and X)
Basic types, AEDesc, AEList and AERecord are OK, but AppleEvent records
themselves may not be reliably flattened for storage.
**************************************************************************/
/*
AEFlattenDesc
Returns the amount of buffer space needed to flatten the
AEDesc. Call this before AEFlattenDesc to make sure your
buffer has enough room for the operation.
*/
/*
* AESizeOfFlattenedDesc()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( Size )
AESizeOfFlattenedDesc(const AEDesc * theAEDesc);
/*
AEFlattenDesc
Fills a buffer with a flattened representation of the
AEDesc and returns the amount of buffer used in actualSize.
If bufferSize was too small it returns errAEBufferTooSmall
(-1741) and does not fill in any of the buffer. The resulting
buffer is only useful with an AEUnflattenDesc call.
Note: if you pass a NULL buffer pointer it returns noErr but
fills in the actualSize field anyway.
*/
/*
* AEFlattenDesc()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSStatus )
AEFlattenDesc(
const AEDesc * theAEDesc,
Ptr buffer,
Size bufferSize,
Size * actualSize);
/*
AEUnflattenDesc
Allocates an AEDesc (given a Null Desc) given a flattened
data buffer. It assumes it was given a good buffer filled
in by AEFlattenDesc. It returns paramErr if it discovers
something fishy about the buffer.
*/
/*
* AEUnflattenDesc()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSStatus )
AEUnflattenDesc(
Ptr buffer,
AEDesc * result);
/**************************************************************************
The following calls are necessary to deal with opaque data in AEDescs, because the
traditional way of dealing with a basic AEDesc has been to dereference the dataHandle
directly. This is not supported under Carbon.
**************************************************************************/
#if ACCESSOR_CALLS_ARE_FUNCTIONS
/*
AEGetDescData no longer supports automatic coercion. If you'd like to
coerce the descriptor use AECoerceDesc.
*/
/*
* AEGetDescData()
*
* Availability:
* Non-Carbon CFM: in CarbonAccessors.o 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEGetDescData(
const AEDesc * theAEDesc,
void * dataPtr,
Size maximumSize);
/*
* AEGetDescDataSize()
*
* Availability:
* Non-Carbon CFM: in CarbonAccessors.o 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( Size )
AEGetDescDataSize(const AEDesc * theAEDesc);
/*
* AEReplaceDescData()
*
* Availability:
* Non-Carbon CFM: in CarbonAccessors.o 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
AEReplaceDescData(
DescType typeCode,
const void * dataPtr,
Size dataSize,
AEDesc * theAEDesc);
#endif /* ACCESSOR_CALLS_ARE_FUNCTIONS */
/*
* Retrieve a range of bytes from an AEDesc. This obviates the need
* to retrieve the entire data from the event using AEGetDescData.
* This is only valid for data type AEDescs. If the requested length
* and offset are such that they do not fit entirely with the data of the
* desc, errAEBufferTooSmall is returned.
*/
/*
* AEGetDescDataRange()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( OSStatus )
AEGetDescDataRange(
const AEDesc * dataDesc,
void * buffer,
Size offset,
Size length);
/**************************************************************************
A AEEventHandler is installed to process an AppleEvent
**************************************************************************/
typedef CALLBACK_API( OSErr , AEEventHandlerProcPtr )(const AppleEvent *theAppleEvent, AppleEvent *reply, long handlerRefcon);
typedef STACK_UPP_TYPE(AEEventHandlerProcPtr) AEEventHandlerUPP;
/*
* NewAEDisposeExternalUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( AEDisposeExternalUPP )
NewAEDisposeExternalUPP(AEDisposeExternalProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppAEDisposeExternalProcInfo = 0x00000FC0 }; /* pascal no_return_value Func(4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(AEDisposeExternalUPP) NewAEDisposeExternalUPP(AEDisposeExternalProcPtr userRoutine) { return (AEDisposeExternalUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppAEDisposeExternalProcInfo, GetCurrentArchitecture()); }
#else
#define NewAEDisposeExternalUPP(userRoutine) (AEDisposeExternalUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppAEDisposeExternalProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewAEEventHandlerUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( AEEventHandlerUPP )
NewAEEventHandlerUPP(AEEventHandlerProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppAEEventHandlerProcInfo = 0x00000FE0 }; /* pascal 2_bytes Func(4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(AEEventHandlerUPP) NewAEEventHandlerUPP(AEEventHandlerProcPtr userRoutine) { return (AEEventHandlerUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppAEEventHandlerProcInfo, GetCurrentArchitecture()); }
#else
#define NewAEEventHandlerUPP(userRoutine) (AEEventHandlerUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppAEEventHandlerProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* DisposeAEDisposeExternalUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
DisposeAEDisposeExternalUPP(AEDisposeExternalUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeAEDisposeExternalUPP(AEDisposeExternalUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeAEDisposeExternalUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeAEEventHandlerUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeAEEventHandlerUPP(AEEventHandlerUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeAEEventHandlerUPP(AEEventHandlerUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeAEEventHandlerUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* InvokeAEDisposeExternalUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
* Mac OS X: in version 10.2 and later
*/
EXTERN_API_C( void )
InvokeAEDisposeExternalUPP(
const void * dataPtr,
Size dataLength,
long refcon,
AEDisposeExternalUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeAEDisposeExternalUPP(const void * dataPtr, Size dataLength, long refcon, AEDisposeExternalUPP userUPP) { CALL_THREE_PARAMETER_UPP(userUPP, uppAEDisposeExternalProcInfo, dataPtr, dataLength, refcon); }
#else
#define InvokeAEDisposeExternalUPP(dataPtr, dataLength, refcon, userUPP) CALL_THREE_PARAMETER_UPP((userUPP), uppAEDisposeExternalProcInfo, (dataPtr), (dataLength), (refcon))
#endif
#endif
/*
* InvokeAEEventHandlerUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSErr )
InvokeAEEventHandlerUPP(
const AppleEvent * theAppleEvent,
AppleEvent * reply,
long handlerRefcon,
AEEventHandlerUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(OSErr) InvokeAEEventHandlerUPP(const AppleEvent * theAppleEvent, AppleEvent * reply, long handlerRefcon, AEEventHandlerUPP userUPP) { return (OSErr)CALL_THREE_PARAMETER_UPP(userUPP, uppAEEventHandlerProcInfo, theAppleEvent, reply, handlerRefcon); }
#else
#define InvokeAEEventHandlerUPP(theAppleEvent, reply, handlerRefcon, userUPP) (OSErr)CALL_THREE_PARAMETER_UPP((userUPP), uppAEEventHandlerProcInfo, (theAppleEvent), (reply), (handlerRefcon))
#endif
#endif
#if CALL_NOT_IN_CARBON || OLDROUTINENAMES
/* support for pre-Carbon UPP routines: New...Proc and Call...Proc */
#define NewAEDisposeExternalProc(userRoutine) NewAEDisposeExternalUPP(userRoutine)
#define NewAEEventHandlerProc(userRoutine) NewAEEventHandlerUPP(userRoutine)
#define CallAEDisposeExternalProc(userRoutine, dataPtr, dataLength, refcon) InvokeAEDisposeExternalUPP(dataPtr, dataLength, refcon, userRoutine)
#define CallAEEventHandlerProc(userRoutine, theAppleEvent, reply, handlerRefcon) InvokeAEEventHandlerUPP(theAppleEvent, reply, handlerRefcon, userRoutine)
#endif /* CALL_NOT_IN_CARBON */
#if PRAGMA_STRUCT_ALIGN
#pragma options align=reset
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(pop)
#elif PRAGMA_STRUCT_PACK
#pragma pack()
#endif
#ifdef PRAGMA_IMPORT_OFF
#pragma import off
#elif PRAGMA_IMPORT
#pragma import reset
#endif
#ifdef __cplusplus
}
#endif
#endif /* __AEDATAMODEL__ */