X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3d1a4878f36ba4b5f66c2ccfd2cb27a9dc528b6f..b16de7461ac6d97b0b04a5ce4e73447925e93416:/src/mac/carbon/printdlg.cpp diff --git a/src/mac/carbon/printdlg.cpp b/src/mac/carbon/printdlg.cpp index e39c6dd133..f3ae94abef 100644 --- a/src/mac/carbon/printdlg.cpp +++ b/src/mac/carbon/printdlg.cpp @@ -9,12 +9,10 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) -#pragma implementation "printdlg.h" -#endif - #include "wx/wxprec.h" +#if wxUSE_PRINTING_ARCHITECTURE + #include "wx/object.h" #include "wx/printdlg.h" #include "wx/mac/printdlg.h" @@ -69,10 +67,41 @@ wxMacPrintDialog::~wxMacPrintDialog() int wxMacPrintDialog::ShowModal() { - m_printDialogData.ConvertToNative() ; - int result = m_printDialogData.GetPrintData().m_nativePrintData->ShowPrintDialog() ; + m_printDialogData.GetPrintData().ConvertToNative(); + ((wxMacCarbonPrintData*)m_printDialogData.GetPrintData().GetNativeData())->TransferFrom( &m_printDialogData ) ; + + int result = wxID_CANCEL ; + OSErr err = noErr ; + wxString message ; + + Boolean accepted; + + err = PMSessionPrintDialog( ((wxMacCarbonPrintData*)m_printDialogData.GetPrintData().GetNativeData())->m_macPrintSession, + ((wxMacCarbonPrintData*)m_printDialogData.GetPrintData().GetNativeData())->m_macPrintSettings, + ((wxMacCarbonPrintData*)m_printDialogData.GetPrintData().GetNativeData())->m_macPageFormat, + &accepted); + if ((err == noErr) && !accepted) + { + err = kPMCancel; // user clicked Cancel button + } + + if ( err == noErr ) + { + result = wxID_OK ; + } + + if ((err != noErr) && (err != kPMCancel)) + { + message.Printf( wxT("Print Error %d"), err ) ; + wxMessageDialog dialog( NULL , message , wxEmptyString, wxICON_HAND | wxOK) ; + dialog.ShowModal(); + } + if ( result == wxID_OK ) - m_printDialogData.ConvertFromNative() ; + { + m_printDialogData.GetPrintData().ConvertFromNative(); + ((wxMacCarbonPrintData*)m_printDialogData.GetPrintData().GetNativeData())->TransferTo( &m_printDialogData ) ; + } return result ; } @@ -115,13 +144,44 @@ wxPageSetupData& wxMacPageSetupDialog::GetPageSetupDialogData() int wxMacPageSetupDialog::ShowModal() { - m_pageSetupData.ConvertToNative(); - - int result = m_pageSetupData.GetPrintData().m_nativePrintData->ShowPageSetupDialog(); + m_pageSetupData.GetPrintData().ConvertToNative(); + ((wxMacCarbonPrintData*)m_pageSetupData.GetPrintData().GetNativeData())->TransferFrom( &m_pageSetupData ) ; + + int result = wxID_CANCEL ; + OSErr err = noErr ; + wxString message ; + Boolean accepted; + + err = PMSessionPageSetupDialog( ((wxMacCarbonPrintData*)m_pageSetupData.GetPrintData().GetNativeData())->m_macPrintSession, + ((wxMacCarbonPrintData*)m_pageSetupData.GetPrintData().GetNativeData())->m_macPageFormat, + &accepted); + if ((err == noErr) && !accepted) + { + err = kPMCancel; // user clicked Cancel button + } + + // If the user did not cancel, flatten and save the PageFormat object + // with our document. + if (err == noErr) + { + result = wxID_OK ; + } + if ((err != noErr) && (err != kPMCancel)) + { + message.Printf( wxT("Print Error %d"), err ) ; + wxMessageDialog dialog( NULL , message , wxEmptyString, wxICON_HAND | wxOK) ; + dialog.ShowModal(); + } + if (result == wxID_OK ) - m_pageSetupData.ConvertFromNative(); - + { + m_pageSetupData.GetPrintData().ConvertFromNative(); + m_pageSetupData.SetPaperSize( m_pageSetupData.GetPrintData().GetPaperSize() ) ; + ((wxMacCarbonPrintData*)m_pageSetupData.GetPrintData().GetNativeData())->TransferTo( &m_pageSetupData ) ; + } return result; } +#endif +