1257 lines
42 KiB
C
Raw Normal View History

2020-04-22 12:56:21 -04:00
/*
File: Navigation.h
Contains: Navigation Services 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 __NAVIGATION__
#define __NAVIGATION__
#ifndef __MACTYPES__
#include <MacTypes.h>
#endif
#ifndef __MACERRORS__
#include <MacErrors.h>
#endif
#ifndef __CODEFRAGMENTS__
#include <CodeFragments.h>
#endif
#ifndef __TRANSLATION__
#include <Translation.h>
#endif
#ifndef __MACWINDOWS__
#include <MacWindows.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
typedef UInt32 NavAskSaveChangesAction;
enum {
/* input action codes for NavAskSaveChanges() */
kNavSaveChangesClosingDocument = 1,
kNavSaveChangesQuittingApplication = 2,
kNavSaveChangesOther = 0
};
typedef UInt32 NavAskSaveChangesResult;
enum {
/* result codes for NavAskSaveChanges() */
kNavAskSaveChangesSave = 1,
kNavAskSaveChangesCancel = 2,
kNavAskSaveChangesDontSave = 3
};
typedef UInt32 NavAskDiscardChangesResult;
enum {
/* result codes for NavAskDiscardChanges() */
kNavAskDiscardChanges = 1,
kNavAskDiscardChangesCancel = 2
};
typedef SInt16 NavFilterModes;
enum {
/* which elements are being filtered for objects: */
kNavFilteringBrowserList = 0,
kNavFilteringFavorites = 1,
kNavFilteringRecents = 2,
kNavFilteringShortCutVolumes = 3,
kNavFilteringLocationPopup = 4 /* for v1.1 or greater */
};
enum {
kNavFileOrFolderVersion = 1
};
struct NavFileOrFolderInfo {
UInt16 version;
Boolean isFolder;
Boolean visible;
UInt32 creationDate;
UInt32 modificationDate;
union {
struct {
Boolean locked; /* file is locked */
Boolean resourceOpen; /* resource fork is opened */
Boolean dataOpen; /* data fork is opened */
Boolean reserved1;
UInt32 dataSize; /* size of the data fork */
UInt32 resourceSize; /* size of the resource fork */
FInfo finderInfo; /* more file info: */
FXInfo finderXInfo;
} fileInfo;
struct {
Boolean shareable;
Boolean sharePoint;
Boolean mounted;
Boolean readable;
Boolean writeable;
Boolean reserved2;
UInt32 numberOfFiles;
DInfo finderDInfo;
DXInfo finderDXInfo;
OSType folderType; /* package type, For struct version >= 1 */
OSType folderCreator; /* package creator, For struct version >= 1 */
char reserved3[206];
} folderInfo;
} fileAndFolder;
};
typedef struct NavFileOrFolderInfo NavFileOrFolderInfo;
union NavEventDataInfo {
EventRecord * event; /* for event processing */
void * param; /* points to event specific data */
};
typedef union NavEventDataInfo NavEventDataInfo;
struct NavEventData {
NavEventDataInfo eventDataParms; /* the event data */
SInt16 itemHit; /* the dialog item number, for v1.1 or greater */
};
typedef struct NavEventData NavEventData;
/*
* NavDialogRef
*
* Summary:
* Opaque Navigation Services dialog identifier
*
* Discussion:
* A NavDialogRef is an opaque reference to an instance of a
* Navigation Services dialog. A new NavDialogRef is returned from
* any of the NavCreate*Dialog functions and is later disposed with
* the NavDialogDispose function. NavDialogRef is the new name for
* the NavContext type, and thus when a client's event proc is
* called, the value of the NavCBRec.context field is the same as
* the NavDialogRef returned from the corresponding
* NavCreate*Dialog. A NavDialogRef is distinct from, and is not
* interchangable with, a Dialog Manager DialogRef.
*/
typedef struct __NavDialog* NavDialogRef;
#if CALL_NOT_IN_CARBON
/* NavContext is the old name for NavDialogRef */
typedef NavDialogRef NavContext;
#endif /* CALL_NOT_IN_CARBON */
/*
* NavUserAction
*
* Summary:
* Indicates an action taken by the user
*
* Discussion:
* When the user clicks a button at the bottom of a Nav Services
* dialog (or makes an equivalent mouse or key gesture), a
* kNavCBUserAction event is sent to the client's event proc
* indicating which action was taken. Often, the action also
* dismisses the dialog. User action events are only generated when
* using dialogs created from a NavCreate*Dialog function. In the
* special case of a modeless GetFile dialog (supported only on Mac
* OS X), the user can option-click on the open button to keep the
* dialog from being dismissed, but the kNavCBUserAction event is
* sent so the client can get the reply record and open the selected
* files.
*/
typedef UInt32 NavUserAction;
enum {
/*
* No action taken. The dialog is still running or was terminated
* programmatically.
*/
kNavUserActionNone = 0,
/*
* The user cancelled the dialog.
*/
kNavUserActionCancel = 1,
/*
* The user clicked the Open button in the GetFile dialog.
*/
kNavUserActionOpen = 2,
/*
* The user clicked the Save button in the PutFile dialog.
*/
kNavUserActionSaveAs = 3,
/*
* The user clicked the Choose button in the ChooseFile,
* ChooseFolder, ChooseVolume or ChooseObject dialogs.
*/
kNavUserActionChoose = 4,
/*
* The user clicked the New Folder button in the New Folder dialog.
*/
kNavUserActionNewFolder = 5,
/*
* The user clicked the Save button in an AskSaveChanges dialog.
*/
kNavUserActionSaveChanges = 6,
/*
* The user clicked the Don't Save button in an AskSaveChanges dialog.
*/
kNavUserActionDontSaveChanges = 7,
/*
* The user clicked the Discard button in the AskDiscardChanges
* dialog.
*/
kNavUserActionDiscardChanges = 8,
/*
* The user clicked the Review Unsaved button in the
* AskReviewDocuments dialog (used only on Mac OS X).
*/
kNavUserActionReviewDocuments = 9,
/*
* The user clicked the Discard Changes button in the
* AskReviewDocuments dialog (used only on Mac OS X).
*/
kNavUserActionDiscardDocuments = 10
};
enum {
kNavCBRecVersion = 1
};
/*
* NavCBRec
*
* Summary:
* A structure passed to event and preview callbacks
*
* Discussion:
* The NavCBRec structure is passed to the client's event proc or
* custom preview proc. It provides information that is specific to
* each event type. New for Carbon: the userAction field.
*/
struct NavCBRec {
/*
* The version of the struct (currently 1)
*/
UInt16 version;
/*
* The NavDialogRef this callback with which this call is associated
*/
NavDialogRef context;
/*
* The dialog's window
*/
WindowRef window;
/*
* The custom control area rectangle (window coordinates)
*/
Rect customRect;
/*
* The custom preview area rectangle (window coordinates)
*/
Rect previewRect;
/*
* The event-specific data, including the EventRecord, if any
*/
NavEventData eventData;
/*
* The action taken by the user that generated a kNavCBUserAction
* event (Carbon dialogs only)
*/
NavUserAction userAction;
/*
* Reserved for future use
*/
char reserved[218];
};
typedef struct NavCBRec NavCBRec;
typedef NavCBRec * NavCBRecPtr;
/*
* NavEventCallbackMessage
*
* Summary:
* Identifies the message type being sent to the client's event proc
*/
typedef SInt32 NavEventCallbackMessage;
enum {
/*
* An OS event has occurred. A pointer to the EventRecord is in the
* eventData.eventDataParms.event field of the NavCBRec.
*/
kNavCBEvent = 0,
/*
* Negotiate for custom control space. Client can set change the
* customRect field in the NavCBRec to create space for a custom
* area. Nav Services will continue to send the kNavCBCustomize
* message until the client leaves the customRect field unchanged.
*/
kNavCBCustomize = 1,
/*
* This message is sent after custom area negotiation, just before
* the dialog is made visible. Add your custom controls when you
* receive this message.
*/
kNavCBStart = 2,
/*
* This is the last message sent, after the dialog has been hidden.
*/
kNavCBTerminate = 3,
/*
* Sent when the dialog has been resized. Check the customRect and or
* previewRect values to see if any relayout is needed. Nav Services
* automatically moves controls in the custom area.
*/
kNavCBAdjustRect = 4,
/*
* The target folder of the dialog has changed. The
* NavCBRec.eventData.eventDataParms.param field is an AEDesc*
* containing an descriptor of the new location (ususally an FSSpec
* or an FSRef).
*/
kNavCBNewLocation = 5,
/*
* The target folder has changed to the user's desktop folder.
*/
kNavCBShowDesktop = 6,
/*
* The user has selected or deselected a file or folder. The
* NavCBRec.eventData.eventDataParms.param field is an AEDescList*
* identifying the currently selected items.
*/
kNavCBSelectEntry = 7,
/*
* The value of the Show/Format popup menu has changed. The
* NavCBRec.eventData.eventDataParms.param is a NavMenuItemSpec*
* identifying the menu item selected. If the dialog was created
* using the Carbon-only NavCreate*Dialog APIs, then the menuType
* field of the NavMenuItemSpec is set to the index into the client's
* CFArray of popupExtension strings (see NavDialogCreationOptions).
*/
kNavCBPopupMenuSelect = 8,
/*
* Sent when the user has accepted (Open, Save, etc.).
*/
kNavCBAccept = 9,
/*
* Sent when the user has cancelled the dialog.
*/
kNavCBCancel = 10,
/*
* The custom preview area state has changed. The
* NavCBRec.eventData.eventDataParms.param is a Boolean* set to true
* if the preview area is visible or false if it is not.
*/
kNavCBAdjustPreview = 11,
/*
* The user has taken one of the actions described in the
* NavUserAction definition. The action may or may not dismiss the
* dialog. The NavCBRec.userAction field indicates which action was
* taken (Carbon dialogs only).
*/
kNavCBUserAction = 12,
/*
* The user has opened a folder or chosen a file. The client can
* block navigation or dismissal by setting the appropriate action
* state with the kNavCtlSetActionState NavCustomControl selector.
*/
kNavCBOpenSelection = (long)0x80000000
};
typedef void * NavCallBackUserData;
/* for events and customization: */
typedef CALLBACK_API( void , NavEventProcPtr )(NavEventCallbackMessage callBackSelector, NavCBRecPtr callBackParms, void *callBackUD);
/* for preview support: */
typedef CALLBACK_API( Boolean , NavPreviewProcPtr )(NavCBRecPtr callBackParms, void *callBackUD);
/* filtering callback information: */
typedef CALLBACK_API( Boolean , NavObjectFilterProcPtr )(AEDesc *theItem, void *info, void *callBackUD, NavFilterModes filterMode);
typedef STACK_UPP_TYPE(NavEventProcPtr) NavEventUPP;
typedef STACK_UPP_TYPE(NavPreviewProcPtr) NavPreviewUPP;
typedef STACK_UPP_TYPE(NavObjectFilterProcPtr) NavObjectFilterUPP;
/*
* NewNavEventUPP()
*
* 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( NavEventUPP )
NewNavEventUPP(NavEventProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppNavEventProcInfo = 0x00000FC0 }; /* pascal no_return_value Func(4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(NavEventUPP) NewNavEventUPP(NavEventProcPtr userRoutine) { return (NavEventUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppNavEventProcInfo, GetCurrentArchitecture()); }
#else
#define NewNavEventUPP(userRoutine) (NavEventUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppNavEventProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewNavPreviewUPP()
*
* 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( NavPreviewUPP )
NewNavPreviewUPP(NavPreviewProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppNavPreviewProcInfo = 0x000003D0 }; /* pascal 1_byte Func(4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(NavPreviewUPP) NewNavPreviewUPP(NavPreviewProcPtr userRoutine) { return (NavPreviewUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppNavPreviewProcInfo, GetCurrentArchitecture()); }
#else
#define NewNavPreviewUPP(userRoutine) (NavPreviewUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppNavPreviewProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewNavObjectFilterUPP()
*
* 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( NavObjectFilterUPP )
NewNavObjectFilterUPP(NavObjectFilterProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppNavObjectFilterProcInfo = 0x00002FD0 }; /* pascal 1_byte Func(4_bytes, 4_bytes, 4_bytes, 2_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(NavObjectFilterUPP) NewNavObjectFilterUPP(NavObjectFilterProcPtr userRoutine) { return (NavObjectFilterUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppNavObjectFilterProcInfo, GetCurrentArchitecture()); }
#else
#define NewNavObjectFilterUPP(userRoutine) (NavObjectFilterUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppNavObjectFilterProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* DisposeNavEventUPP()
*
* 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 )
DisposeNavEventUPP(NavEventUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeNavEventUPP(NavEventUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeNavEventUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeNavPreviewUPP()
*
* 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 )
DisposeNavPreviewUPP(NavPreviewUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeNavPreviewUPP(NavPreviewUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeNavPreviewUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeNavObjectFilterUPP()
*
* 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 )
DisposeNavObjectFilterUPP(NavObjectFilterUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeNavObjectFilterUPP(NavObjectFilterUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeNavObjectFilterUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* InvokeNavEventUPP()
*
* 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 )
InvokeNavEventUPP(
NavEventCallbackMessage callBackSelector,
NavCBRecPtr callBackParms,
void * callBackUD,
NavEventUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeNavEventUPP(NavEventCallbackMessage callBackSelector, NavCBRecPtr callBackParms, void * callBackUD, NavEventUPP userUPP) { CALL_THREE_PARAMETER_UPP(userUPP, uppNavEventProcInfo, callBackSelector, callBackParms, callBackUD); }
#else
#define InvokeNavEventUPP(callBackSelector, callBackParms, callBackUD, userUPP) CALL_THREE_PARAMETER_UPP((userUPP), uppNavEventProcInfo, (callBackSelector), (callBackParms), (callBackUD))
#endif
#endif
/*
* InvokeNavPreviewUPP()
*
* 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( Boolean )
InvokeNavPreviewUPP(
NavCBRecPtr callBackParms,
void * callBackUD,
NavPreviewUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(Boolean) InvokeNavPreviewUPP(NavCBRecPtr callBackParms, void * callBackUD, NavPreviewUPP userUPP) { return (Boolean)CALL_TWO_PARAMETER_UPP(userUPP, uppNavPreviewProcInfo, callBackParms, callBackUD); }
#else
#define InvokeNavPreviewUPP(callBackParms, callBackUD, userUPP) (Boolean)CALL_TWO_PARAMETER_UPP((userUPP), uppNavPreviewProcInfo, (callBackParms), (callBackUD))
#endif
#endif
/*
* InvokeNavObjectFilterUPP()
*
* 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( Boolean )
InvokeNavObjectFilterUPP(
AEDesc * theItem,
void * info,
void * callBackUD,
NavFilterModes filterMode,
NavObjectFilterUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(Boolean) InvokeNavObjectFilterUPP(AEDesc * theItem, void * info, void * callBackUD, NavFilterModes filterMode, NavObjectFilterUPP userUPP) { return (Boolean)CALL_FOUR_PARAMETER_UPP(userUPP, uppNavObjectFilterProcInfo, theItem, info, callBackUD, filterMode); }
#else
#define InvokeNavObjectFilterUPP(theItem, info, callBackUD, filterMode, userUPP) (Boolean)CALL_FOUR_PARAMETER_UPP((userUPP), uppNavObjectFilterProcInfo, (theItem), (info), (callBackUD), (filterMode))
#endif
#endif
#if CALL_NOT_IN_CARBON || OLDROUTINENAMES
/* support for pre-Carbon UPP routines: New...Proc and Call...Proc */
#define NewNavEventProc(userRoutine) NewNavEventUPP(userRoutine)
#define NewNavPreviewProc(userRoutine) NewNavPreviewUPP(userRoutine)
#define NewNavObjectFilterProc(userRoutine) NewNavObjectFilterUPP(userRoutine)
#define CallNavEventProc(userRoutine, callBackSelector, callBackParms, callBackUD) InvokeNavEventUPP(callBackSelector, callBackParms, callBackUD, userRoutine)
#define CallNavPreviewProc(userRoutine, callBackParms, callBackUD) InvokeNavPreviewUPP(callBackParms, callBackUD, userRoutine)
#define CallNavObjectFilterProc(userRoutine, theItem, info, callBackUD, filterMode) InvokeNavObjectFilterUPP(theItem, info, callBackUD, filterMode, userRoutine)
#endif /* CALL_NOT_IN_CARBON */
typedef SInt32 NavCustomControlMessage;
enum {
kNavCtlShowDesktop = 0, /* show desktop, parms = nil */
kNavCtlSortBy = 1, /* sort key field, parms->NavSortKeyField */
kNavCtlSortOrder = 2, /* sort order, parms->NavSortOrder */
kNavCtlScrollHome = 3, /* scroll list home, parms = nil */
kNavCtlScrollEnd = 4, /* scroll list end, parms = nil */
kNavCtlPageUp = 5, /* page list up, parms = nil */
kNavCtlPageDown = 6, /* page list down, parms = nil */
kNavCtlGetLocation = 7, /* get current location, parms<-AEDesc* */
kNavCtlSetLocation = 8, /* set current location, parms->AEDesc* */
kNavCtlGetSelection = 9, /* get current selection, parms<-AEDescList* */
kNavCtlSetSelection = 10, /* set current selection, parms->AEDescList* */
kNavCtlShowSelection = 11, /* make selection visible, parms = nil */
kNavCtlOpenSelection = 12, /* open view of selection, parms = nil */
kNavCtlEjectVolume = 13, /* eject volume, parms->vRefNum */
kNavCtlNewFolder = 14, /* create a new folder, parms->StringPtr */
kNavCtlCancel = 15, /* cancel dialog, parms = nil */
kNavCtlAccept = 16, /* accept dialog default, parms = nil */
kNavCtlIsPreviewShowing = 17, /* query preview status, parms<-Boolean */
kNavCtlAddControl = 18, /* add one control to dialog, parms->ControlHandle */
kNavCtlAddControlList = 19, /* add control list to dialog, parms->Handle (DITL rsrc) */
kNavCtlGetFirstControlID = 20, /* get 1st control ID, parms<-UInt16 */
kNavCtlSelectCustomType = 21, /* select a custom menu item parms->NavMenuItemSpec* */
kNavCtlSelectAllType = 22, /* select an "All" menu item parms->SInt16 */
kNavCtlGetEditFileName = 23, /* get save dlog's file name parms<-StringPtr */
kNavCtlSetEditFileName = 24, /* set save dlog's file name parms->StringPtr */
kNavCtlSelectEditFileName = 25, /* select save dlog file name parms->ControlEditTextSelectionRec*, v1.1 or greater */
kNavCtlBrowserSelectAll = 26, /* re-scan the browser list parms = nil, v2.0 or greater */
kNavCtlGotoParent = 27, /* navigate to parent parms = nil, v2.0 or greater */
kNavCtlSetActionState = 28, /* restrict navigation parms->NavActionState (flags), v2.0 or greater */
kNavCtlBrowserRedraw = 29, /* rescan browser list parms = nil, v2.0 or greater */
kNavCtlTerminate = 30 /* terminate/dismiss dialog parms = nil, v2.0 or greater */
};
typedef UInt32 NavActionState;
enum {
kNavNormalState = 0x00000000, /* normal/default state */
kNavDontOpenState = 0x00000001, /* disallow opening files/folders */
kNavDontSaveState = 0x00000002, /* disallow saving files */
kNavDontChooseState = 0x00000004, /* disallow choosing objects */
kNavDontNewFolderState = 0x00000010 /* disallow creating new folders */
};
typedef UInt16 NavPopupMenuItem;
enum {
kNavAllKnownFiles = 0,
kNavAllReadableFiles = 1,
kNavAllFiles = 2
};
typedef UInt16 NavSortKeyField;
enum {
kNavSortNameField = 0,
kNavSortDateField = 1
};
typedef UInt16 NavSortOrder;
enum {
kNavSortAscending = 0,
kNavSortDescending = 1
};
typedef UInt32 NavDialogOptionFlags;
enum {
kNavDefaultNavDlogOptions = 0x000000E4, /* use defaults for all the options */
kNavNoTypePopup = 0x00000001, /* don't show file type/extension popup on Open/Save */
kNavDontAutoTranslate = 0x00000002, /* don't automatically translate on Open */
kNavDontAddTranslateItems = 0x00000004, /* don't add translation choices on Open/Save */
kNavAllFilesInPopup = 0x00000010, /* "All Files" menu item in the type popup on Open */
kNavAllowStationery = 0x00000020, /* allow saving of stationery files */
kNavAllowPreviews = 0x00000040, /* allow preview to show */
kNavAllowMultipleFiles = 0x00000080, /* allow multiple items to be selected */
kNavAllowInvisibleFiles = 0x00000100, /* allow invisible items to be shown */
kNavDontResolveAliases = 0x00000200, /* don't resolve aliases */
kNavSelectDefaultLocation = 0x00000400, /* make the default location the browser selection */
kNavSelectAllReadableItem = 0x00000800, /* make the dialog select "All Readable Documents" on open */
kNavSupportPackages = 0x00001000, /* recognize file system packages, v2.0 or greater */
kNavAllowOpenPackages = 0x00002000, /* allow opening of packages, v2.0 or greater */
kNavDontAddRecents = 0x00004000, /* don't add chosen objects to the recents list, v2.0 or greater */
kNavDontUseCustomFrame = 0x00008000, /* don't draw the custom area bevel frame, v2.0 or greater */
kNavDontConfirmReplacement = 0x00010000, /* don't show the "Replace File?" alert on save conflict, v3.0 or greater */
kNavPreserveSaveFileExtension = 0x00020000 /* extension in default file name is preserved and initially hidden, v3.1 or greater */
};
typedef UInt32 NavTranslationOptions;
enum {
kNavTranslateInPlace = 0, /* translate in place, replacing translation source file (default for Save) */
kNavTranslateCopy = 1 /* translate to a copy of the source file (default for Open) */
};
enum {
kNavMenuItemSpecVersion = 0
};
struct NavMenuItemSpec {
UInt16 version;
OSType menuCreator;
OSType menuType;
Str255 menuItemName;
char reserved[245];
};
typedef struct NavMenuItemSpec NavMenuItemSpec;
typedef NavMenuItemSpec * NavMenuItemSpecArrayPtr;
typedef NavMenuItemSpecArrayPtr * NavMenuItemSpecArrayHandle;
typedef NavMenuItemSpecArrayPtr NavMenuItemSpecPtr;
typedef NavMenuItemSpecArrayHandle NavMenuItemSpecHandle;
enum {
kNavGenericSignature = FOUR_CHAR_CODE('****')
};
struct NavTypeList {
OSType componentSignature;
short reserved;
short osTypeCount;
OSType osType[1];
};
typedef struct NavTypeList NavTypeList;
typedef NavTypeList * NavTypeListPtr;
typedef NavTypeListPtr * NavTypeListHandle;
enum {
kNavDialogOptionsVersion = 0
};
struct NavDialogOptions {
UInt16 version;
NavDialogOptionFlags dialogOptionFlags; /* option flags for affecting the dialog's behavior */
Point location; /* top-left location of the dialog, or {-1,-1} for default position */
Str255 clientName;
Str255 windowTitle;
Str255 actionButtonLabel; /* label of the default button (or null string for default) */
Str255 cancelButtonLabel; /* label of the cancel button (or null string for default) */
Str255 savedFileName; /* default name for text box in NavPutFile (or null string for default) */
Str255 message; /* custom message prompt (or null string for default) */
UInt32 preferenceKey; /* a key for to managing preferences for using multiple utility dialogs */
NavMenuItemSpecArrayHandle popupExtension; /* extended popup menu items, an array of NavMenuItemSpecs */
char reserved[494];
};
typedef struct NavDialogOptions NavDialogOptions;
enum {
kNavReplyRecordVersion = 2
};
/*
* NavReplyRecord
*
* Summary:
* A structure describing the results of a Nav Services dialog
*
* Discussion:
* A reply record is the result of a Nav Services file dialog. Using
* the older API, which is always modal, the client passes the
* address of a reply record when invoking the dialog. In the Carbon
* API, dialogs may also be window modal or modeless, so the client
* requests the reply record by calling NavDialogGetReply when a
* kNavCBUserAction event is received. Either way, a reply record
* should be disposed of using NavDisposeReply.
*/
struct NavReplyRecord {
/*
* The version of the structure. The first public version of the
* structure was version 0. Fields added after version 0, starting
* with the saveFileName field, are noted below.
*/
UInt16 version;
/*
* True if the reply contains a non-null selection
*/
Boolean validRecord;
/*
* True if this reply is from a PutFile dialog and the file to be
* saved already exists and needs to be replaced. The user has
* already been warned unless the kNavDontConfirmReplacement option
* flag is used.
*/
Boolean replacing;
/*
* True if this reply is from a PutFile dialog and the user wants to
* save the file as stationery.
*/
Boolean isStationery;
/*
* True if translation was performed on the file(s) to be opened or
* if transtlation will be needed on the file to be saved.
*/
Boolean translationNeeded;
/*
* For GetFile or Choose dialogs, a list of items chosen by the user.
* For the older NavPutFile dialog, a list containing one item: an
* FSSpec of the file to be saved. ** IMPORTANT NOTE *** For the new
* Carbon-only PutFile dialog created with NavCreatePutFileDialog,
* the selection is a list containing one item: the DIRECTORY where
* the file is to be saved. The file name is obtained from the
* saveFileName field. When using the original modal API, each
* descriptor will contain an FSSpec (typeFSS). When using the new
* Carbon-only dialogs created via the NavCreate*Dialog functions,
* each descriptor could contain either an FSSpec (typeFSS, used on
* Mac OS 8 or 9) or an FSRef (typeFSRef, used on Mac OS X). This
* divergence is caused by the need to use FSRef (for Unicode/HFS+
* support) on Mac OS X, while being unable to provide FSRefs on Mac
* OS 8.6.
*/
AEDescList selection;
/*
* For NavPutFile: the script system associated with the name of the
* file to be saved.
*/
ScriptCode keyScript;
/*
* A handle to an array of type FileTranslationSpec. Each array entry
* corresponds to an item in the selection and describes the
* translation that was performed (GetFile) or needs to be performed
* (PutFile) on that item.
*/
FileTranslationSpecArrayHandle fileTranslation;
/*
* Reserved for private use.
*/
UInt32 reserved1;
/*
* Carbon PutFile dialog only: the name of the file to be saved. This
* field contains the true file name to saved, even if the extension
* will be hidden from the user. This field was added in structure
* version 1.
*/
CFStringRef saveFileName;
/*
* The extension on the name of the saved file should be hidden. Once
* the file has been saved, the client should call NavCompleteSave.
* NavCompleteSave will take care of hiding the extension on the
* file. However, the client needs to know that the extension is
* hidden so that it can display the document name correctly in the
* UI, such as in window titles and menus. This field is only used if
* the client has r equested extension preservation using the
* kNavPreserveSaveFileExtension dialog option flag. This field was
* added in structure version 2.
*/
Boolean saveFileExtensionHidden;
/*
* Reserved for future use.
*/
UInt8 reserved2;
/*
* Reserved for future use.
*/
char reserved[225];
};
typedef struct NavReplyRecord NavReplyRecord;
/*
* NavLoad()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: not available
*/
EXTERN_API( OSErr )
NavLoad(void);
/*
* NavUnload()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: not available
*/
EXTERN_API( OSErr )
NavUnload(void);
/*
* NavLibraryVersion()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( UInt32 )
NavLibraryVersion(void);
/*
* NavGetDefaultDialogOptions()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavGetDefaultDialogOptions(NavDialogOptions * dialogOptions);
/*
* NavGetFile()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavGetFile(
AEDesc * defaultLocation, /* can be NULL */
NavReplyRecord * reply,
NavDialogOptions * dialogOptions, /* can be NULL */
NavEventUPP eventProc, /* can be NULL */
NavPreviewUPP previewProc, /* can be NULL */
NavObjectFilterUPP filterProc, /* can be NULL */
NavTypeListHandle typeList, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavPutFile()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavPutFile(
AEDesc * defaultLocation, /* can be NULL */
NavReplyRecord * reply,
NavDialogOptions * dialogOptions, /* can be NULL */
NavEventUPP eventProc, /* can be NULL */
OSType fileType,
OSType fileCreator,
void * callBackUD); /* can be NULL */
/*
* NavAskSaveChanges()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavAskSaveChanges(
NavDialogOptions * dialogOptions,
NavAskSaveChangesAction action,
NavAskSaveChangesResult * reply,
NavEventUPP eventProc, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavCustomAskSaveChanges()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavCustomAskSaveChanges(
NavDialogOptions * dialogOptions,
NavAskSaveChangesResult * reply,
NavEventUPP eventProc, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavAskDiscardChanges()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavAskDiscardChanges(
NavDialogOptions * dialogOptions,
NavAskDiscardChangesResult * reply,
NavEventUPP eventProc, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavChooseFile()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavChooseFile(
AEDesc * defaultLocation, /* can be NULL */
NavReplyRecord * reply,
NavDialogOptions * dialogOptions, /* can be NULL */
NavEventUPP eventProc, /* can be NULL */
NavPreviewUPP previewProc, /* can be NULL */
NavObjectFilterUPP filterProc, /* can be NULL */
NavTypeListHandle typeList, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavChooseFolder()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavChooseFolder(
AEDesc * defaultLocation, /* can be NULL */
NavReplyRecord * reply,
NavDialogOptions * dialogOptions, /* can be NULL */
NavEventUPP eventProc, /* can be NULL */
NavObjectFilterUPP filterProc, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavChooseVolume()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavChooseVolume(
AEDesc * defaultSelection, /* can be NULL */
NavReplyRecord * reply,
NavDialogOptions * dialogOptions, /* can be NULL */
NavEventUPP eventProc, /* can be NULL */
NavObjectFilterUPP filterProc, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavChooseObject()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavChooseObject(
AEDesc * defaultLocation, /* can be NULL */
NavReplyRecord * reply,
NavDialogOptions * dialogOptions, /* can be NULL */
NavEventUPP eventProc, /* can be NULL */
NavObjectFilterUPP filterProc, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavNewFolder()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavNewFolder(
AEDesc * defaultLocation, /* can be NULL */
NavReplyRecord * reply,
NavDialogOptions * dialogOptions, /* can be NULL */
NavEventUPP eventProc, /* can be NULL */
void * callBackUD); /* can be NULL */
/*
* NavTranslateFile()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavTranslateFile(
NavReplyRecord * reply,
NavTranslationOptions howToTranslate);
/*
* NavCompleteSave()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavCompleteSave(
NavReplyRecord * reply,
NavTranslationOptions howToTranslate);
/*
* NavCustomControl()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavCustomControl(
NavDialogRef dialog,
NavCustomControlMessage selector,
void * parms);
/*
* NavCreatePreview()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 2.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavCreatePreview(
AEDesc * theObject,
OSType previewDataType,
const void * previewData,
Size previewDataSize);
/*
* NavDisposeReply()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API( OSErr )
NavDisposeReply(NavReplyRecord * reply);
/*
* NavServicesCanRun()
*
* Availability:
* Non-Carbon CFM: in NavigationLib 1.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: not available
*/
EXTERN_API( Boolean )
NavServicesCanRun(void);
#if TARGET_RT_MAC_CFM
#ifdef __cplusplus
inline pascal Boolean NavServicesAvailable() { return ((NavLibraryVersion != (void*)kUnresolvedCFragSymbolAddress) && NavServicesCanRun()); }
#else
#define NavServicesAvailable() ((NavLibraryVersion != (void*)kUnresolvedCFragSymbolAddress) && NavServicesCanRun())
#endif
#elif TARGET_RT_MAC_MACHO
/* Navigation is always available on OS X */
#ifdef __cplusplus
inline pascal Boolean NavServicesAvailable() { return true; }
#else
#define NavServicesAvailable() (true)
#endif
#else
/* NavServicesAvailable() is implemented in Navigation.o for classic 68K clients*/
#if CALL_NOT_IN_CARBON
/*
* NavServicesAvailable()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: not available
*/
EXTERN_API( Boolean )
NavServicesAvailable(void);
#endif /* CALL_NOT_IN_CARBON */
#endif /* */
#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 /* __NAVIGATION__ */