#include "wx/dcprint.h"
#include "wx/msgdlg.h"
#include "wx/mac/uma.h"
+#ifndef __DARWIN__
+ #include "Printing.h"
+#endif
+
+#if defined(TARGET_CARBON) && !defined(__DARWIN__)
+# if PM_USE_SESSION_APIS
+# include <PMCore.h>
+# endif
+# include <PMApplication.h>
+#endif
// Use generic page setup dialog: use your own native one if one exists.
wxPrintDialog::~wxPrintDialog()
{
- if (m_destroyDC && m_printerDC)
+ if (m_destroyDC && m_printerDC) {
delete m_printerDC;
+ m_printerDC = NULL;
+ }
}
int wxPrintDialog::ShowModal()
wxString message ;
#if !TARGET_CARBON
- err = ::UMAPrOpen() ;
+ err = ::UMAPrOpen(NULL) ;
if ( err == noErr )
{
m_printDialogData.ConvertToNative() ;
- if ( ::PrJobDialog( m_printDialogData.GetPrintData().m_macPrintInfo ) )
+ if ( ::PrJobDialog( (THPrint) m_printDialogData.GetPrintData().m_macPrintSettings ) )
{
m_printDialogData.ConvertFromNative() ;
result = wxID_OK ;
wxMessageDialog dialog( NULL , message , "", wxICON_HAND | wxOK) ;
dialog.ShowModal();
}
- ::UMAPrClose() ;
+ ::UMAPrClose(NULL) ;
#else
#if PM_USE_SESSION_APIS
- PMPrintSession macPrintSession = kPMNoReference;
Boolean accepted;
- err = ::UMAPrOpen(&macPrintSession) ;
- if ( err == noErr )
- {
- m_printDialogData.ConvertToNative() ;
-
- // Set up a valid PageFormat object.
- if (m_printDialogData.GetPrintData().m_macPageFormat == kPMNoPageFormat)
- {
- err = PMCreatePageFormat(&m_printDialogData.GetPrintData().m_macPageFormat);
-
- // Note that PMPageFormat is not session-specific, but calling
- // PMSessionDefaultPageFormat assigns values specific to the printer
- // associated with the current printing session.
- if ((err == noErr) &&
- (m_printDialogData.GetPrintData().m_macPageFormat != kPMNoPageFormat))
- {
- err = PMSessionDefaultPageFormat(macPrintSession,
- m_printDialogData.GetPrintData().m_macPageFormat);
- }
- }
- else
- {
- err = PMSessionValidatePageFormat(macPrintSession,
- m_printDialogData.GetPrintData().m_macPageFormat,
- kPMDontWantBoolean);
- }
+ {
+ m_printDialogData.ConvertToNative() ;
+
+ // Set up a valid PageFormat object.
+ if (m_printDialogData.GetPrintData().m_macPageFormat == kPMNoPageFormat)
+ {
+ err = PMCreatePageFormat((PMPageFormat *)&m_printDialogData.GetPrintData().m_macPageFormat);
+
+ // Note that PMPageFormat is not session-specific, but calling
+ // PMSessionDefaultPageFormat assigns values specific to the printer
+ // associated with the current printing session.
+ if ((err == noErr) &&
+ (m_printDialogData.GetPrintData().m_macPageFormat != kPMNoPageFormat))
+ {
+ err = PMSessionDefaultPageFormat((PMPrintSession)m_printDialogData.GetPrintData().m_macPrintSession,
+ (PMPageFormat)m_printDialogData.GetPrintData().m_macPageFormat);
+ }
+ }
+ else
+ {
+ err = PMSessionValidatePageFormat((PMPrintSession)m_printDialogData.GetPrintData().m_macPrintSession,
+ (PMPageFormat)m_printDialogData.GetPrintData().m_macPageFormat,
+ kPMDontWantBoolean);
+ }
- // Set up a valid PrintSettings object.
- if (m_printDialogData.GetPrintData().m_macPrintSettings == kPMNoPrintSettings)
- {
- err = PMCreatePrintSettings(&m_printDialogData.GetPrintData().m_macPrintSettings);
-
- // Note that PMPrintSettings is not session-specific, but calling
- // PMSessionDefaultPrintSettings assigns values specific to the printer
- // associated with the current printing session.
- if ((err == noErr) &&
- (m_printDialogData.GetPrintData().m_macPrintSettings != kPMNoPrintSettings))
- {
- err = PMSessionDefaultPrintSettings(macPrintSession,
- m_printDialogData.GetPrintData().m_macPrintSettings);
- }
- }
- else
- {
- err = PMSessionValidatePrintSettings(macPrintSession,
- m_printDialogData.GetPrintData().m_macPrintSettings,
- kPMDontWantBoolean);
- }
- // Set a valid page range before displaying the Print dialog
- if (err == noErr)
- {
- // err = PMSetPageRange(m_printDialogData.GetPrintData().m_macPrintSettings,
- // minPage, maxPage);
- }
-
- // Display the Print dialog.
- if (err == noErr)
- {
- err = PMSessionPrintDialog(macPrintSession,
- m_printDialogData.GetPrintData().m_macPrintSettings,
- m_printDialogData.GetPrintData().m_macPageFormat,
- &accepted);
- if ((err == noErr) && !accepted)
- {
- err = kPMCancel; // user clicked Cancel button
- }
- }
- if ( err == noErr )
- {
- m_printDialogData.ConvertFromNative() ;
- result = wxID_OK ;
- }
- }
- if ((err != noErr) && (err != kPMCancel))
- {
- message.Printf( "Print Error %d", err ) ;
- wxMessageDialog dialog( NULL , message , "", wxICON_HAND | wxOK) ;
- dialog.ShowModal();
- }
- ::UMAPrClose(&macPrintSession) ;
+ // Set up a valid PrintSettings object.
+ if (m_printDialogData.GetPrintData().m_macPrintSettings == kPMNoPrintSettings)
+ {
+ err = PMCreatePrintSettings((PMPrintSettings *)&m_printDialogData.GetPrintData().m_macPrintSettings);
+
+ // Note that PMPrintSettings is not session-specific, but calling
+ // PMSessionDefaultPrintSettings assigns values specific to the printer
+ // associated with the current printing session.
+ if ((err == noErr) &&
+ (m_printDialogData.GetPrintData().m_macPrintSettings != kPMNoPrintSettings))
+ {
+ err = PMSessionDefaultPrintSettings((PMPrintSession)m_printDialogData.GetPrintData().m_macPrintSession,
+ (PMPrintSettings)m_printDialogData.GetPrintData().m_macPrintSettings);
+ }
+ }
+ else
+ {
+ err = PMSessionValidatePrintSettings((PMPrintSession)m_printDialogData.GetPrintData().m_macPrintSession,
+ (PMPrintSettings)m_printDialogData.GetPrintData().m_macPrintSettings,
+ kPMDontWantBoolean);
+ }
+ // Set a valid page range before displaying the Print dialog
+ if (err == noErr)
+ {
+ // err = PMSetPageRange(m_printDialogData.GetPrintData().m_macPrintSettings,
+ // minPage, maxPage);
+ }
+
+ // Display the Print dialog.
+ if (err == noErr)
+ {
+ err = PMSessionPrintDialog((PMPrintSession)m_printDialogData.GetPrintData().m_macPrintSession,
+ (PMPrintSettings)m_printDialogData.GetPrintData().m_macPrintSettings,
+ (PMPageFormat)m_printDialogData.GetPrintData().m_macPageFormat,
+ &accepted);
+ if ((err == noErr) && !accepted)
+ {
+ err = kPMCancel; // user clicked Cancel button
+ }
+ }
+ if ( err == noErr )
+ {
+ m_printDialogData.ConvertFromNative() ;
+ result = wxID_OK ;
+ }
+ }
+ if ((err != noErr) && (err != kPMCancel))
+ {
+ message.Printf( "Print Error %d", err ) ;
+ wxMessageDialog dialog( NULL , message , "", wxICON_HAND | wxOK) ;
+ dialog.ShowModal();
+ }
#else
#pragma warning "TODO: Printing for carbon without session apis"
#endif
wxString message ;
#if !TARGET_CARBON
- err = ::UMAPrOpen() ;
+ err = ::UMAPrOpen(NULL) ;
if ( err == noErr )
{
m_pageSetupData.ConvertToNative() ;
- if ( ::PrStlDialog( m_pageSetupData.GetPrintData().m_macPrintInfo ) )
+ if ( ::PrStlDialog( (THPrint) m_pageSetupData.GetPrintData().m_macPrintSettings ) )
{
m_pageSetupData.ConvertFromNative() ;
result = wxID_OK ;
wxMessageDialog dialog( NULL , message , "", wxICON_HAND | wxOK) ;
dialog.ShowModal();
}
- ::UMAPrClose() ;
+ ::UMAPrClose(NULL) ;
#else
#if PM_USE_SESSION_APIS
- PMPrintSession macPrintSession = kPMNoReference;
Boolean accepted;
- err = ::UMAPrOpen(&macPrintSession) ;
- if ( err == noErr )
- {
- m_pageSetupData.ConvertToNative() ;
-
- // Set up a valid PageFormat object.
- if (m_pageSetupData.GetPrintData().m_macPageFormat == kPMNoPageFormat)
- {
- err = PMCreatePageFormat(&m_pageSetupData.GetPrintData().m_macPageFormat);
-
- // Note that PMPageFormat is not session-specific, but calling
- // PMSessionDefaultPageFormat assigns values specific to the printer
- // associated with the current printing session.
- if ((err == noErr) &&
- (m_pageSetupData.GetPrintData().m_macPageFormat != kPMNoPageFormat))
- {
- err = PMSessionDefaultPageFormat(macPrintSession,
- m_pageSetupData.GetPrintData().m_macPageFormat);
- }
- }
- else
- {
- err = PMSessionValidatePageFormat(macPrintSession,
- m_pageSetupData.GetPrintData().m_macPageFormat,
- kPMDontWantBoolean);
- }
-
- // Display the Page Setup dialog.
- if (err == noErr)
- {
- err = PMSessionPageSetupDialog(macPrintSession,
- m_pageSetupData.GetPrintData().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) {
- // err = FlattenAndSavePageFormat(m_pageSetupData.GetPrintData().m_macPageFormat);
- m_pageSetupData.ConvertFromNative() ;
- result = wxID_OK ;
- }
- }
- if ((err != noErr) && (err != kPMCancel))
- {
- message.Printf( "Print Error %d", err ) ;
- wxMessageDialog dialog( NULL , message , "", wxICON_HAND | wxOK) ;
- dialog.ShowModal();
- }
- ::UMAPrClose(&macPrintSession) ;
+ {
+ m_pageSetupData.ConvertToNative() ;
+
+ // Set up a valid PageFormat object.
+ if (m_pageSetupData.GetPrintData().m_macPageFormat == kPMNoPageFormat)
+ {
+ err = PMCreatePageFormat((PMPageFormat *)&m_pageSetupData.GetPrintData().m_macPageFormat);
+
+ // Note that PMPageFormat is not session-specific, but calling
+ // PMSessionDefaultPageFormat assigns values specific to the printer
+ // associated with the current printing session.
+ if ((err == noErr) &&
+ (m_pageSetupData.GetPrintData().m_macPageFormat != kPMNoPageFormat))
+ {
+ err = PMSessionDefaultPageFormat((PMPrintSession)m_pageSetupData.GetPrintData().m_macPrintSession,
+ (PMPageFormat)m_pageSetupData.GetPrintData().m_macPageFormat);
+ }
+ }
+ else
+ {
+ err = PMSessionValidatePageFormat((PMPrintSession)m_pageSetupData.GetPrintData().m_macPrintSession,
+ (PMPageFormat)m_pageSetupData.GetPrintData().m_macPageFormat,
+ kPMDontWantBoolean);
+ }
+
+ // Display the Page Setup dialog.
+ if (err == noErr)
+ {
+ err = PMSessionPageSetupDialog((PMPrintSession)m_pageSetupData.GetPrintData().m_macPrintSession,
+ (PMPageFormat)m_pageSetupData.GetPrintData().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) {
+ // err = FlattenAndSavePageFormat(m_pageSetupData.GetPrintData().m_macPageFormat);
+ m_pageSetupData.ConvertFromNative() ;
+ result = wxID_OK ;
+ }
+ }
+ if ((err != noErr) && (err != kPMCancel))
+ {
+ message.Printf( "Print Error %d", err ) ;
+ wxMessageDialog dialog( NULL , message , "", wxICON_HAND | wxOK) ;
+ dialog.ShowModal();
+ }
#else
#pragma warning "TODO: Printing for carbon without session apis"
#endif