X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8907154c1a8a6882c6797d1f16393ddfb23e7f3a..d059fe4a3c45594273788a502b715567850ac7d4:/src/mac/carbon/msgdlg.cpp diff --git a/src/mac/carbon/msgdlg.cpp b/src/mac/carbon/msgdlg.cpp index 315012b368..655d74bc43 100644 --- a/src/mac/carbon/msgdlg.cpp +++ b/src/mac/carbon/msgdlg.cpp @@ -31,8 +31,6 @@ int wxMessageDialog::ShowModal() { int resultbutton = wxID_CANCEL ; - short result ; - const long style = GetMessageDialogStyle(); wxASSERT_MSG( ( style & 0x3F ) != wxYES , wxT("this style is not supported on mac") ) ; @@ -47,6 +45,62 @@ int wxMessageDialog::ShowModal() else if (style & wxICON_QUESTION) alertType = kAlertCautionAlert ; +#if TARGET_API_MAC_OSX + CFStringRef defaultButtonTitle = NULL ; + CFStringRef alternateButtonTitle = NULL ; + CFStringRef otherButtonTitle = NULL ; + + wxMacCFStringHolder cfTitle(m_caption , m_font.GetEncoding()); + wxMacCFStringHolder cfText(m_message , m_font.GetEncoding()); + + wxMacCFStringHolder cfNoString(_("No") , m_font.GetEncoding()) ; + wxMacCFStringHolder cfYesString( _("Yes") , m_font.GetEncoding()) ; + wxMacCFStringHolder cfCancelString( _("Cancel") , m_font.GetEncoding()) ; + + int buttonId[4] = { 0 , 0 , 0 , wxID_CANCEL /* time-out */ } ; + + if (style & wxYES_NO) + { + if ( style & wxNO_DEFAULT ) + { + defaultButtonTitle = cfNoString ; + alternateButtonTitle = cfYesString ; + buttonId[0] = wxID_NO ; + buttonId[1] = wxID_YES ; + } + else + { + defaultButtonTitle = cfYesString ; + alternateButtonTitle = cfNoString ; + buttonId[0] = wxID_YES ; + buttonId[1] = wxID_NO ; + } + if (style & wxCANCEL) + { + otherButtonTitle = cfCancelString ; + buttonId[2] = wxID_CANCEL ; + } + } + else + { + // the msw implementation even shows an ok button if it is not specified, we'll do the same + buttonId[0] = wxID_OK ; + if (style & wxCANCEL) + { + alternateButtonTitle = cfCancelString ; + buttonId[1] = wxID_CANCEL ; + } + } + + CFOptionFlags exitButton ; + OSStatus err = CFUserNotificationDisplayAlert ( 0 , alertType , NULL , NULL , NULL , cfTitle , cfText , + defaultButtonTitle , alternateButtonTitle , otherButtonTitle , &exitButton ); + if ( err == noErr ) + resultbutton = buttonId[exitButton] ; + +#else + short result ; + #if TARGET_CARBON if ( UMAGetSystemVersion() >= 0x1000 ) { @@ -255,7 +309,8 @@ int wxMessageDialog::ShowModal() } } } - +#endif + return resultbutton ; }