::NavCustomControl(ioParams->context, kNavCtlSetLocation, (void *) &theLocation);
}
- NavMenuItemSpec menuItem;
- menuItem.version = kNavMenuItemSpecVersion;
- menuItem.menuCreator = 'WXNG';
- menuItem.menuType = data->currentfilter;
- wxMacStringToPascal( data->name[data->currentfilter] , (StringPtr)(menuItem.menuItemName) ) ;
- ::NavCustomControl(ioParams->context, kNavCtlSelectCustomType, &menuItem);
+ if( data->extensions.GetCount() > 0 )
+ {
+ NavMenuItemSpec menuItem;
+ memset( &menuItem, 0, sizeof(menuItem) );
+ menuItem.version = kNavMenuItemSpecVersion;
+ menuItem.menuType = data->currentfilter;
+ ::NavCustomControl(ioParams->context, kNavCtlSelectCustomType, &menuItem);
+ }
}
else if ( inSelector == kNavCBPopupMenuSelect )
{
wxString extension = firstExtension.AfterLast('.') ;
wxString sfilename ;
- wxMacCFStringHolder cfString( NavDialogGetSaveFileName( ioParams->context ) , false );
+ wxCFStringRef cfString( wxCFRetain( NavDialogGetSaveFileName( ioParams->context ) ) );
sfilename = cfString.AsString() ;
int pos = sfilename.Find('.', true) ;
- if ( pos != wxNOT_FOUND )
+ if ( pos != wxNOT_FOUND && extension != wxT("*") )
{
sfilename = sfilename.Left(pos+1)+extension ;
- cfString.Assign( sfilename , wxFONTENCODING_DEFAULT ) ;
+ cfString = wxCFStringRef( sfilename , wxFONTENCODING_DEFAULT ) ;
NavDialogSetSaveFileName( ioParams->context , cfString ) ;
}
}
return true ;
}
-#if !TARGET_API_MAC_OSX
-static pascal Boolean CrossPlatformFileFilter(CInfoPBPtr myCInfoPBPtr, void *dataPtr)
-{
- OpenUserDataRecPtr data = (OpenUserDataRecPtr) dataPtr ;
- // return true if this item is invisible or a file
-
- Boolean visibleFlag;
- Boolean folderFlag;
-
- visibleFlag = ! (myCInfoPBPtr->hFileInfo.ioFlFndrInfo.fdFlags & kIsInvisible);
- folderFlag = (myCInfoPBPtr->hFileInfo.ioFlAttrib & 0x10);
-
- // because the semantics of the filter proc are "true means don't show
- // it" we need to invert the result that we return
-
- if ( !visibleFlag )
- return true ;
-
- if ( !folderFlag )
- {
- wxString file = wxMacMakeStringFromPascal( myCInfoPBPtr->hFileInfo.ioNamePtr ) ;
- return !CheckFile( file , myCInfoPBPtr->hFileInfo.ioFlFndrInfo.fdType , data ) ;
- }
-
- return false ;
-}
-#endif
-
// end wxmac
wxFileDialog::wxFileDialog(
// filter string.
// However, packages should be dealt with like files and not like folders. So
// check if a folder is a package before deciding what to do.
- FSRef fsref;
NavFileOrFolderInfo* theInfo = (NavFileOrFolderInfo*) info ;
- AECoerceDesc (theItem, typeFSRef, theItem);
- if ( AEGetDescData (theItem, &fsref, sizeof (FSRef)) != noErr)
- return true;
+ FSRef fsref;
if ( theInfo->isFolder )
{
!(lsInfo.flags & (kLSItemInfoIsApplication | kLSItemInfoIsPackage)) )
return true;
}
-
- wxString file = wxMacFSRefToPath( &fsref ) ;
- return CheckFile( file , theInfo->fileAndFolder.fileInfo.finderInfo.fdType , data ) ;
-
+ else
+ {
+ AECoerceDesc (theItem, typeFSRef, theItem);
+ if ( AEGetDescData (theItem, &fsref, sizeof (FSRef)) == noErr)
+ {
+ wxString file = wxMacFSRefToPath( &fsref ) ;
+ return CheckFile( file , theInfo->fileAndFolder.fileInfo.finderInfo.fdType , data ) ;
+ }
+ }
}
return true;
// this was always unset in the old code
dialogCreateOptions.optionFlags &= ~kNavSelectDefaultLocation;
- wxMacCFStringHolder message(m_message, m_font.GetEncoding());
+ wxCFStringRef message(m_message, GetFont().GetEncoding());
dialogCreateOptions.windowTitle = message;
- wxMacCFStringHolder defaultFileName(m_fileName, m_font.GetEncoding());
+ wxCFStringRef defaultFileName(m_fileName, GetFont().GetEncoding());
dialogCreateOptions.saveFileName = defaultFileName;
myData.menuitems = dialogCreateOptions.popupExtension ;
for ( size_t i = 0 ; i < numFilters ; ++i )
{
- CFArrayAppendValue( popup , (CFStringRef) wxMacCFStringHolder( myData.name[i] , m_font.GetEncoding() ) ) ;
+ CFArrayAppendValue( popup , (CFStringRef) wxCFStringRef( myData.name[i] , GetFont().GetEncoding() ) ) ;
}
}
if (numFilters < 2)
dialogCreateOptions.optionFlags |= kNavPreserveSaveFileExtension;
-#if TARGET_API_MAC_OSX
if (!(m_windowStyle & wxFD_OVERWRITE_PROMPT))
dialogCreateOptions.optionFlags |= kNavDontConfirmReplacement;
-#endif
err = ::NavCreatePutFileDialog(
&dialogCreateOptions,
::DisposeNavObjectFilterUPP(navFilterUPP);
if (err != noErr)
+ {
+ ::NavDialogDispose(dialog);
return wxID_CANCEL;
+ }
NavReplyRecord navReply;
err = ::NavDialogGetReply(dialog, &navReply);
if (!thePath)
{
::NavDisposeReply(&navReply);
+ ::NavDialogDispose(dialog);
return wxID_CANCEL;
}
}
::NavDisposeReply(&navReply);
+ ::NavDialogDispose(dialog);
return (err == noErr) ? wxID_OK : wxID_CANCEL;
}