123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527 |
- {
- File: LaunchServices/LSOpen.h
-
- Contains: Public interfaces for LaunchServices.framework
-
- Version: LaunchServices-360.3~1
-
- Copyright: © 2001-2008 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
-
- }
- { Pascal Translation: Gorazd Krosl <[email protected]>, October 2009 }
- {
- Modified for use with Free Pascal
- Version 308
- Please report any bugs to <[email protected]>
- }
- {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
- {$mode macpas}
- {$packenum 1}
- {$macro on}
- {$inline on}
- {$calling mwpascal}
- unit LSOpen;
- interface
- {$setc UNIVERSAL_INTERFACES_VERSION := $0400}
- {$setc GAP_INTERFACES_VERSION := $0308}
- {$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 CPUPOWERPC32}
- {$setc __ppc__ := 1}
- {$elsec}
- {$setc __ppc__ := 0}
- {$endc}
- {$ifc not defined __ppc64__ and defined CPUPOWERPC64}
- {$setc __ppc64__ := 1}
- {$elsec}
- {$setc __ppc64__ := 0}
- {$endc}
- {$ifc not defined __i386__ and defined CPUI386}
- {$setc __i386__ := 1}
- {$elsec}
- {$setc __i386__ := 0}
- {$endc}
- {$ifc not defined __x86_64__ and defined CPUX86_64}
- {$setc __x86_64__ := 1}
- {$elsec}
- {$setc __x86_64__ := 0}
- {$endc}
- {$ifc not defined __arm__ and defined CPUARM}
- {$setc __arm__ := 1}
- {$elsec}
- {$setc __arm__ := 0}
- {$endc}
- {$ifc defined cpu64}
- {$setc __LP64__ := 1}
- {$elsec}
- {$setc __LP64__ := 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_PPC64 := FALSE}
- {$setc TARGET_CPU_X86 := FALSE}
- {$setc TARGET_CPU_X86_64 := FALSE}
- {$setc TARGET_CPU_ARM := FALSE}
- {$setc TARGET_OS_MAC := TRUE}
- {$setc TARGET_OS_IPHONE := FALSE}
- {$setc TARGET_IPHONE_SIMULATOR := FALSE}
- {$elifc defined __ppc64__ and __ppc64__}
- {$setc TARGET_CPU_PPC := FALSE}
- {$setc TARGET_CPU_PPC64 := TRUE}
- {$setc TARGET_CPU_X86 := FALSE}
- {$setc TARGET_CPU_X86_64 := FALSE}
- {$setc TARGET_CPU_ARM := FALSE}
- {$setc TARGET_OS_MAC := TRUE}
- {$setc TARGET_OS_IPHONE := FALSE}
- {$setc TARGET_IPHONE_SIMULATOR := FALSE}
- {$elifc defined __i386__ and __i386__}
- {$setc TARGET_CPU_PPC := FALSE}
- {$setc TARGET_CPU_PPC64 := FALSE}
- {$setc TARGET_CPU_X86 := TRUE}
- {$setc TARGET_CPU_X86_64 := FALSE}
- {$setc TARGET_CPU_ARM := FALSE}
- {$ifc defined(iphonesim)}
- {$setc TARGET_OS_MAC := FALSE}
- {$setc TARGET_OS_IPHONE := TRUE}
- {$setc TARGET_IPHONE_SIMULATOR := TRUE}
- {$elsec}
- {$setc TARGET_OS_MAC := TRUE}
- {$setc TARGET_OS_IPHONE := FALSE}
- {$setc TARGET_IPHONE_SIMULATOR := FALSE}
- {$endc}
- {$elifc defined __x86_64__ and __x86_64__}
- {$setc TARGET_CPU_PPC := FALSE}
- {$setc TARGET_CPU_PPC64 := FALSE}
- {$setc TARGET_CPU_X86 := FALSE}
- {$setc TARGET_CPU_X86_64 := TRUE}
- {$setc TARGET_CPU_ARM := FALSE}
- {$setc TARGET_OS_MAC := TRUE}
- {$setc TARGET_OS_IPHONE := FALSE}
- {$setc TARGET_IPHONE_SIMULATOR := FALSE}
- {$elifc defined __arm__ and __arm__}
- {$setc TARGET_CPU_PPC := FALSE}
- {$setc TARGET_CPU_PPC64 := FALSE}
- {$setc TARGET_CPU_X86 := FALSE}
- {$setc TARGET_CPU_X86_64 := FALSE}
- {$setc TARGET_CPU_ARM := TRUE}
- { will require compiler define when/if other Apple devices with ARM cpus ship }
- {$setc TARGET_OS_MAC := FALSE}
- {$setc TARGET_OS_IPHONE := TRUE}
- {$setc TARGET_IPHONE_SIMULATOR := FALSE}
- {$elsec}
- {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ is defined.}
- {$endc}
- {$ifc defined __LP64__ and __LP64__ }
- {$setc TARGET_CPU_64 := TRUE}
- {$elsec}
- {$setc TARGET_CPU_64 := FALSE}
- {$endc}
- {$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_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,CFArray,CFDictionary,CFURL,Files,Processes,LSInfo,AEDataModel;
- {$endc} {not MACOSALLINCLUDE}
- {$ifc TARGET_OS_MAC}
- {$ALIGN MAC68K}
- { ======================================================================================================== }
- { LaunchServices Type & Constants }
- { ======================================================================================================== }
- type
- LSLaunchFlags = OptionBits;
- const
- kLSLaunchDefaults = $00000001; { Defaults = open, async, use Info.plist, start Classic}
- kLSLaunchAndPrint = $00000002; { Print items instead of open them}
- kLSLaunchReserved2 = $00000004;
- kLSLaunchReserved3 = $00000008;
- kLSLaunchReserved4 = $00000010;
- kLSLaunchReserved5 = $00000020;
- kLSLaunchAndDisplayErrors = $00000040; { Report launch/open failures in the UI}
- kLSLaunchInhibitBGOnly = $00000080; { Causes launch to fail if target is background-only.}
- kLSLaunchDontAddToRecents = $00000100; { Do not add app or documents to recents menus.}
- kLSLaunchDontSwitch = $00000200; { Do not bring new app to the foreground.}
- kLSLaunchNoParams = $00000800; { Use Info.plist to determine launch parameters}
- kLSLaunchAsync = $00010000; { Asynchronous launch; return as soon as the app starts launching.}
- kLSLaunchStartClassic = $00020000; { Start up Classic environment if required for app.}
- kLSLaunchInClassic = $00040000; { Force app to launch in Classic environment.}
- kLSLaunchNewInstance = $00080000; { Instantiate app even if it is already running.}
- kLSLaunchAndHide = $00100000; { Send child a "hide" request as soon as it checks in.}
- kLSLaunchAndHideOthers = $00200000; { Hide all other apps when the app checks in.}
- kLSLaunchHasUntrustedContents = $00400000; { Mark items to be opened as untrusted}
- type
- LSLaunchFSRefSpec = record
- appRef: {const} FSRefPtr; { app to use, can be NULL}
- numDocs: ItemCount; { items to open/print, can be zero}
- itemRefs: {const} FSRefPtr; { array of FSRefs, ignored when numDocs is zero}
- passThruParams: {const} AEDescPtr; { passed untouched to application as optional event parameter, }
- { with keyword keyAEPropData (can be NULL)}
- launchFlags: LSLaunchFlags;
- asyncRefCon: UnivPtr; { used if you register for app birth/death notification}
- end;
- type
- LSLaunchURLSpec = record
- appURL: CFURLRef; { app to use, can be NULL}
- itemURLs: CFArrayRef; { items to open/print, can be NULL}
- passThruParams: {const} AEDescPtr; { passed untouched to application as optional parameter (can be NULL)}
- launchFlags: LSLaunchFlags;
- asyncRefCon: UnivPtr; { used if you register for app birth/death notification}
- end;
- { ======================================================================================================== }
- { LaunchServices API }
- { ======================================================================================================== }
- {
- * LSOpenFSRef()
- *
- * Summary:
- * Open an application, document, or folder.
- *
- * Discussion:
- * Opens applications, documents, and folders. Applications are
- * opened via an 'oapp' or 'rapp' event. Documents are opened in
- * their user-overridden or default applications as appropriate.
- * Folders are opened in the Finder. Use the more specific
- * LSOpenFromRefSpec for more control over launching.
- *
- * Mac OS X threading:
- * Thread safe since version 10.2
- *
- * Parameters:
- *
- * inRef:
- * The FSRef of the item to launch.
- *
- * outLaunchedRef:
- * The FSRef of the item actually launched. For inRefs that are
- * documents, outLaunchedRef will be the application used to
- * launch the document. Can be NULL.
- *
- * Availability:
- * Mac OS X: in version 10.0 and later in ApplicationServices.framework
- * CarbonLib: not available in CarbonLib 1.x
- * Non-Carbon CFM: not available
- }
- function LSOpenFSRef( const (*var*) inRef: FSRef; outLaunchedRef: FSRefPtr { can be NULL } ): OSStatus; external name '_LSOpenFSRef';
- (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
- {
- * LSOpenCFURLRef()
- *
- * Summary:
- * Open an application, document, or folder.
- *
- * Discussion:
- * Opens applications, documents, and folders. Applications are
- * opened via an 'oapp' or 'rapp' event. Documents are opened in
- * their user-overridden or default applications as appropriate.
- * Folders are opened in the Finder. Use the more specific
- * LSOpenFromURLSpec for more control over launching.
- *
- * Mac OS X threading:
- * Thread safe since version 10.2
- *
- * Parameters:
- *
- * inURL:
- * The CFURLRef of the item to launch.
- *
- * outLaunchedURL:
- * The CFURLRef of the item actually launched. For inURLs that are
- * documents, outLaunchedURL will be the application used to
- * launch the document. Can be NULL. THIS FUNCTION, DESPITE ITS
- * NAME, RETAINS THE URL REFERENCE ON BEHALF OF THE CALLER. THE
- * CALLER MUST EVENTUALLY RELEASE THE RETURNED URL REFERENCE.
- *
- * Availability:
- * Mac OS X: in version 10.0 and later in ApplicationServices.framework
- * CarbonLib: not available in CarbonLib 1.x
- * Non-Carbon CFM: not available
- }
- function LSOpenCFURLRef( inURL: CFURLRef; outLaunchedURL: CFURLRefPtr { can be NULL } ): OSStatus; external name '_LSOpenCFURLRef';
- (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
- {
- * LSOpenFromRefSpec()
- *
- * Summary:
- * Opens an application or one or more documents or folders.
- *
- * Discussion:
- * Opens applications, documents, and folders.
- *
- * Mac OS X threading:
- * Thread safe since version 10.2
- *
- * Parameters:
- *
- * inLaunchSpec:
- * The specification of what to launch and how to launch it.
- *
- * outLaunchedRef:
- * The FSRef of the item actually launched. For inRefs that are
- * documents, outLaunchedRef will be the application used to
- * launch the document. Can be NULL.
- *
- * Availability:
- * Mac OS X: in version 10.0 and later in ApplicationServices.framework
- * CarbonLib: not available in CarbonLib 1.x
- * Non-Carbon CFM: not available
- }
- function LSOpenFromRefSpec( const (*var*) inLaunchSpec: LSLaunchFSRefSpec; outLaunchedRef: FSRefPtr { can be NULL } ): OSStatus; external name '_LSOpenFromRefSpec';
- (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
- {
- * LSOpenFromURLSpec()
- *
- * Summary:
- * Opens an application or one or more documents or folders.
- *
- * Discussion:
- * Opens applications, documents, and folders.
- *
- * Mac OS X threading:
- * Thread safe since version 10.2
- *
- * Parameters:
- *
- * inLaunchSpec:
- * The specification of what to launch and how to launch it.
- *
- * outLaunchedURL:
- * The CFURLRef of the item actually launched. For inURLs that are
- * documents, outLaunchedURL will be the application used to
- * launch the document. Can be NULL. THIS FUNCTION, DESPITE ITS
- * NAME, RETAINS THE URL REFERENCE ON BEHALF OF THE CALLER. THE
- * CALLER MUST EVENTUALLY RELEASE THE RETURNED URL REFERENCE.
- *
- * Availability:
- * Mac OS X: in version 10.0 and later in ApplicationServices.framework
- * CarbonLib: not available in CarbonLib 1.x
- * Non-Carbon CFM: not available
- }
- function LSOpenFromURLSpec( const (*var*) inLaunchSpec: LSLaunchURLSpec; outLaunchedURL: CFURLRefPtr { can be NULL } ): OSStatus; external name '_LSOpenFromURLSpec';
- (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *)
- { ================================================================================== }
- { API for opening with a specific role and additional parameters }
- { ================================================================================== }
- {
- * LSApplicationParameters
- *
- * This structure is used by the new LSOpen functions to specify
- * an application, launch flags, and additional parameters
- * controlling how an application is launched.
- *
- * A version field allows the structure to be extended in
- * future releases.
- }
- type
- LSApplicationParameters = record
- version: CFIndex; { This must be set to zero by the client }
- flags: LSLaunchFlags; { See the LSLaunchFlags enum }
- application: {const} FSRefPtr; { The application to open (and possibly handle documents/URLs) }
- asyncLaunchRefCon: UnivPtr; { The client refCon which will appear in subsequent launch notifications }
- environment: CFDictionaryRef; { Environment variables to set in the launched process }
- { (a dictionary of CFStringRef keys and values). Can be NULL. }
- argv: CFArrayRef; { Note: argv is ignored on 10.4. On 10.5 and later, the array elements }
- { (which must be CFStringRefs) are passed as arguments to main() in the launched process. }
- initialEvent: AppleEventPtr; { The first Apple Event to be sent to the launched process. Can be NULL. }
- end;
- type
- LSApplicationParametersPtr = ^LSApplicationParameters;
-
- {
- * LSOpenApplication()
- *
- * LSOpenApplication launches one application. This function
- * is an updated alternative to the Process Manager's LaunchApplication().
- *
- * Launch arguments are specified in the inAppParams argument, which
- * must be supplied. If the application is already running in the current
- * session, it will be made the front process (unless the kLSLaunchNewInstance
- * flag is used, which will always cause a new process to be created).
- *
- * If outPSN is not NULL, the structure it points to will contain the process
- * serial number of the launched (or activated) process. Note that for
- * asynchronous launches, the application may not have finished launching
- * when this function returns.
- }
- {
- * LSOpenApplication()
- *
- * Mac OS X threading:
- * Thread safe since version 10.4
- *
- * Availability:
- * Mac OS X: in version 10.4 and later in ApplicationServices.framework
- * CarbonLib: not available
- * Non-Carbon CFM: not available
- }
- function LSOpenApplication( const (*var*) appParams: LSApplicationParameters; outPSN: ProcessSerialNumberPtr { can be NULL } ): OSStatus; external name '_LSOpenApplication';
- (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *)
- {
- * LSOpenItemsWithRole()
- *
- * Opens the items specified as an array of FSRefs with the role
- * specified by inRoleMask. If the role doesn't matter, use kLSRolesAll.
- *
- * Clients can optionally specify the application and launch parameters
- * in inAppParams. If a specific application is given in inAppParams, then
- * inRoleMask is ignored and the application is launched (if necessary).
- * Otherwise, an application will be selected which can handle each input
- * item in the specified role(s).
- *
- * Each launched application will receive an 'odoc' Apple Event specifying
- * which items are to be opened.
- *
- * Note that if the input items array contains any applications, this
- * function will not launch them unless the kLSRolesShell bit is set
- * in the inRolesMask (in which case the application is its own shell).
- *
- * The optional inAEParam argument specifies an AEDesc to be attached to
- * the Apple Event(s) generated by Launch Services with the specified
- * AEKeyword.
- *
- * If not NULL, the outPSNs buffer will be filled with the PSN which
- * was used to open each item at the same index of the input FSRef array. The
- * PSN capacity of the output buffer is specified by inMaxPSNCount.
- }
- {
- * LSOpenItemsWithRole()
- *
- * Mac OS X threading:
- * Thread safe since version 10.4
- *
- * Availability:
- * Mac OS X: in version 10.4 and later in ApplicationServices.framework
- * CarbonLib: not available
- * Non-Carbon CFM: not available
- }
- function LSOpenItemsWithRole( const (*var*) inItems: FSRef; inItemCount: CFIndex; inRole: LSRolesMask; {const} inAEParam: AEKeyDescPtr { can be NULL }; {const} inAppParams: LSApplicationParametersPtr { can be NULL }; outPSNs: ProcessSerialNumberPtr { can be NULL }; inMaxPSNCount: CFIndex ): OSStatus; external name '_LSOpenItemsWithRole';
- (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *)
- {
- * LSOpenURLsWithRole()
- *
- * Opens the URLs specified by inURLs (an array of CFURLRefs) with the role
- * specified by inRoleMask. If the role doesn't matter, use kLSRolesAll.
- *
- * Clients can optionally specify the application and launch parameters
- * in inAppParams. If a specific application is given in inAppParams, then
- * inRoleMask is ignored and the application is launched (if necessary).
- * Otherwise, an application will be selected which can handle each input
- * URL in at least one of the specified role(s).
- *
- * Each launched application will receive one or more 'GURL' Apple Event
- * specifying the URLs to be opened. Clients may also pass file URLs, which
- * will be interpreted as file system items and opened in the manner of
- * LSOpenItemsWithRole (i.e., a handler will be selected base on the item's
- * metadata).
- *
- * Note that if the input array contains any application URLs, this
- * function will not launch them unless the kLSRolesShell bit is set
- * in the inRolesMask (in which case the application is its own shell).
- *
- * The optional inAEParam argument specifies an AEDesc to be attached to
- * the Apple Event(s) generated by Launch Services with the specified
- * AEKeyword.
- *
- * If not NULL, the outPSNs buffer will be filled with the PSN which
- * was used to open each URL at the same index of the input URL array. The
- * PSN capacity of the output buffer is specified by inMaxPSNCount.
- }
- {
- * LSOpenURLsWithRole()
- *
- * Mac OS X threading:
- * Thread safe since version 10.4
- *
- * Availability:
- * Mac OS X: in version 10.4 and later in ApplicationServices.framework
- * CarbonLib: not available
- * Non-Carbon CFM: not available
- }
- function LSOpenURLsWithRole( inURLs: CFArrayRef; inRole: LSRolesMask; {const} inAEParam: AEKeyDescPtr { can be NULL }; {const} inAppParams: LSApplicationParametersPtr { can be NULL }; outPSNs: ProcessSerialNumberPtr { can be NULL }; inMaxPSNCount: CFIndex ): OSStatus; external name '_LSOpenURLsWithRole';
- (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *)
- {$endc} {TARGET_OS_MAC}
- {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
- end.
- {$endc} {not MACOSALLINCLUDE}
|