#endif
#include "wx/filename.h"
+#include "wx/tokenzr.h"
#include "wx/osx/private.h"
const size_t extCount = extensions.GetCount();
for ( size_t i = 0 ; i < extCount; i++ )
{
- wxString extension = extensions[i];
-
- // Remove leading '*'
- if (extension.length() && (extension.GetChar(0) == '*'))
- extension = extension.Mid( 1 );
-
- // Remove leading '.'
- if (extension.length() && (extension.GetChar(0) == '.'))
- extension = extension.Mid( 1 );
-
- if ( extension.IsEmpty() )
+ wxString extensiongroup = extensions[i];
+ wxStringTokenizer tokenizer( extensiongroup , wxT(";") ) ;
+ while ( tokenizer.HasMoreTokens() )
{
- if ( types != nil )
- [types release];
- return nil;
- }
+ wxString extension = tokenizer.GetNextToken() ;
+ // Remove leading '*'
+ if (extension.length() && (extension.GetChar(0) == '*'))
+ extension = extension.Mid( 1 );
+ // Remove leading '.'
+ if (extension.length() && (extension.GetChar(0) == '.'))
+ extension = extension.Mid( 1 );
+
+ if ( extension.IsEmpty() )
+ {
+ if ( types != nil )
+ [types release];
+ return nil;
+ }
- if ( types == nil )
- types = [[NSMutableArray alloc] init];
+ if ( types == nil )
+ types = [[NSMutableArray alloc] init];
- wxCFStringRef cfext(extension);
- [types addObject: (NSString*)cfext.AsNSString() ];
+ wxCFStringRef cfext(extension);
+ [types addObject: (NSString*)cfext.AsNSString() ];
#if 0
- // add support for classic fileType / creator here
- wxUint32 fileType, creator;
- // extension -> mactypes
+ // add support for classic fileType / creator here
+ wxUint32 fileType, creator;
+ // extension -> mactypes
#endif
+ }
+
}
}
return types;
m_path = wxEmptyString;
m_fileNames.Clear();
-
+ m_paths.Clear();
+ // since we don't support retrieving the matching filter
+ m_filterIndex = -1;
+
wxNonOwnedWindow* parentWindow = NULL;
int returnCode = -1;
-
- if (GetParent())
+
+ if (GetParent())
{
parentWindow = dynamic_cast<wxNonOwnedWindow*>(wxGetTopLevelParent(GetParent()));
}
if ( HasFlag(wxFD_OVERWRITE_PROMPT) )
{
}
-
+
+/*
if (parentWindow)
{
NSWindow* nativeParent = parentWindow->GetWXWindow();
- ModalDialogDelegate* sheetDelegate = [[ModalDialogDelegate alloc] init];
- [sPanel beginSheetForDirectory:dir.AsNSString() file:file.AsNSString()
- modalForWindow: nativeParent modalDelegate: sheetDelegate
- didEndSelector: @selector(sheetDidEnd:returnCode:contextInfo:)
+ ModalDialogDelegate* sheetDelegate = [[ModalDialogDelegate alloc] init];
+ [sPanel beginSheetForDirectory:dir.AsNSString() file:file.AsNSString()
+ modalForWindow: nativeParent modalDelegate: sheetDelegate
+ didEndSelector: @selector(sheetDidEnd:returnCode:contextInfo:)
contextInfo: nil];
[sheetDelegate waitForSheetToFinish];
- result = [sheetDelegate code];
+ returnCode = [sheetDelegate code];
[sheetDelegate release];
}
else
+*/
{
- result = [sPanel runModalForDirectory:dir.AsNSString() file:file.AsNSString() ];
+ returnCode = [sPanel runModalForDirectory:dir.AsNSString() file:file.AsNSString() ];
}
-
- if (result == NSOKButton )
+
+ if (returnCode == NSOKButton )
{
panel = sPanel;
result = wxID_OK;
- wxCFStringRef filename( [[sPanel filename] retain] );
-
- m_path = filename.AsString();
+ m_path = wxCFStringRef::AsString([sPanel filename]);
m_fileName = wxFileNameFromPath(m_path);
m_dir = wxPathOnly( m_path );
}
[oPanel setCanChooseFiles:YES];
[oPanel setMessage:cf.AsNSString()];
+/*
if (parentWindow)
{
NSWindow* nativeParent = parentWindow->GetWXWindow();
- ModalDialogDelegate* sheetDelegate = [[ModalDialogDelegate alloc] init];
- [oPanel beginSheetForDirectory:dir.AsNSString() file:file.AsNSString()
- types: types modalForWindow: nativeParent
- modalDelegate: sheetDelegate
- didEndSelector: @selector(sheetDidEnd:returnCode:contextInfo:)
+ ModalDialogDelegate* sheetDelegate = [[ModalDialogDelegate alloc] init];
+ [oPanel beginSheetForDirectory:dir.AsNSString() file:file.AsNSString()
+ types: types modalForWindow: nativeParent
+ modalDelegate: sheetDelegate
+ didEndSelector: @selector(sheetDidEnd:returnCode:contextInfo:)
contextInfo: nil];
[sheetDelegate waitForSheetToFinish];
- result = [sheetDelegate code];
+ returnCode = [sheetDelegate code];
[sheetDelegate release];
}
else
+*/
{
- result = [oPanel runModalForDirectory:dir.AsNSString()
+ returnCode = [oPanel runModalForDirectory:dir.AsNSString()
file:file.AsNSString() types:types];
}
- if (result == NSOKButton )
+ if (returnCode == NSOKButton )
{
panel = oPanel;
result = wxID_OK;
NSArray* filenames = [oPanel filenames];
for ( size_t i = 0 ; i < [filenames count] ; ++ i )
{
- wxCFStringRef filename( [(NSString*) [filenames objectAtIndex:i] retain] );
- wxString fnstr = filename.AsString();
+ wxString fnstr = wxCFStringRef::AsString([filenames objectAtIndex:i]);
m_paths.Add( fnstr );
m_fileNames.Add( wxFileNameFromPath(fnstr) );
if ( i == 0 )